12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- package node
- import (
- "github.com/lf-edge/ekuiper/pkg/api"
- "sync/atomic"
- )
- type DynamicChannelBuffer struct {
- limit int64
- In chan api.SourceTuple
- Out chan api.SourceTuple
- buffer []api.SourceTuple
- done chan bool
- }
- func NewDynamicChannelBuffer() *DynamicChannelBuffer {
- buffer := &DynamicChannelBuffer{
- In: make(chan api.SourceTuple),
- Out: make(chan api.SourceTuple),
- buffer: make([]api.SourceTuple, 0),
- limit: 102400,
- done: make(chan bool, 1),
- }
- go buffer.run()
- return buffer
- }
- func (b *DynamicChannelBuffer) SetLimit(limit int) {
- if limit > 0 {
- atomic.StoreInt64(&b.limit, int64(limit))
- }
- }
- func (b *DynamicChannelBuffer) run() {
- for {
- l := len(b.buffer)
- if int64(l) >= atomic.LoadInt64(&b.limit) {
- select {
- case b.Out <- b.buffer[0]:
- b.buffer = b.buffer[1:]
- case <-b.done:
- return
- }
- } 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)
- case <-b.done:
- return
- }
- } else {
- select {
- case value := <-b.In:
- b.buffer = append(b.buffer, value)
- case <-b.done:
- return
- }
- }
- }
- }
- func (b *DynamicChannelBuffer) GetLength() int {
- return len(b.buffer)
- }
- func (b *DynamicChannelBuffer) Close() {
- b.done <- true
- }
|