mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-28 22:45:26 +08:00
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>
39 lines
836 B
Go
39 lines
836 B
Go
package utility
|
|
|
|
import (
|
|
"github.com/milvus-io/milvus/pkg/v2/streaming/util/message"
|
|
"github.com/milvus-io/milvus/pkg/v2/util/typeutil"
|
|
)
|
|
|
|
type PendingQueue struct {
|
|
*typeutil.MultipartQueue[message.ImmutableMessage]
|
|
bytes int
|
|
}
|
|
|
|
func NewPendingQueue() *PendingQueue {
|
|
return &PendingQueue{
|
|
MultipartQueue: typeutil.NewMultipartQueue[message.ImmutableMessage](),
|
|
}
|
|
}
|
|
|
|
func (q *PendingQueue) Bytes() int {
|
|
return q.bytes
|
|
}
|
|
|
|
func (q *PendingQueue) Add(msg []message.ImmutableMessage) {
|
|
for _, m := range msg {
|
|
q.bytes += m.EstimateSize()
|
|
}
|
|
q.MultipartQueue.Add(msg)
|
|
}
|
|
|
|
func (q *PendingQueue) AddOne(msg message.ImmutableMessage) {
|
|
q.bytes += msg.EstimateSize()
|
|
q.MultipartQueue.AddOne(msg)
|
|
}
|
|
|
|
func (q *PendingQueue) UnsafeAdvance() {
|
|
q.bytes -= q.MultipartQueue.Next().EstimateSize()
|
|
q.MultipartQueue.UnsafeAdvance()
|
|
}
|