Browse Source

close the input

pull/5637/head
chrislu 12 months ago
parent
commit
5dc1362bdc
  1. 24
      weed/util/buffered_queue/buffered_queue.go

24
weed/util/buffered_queue/buffered_queue.go

@ -1,6 +1,7 @@
package buffered_queue
import (
"fmt"
"sync"
)
@ -24,6 +25,7 @@ type BufferedQueue[T any] struct {
nodeCounter int
waitOnRead bool
waitCond *sync.Cond
isClosed bool
}
// NewBufferedQueue creates a new buffered queue with the specified chunk size
@ -44,7 +46,12 @@ func NewBufferedQueue[T any](chunkSize int, waitOnRead bool) *BufferedQueue[T] {
}
// Enqueue adds a job to the queue
func (q *BufferedQueue[T]) Enqueue(job T) {
func (q *BufferedQueue[T]) Enqueue(job T) error {
if q.isClosed {
return fmt.Errorf("queue is closed")
}
q.mutex.Lock()
defer q.mutex.Unlock()
@ -73,6 +80,8 @@ func (q *BufferedQueue[T]) Enqueue(job T) {
if q.waitOnRead {
q.waitCond.Signal()
}
return nil
}
// Dequeue removes and returns a job from the queue
@ -81,9 +90,13 @@ func (q *BufferedQueue[T]) Dequeue() (T, bool) {
defer q.mutex.Unlock()
if q.waitOnRead {
for q.count <= 0 {
for q.count <= 0 && !q.isClosed {
q.waitCond.Wait()
}
if q.isClosed {
var a T
return a, false
}
} else {
if q.count == 0 {
var a T
@ -124,3 +137,10 @@ func (q *BufferedQueue[T]) Size() int {
func (q *BufferedQueue[T]) IsEmpty() bool {
return q.Size() == 0
}
func (q *BufferedQueue[T]) CloseInput() {
q.mutex.Lock()
defer q.mutex.Unlock()
q.isClosed = true
q.waitCond.Broadcast()
}
Loading…
Cancel
Save