123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- package nodes
- import "github.com/emqx/kuiper/xstream/api"
- type DynamicChannelBuffer struct {
- In chan api.SourceTuple
- Out chan api.SourceTuple
- buffer []api.SourceTuple
- limit int
- }
- func NewDynamicChannelBuffer() *DynamicChannelBuffer {
- buffer := &DynamicChannelBuffer{
- In: make(chan api.SourceTuple),
- Out: make(chan api.SourceTuple),
- buffer: make([]api.SourceTuple, 0),
- limit: 102400,
- }
- go buffer.run()
- return buffer
- }
- func (b *DynamicChannelBuffer) SetLimit(limit int) {
- if limit > 0 {
- b.limit = limit
- }
- }
- func (b *DynamicChannelBuffer) run() {
- for {
- l := len(b.buffer)
- if l >= b.limit {
- b.Out <- b.buffer[0]
- b.buffer = b.buffer[1:]
- } else if l > 0 {
- select {
- case b.Out <- b.buffer[0]:
- b.buffer = b.buffer[1:]
- case value := <-b.In:
- b.buffer = append(b.buffer, value)
- }
- } else {
- value := <-b.In
- b.buffer = append(b.buffer, value)
- }
- }
- }
- func (b *DynamicChannelBuffer) GetLength() int {
- return len(b.buffer)
- }
|