mirror of
https://gitee.com/milvus-io/milvus.git
synced 2026-02-02 01:06:41 +08:00
Cherry-pick from master pr: #39990 Related to #39095 https://go.dev/doc/modules/version-numbers Update pkg version according to golang dep version convention Signed-off-by: Congqi Xia <congqi.xia@zilliz.com>
56 lines
1.4 KiB
Go
56 lines
1.4 KiB
Go
package message
|
|
|
|
import (
|
|
"github.com/cockroachdb/errors"
|
|
|
|
"github.com/milvus-io/milvus/pkg/v2/util/typeutil"
|
|
)
|
|
|
|
var (
|
|
// messageIDUnmarshaler is the map for message id unmarshaler.
|
|
messageIDUnmarshaler typeutil.ConcurrentMap[string, MessageIDUnmarshaler]
|
|
|
|
ErrInvalidMessageID = errors.New("invalid message id")
|
|
)
|
|
|
|
// RegisterMessageIDUnmsarshaler register the message id unmarshaler.
|
|
func RegisterMessageIDUnmsarshaler(name string, unmarshaler MessageIDUnmarshaler) {
|
|
_, loaded := messageIDUnmarshaler.GetOrInsert(name, unmarshaler)
|
|
if loaded {
|
|
panic("MessageID Unmarshaler already registered: " + name)
|
|
}
|
|
}
|
|
|
|
// MessageIDUnmarshaler is the unmarshaler for message id.
|
|
type MessageIDUnmarshaler = func(b string) (MessageID, error)
|
|
|
|
// UnmsarshalMessageID unmarshal the message id.
|
|
func UnmarshalMessageID(name string, b string) (MessageID, error) {
|
|
unmarshaler, ok := messageIDUnmarshaler.Get(name)
|
|
if !ok {
|
|
panic("MessageID Unmarshaler not registered: " + name)
|
|
}
|
|
return unmarshaler(b)
|
|
}
|
|
|
|
// MessageID is the interface for message id.
|
|
type MessageID interface {
|
|
// WALName returns the name of message id related wal.
|
|
WALName() string
|
|
|
|
// LT less than.
|
|
LT(MessageID) bool
|
|
|
|
// LTE less than or equal to.
|
|
LTE(MessageID) bool
|
|
|
|
// EQ Equal to.
|
|
EQ(MessageID) bool
|
|
|
|
// Marshal marshal the message id.
|
|
Marshal() string
|
|
|
|
// Convert into string for logging.
|
|
String() string
|
|
}
|