mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-29 23:15:28 +08:00
39 lines
830 B
Go
39 lines
830 B
Go
package utility
|
|
|
|
import (
|
|
"github.com/milvus-io/milvus/pkg/streaming/util/message"
|
|
"github.com/milvus-io/milvus/pkg/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()
|
|
}
|