Sha256: fce9f8fcf4aa3af5319ba425cfd365cb1a07ca16dfcdaf3d45951ea9d053e515

Contents?: true

Size: 1.26 KB

Versions: 6

Compression:

Stored size: 1.26 KB

Contents

require_relative 'queue'

module LightIO::Library
  class SizedQueue < LightIO::Library::Queue
    extend Base::MockMethods
    mock ::SizedQueue

    attr_accessor :max

    def initialize(max)
      raise ArgumentError, 'queue size must be positive' unless max > 0
      super()
      @max = max
      @enqueue_waiters = []
    end

    def push(object)
      raise ClosedQueueError, "queue closed" if @close
      if size >= max
        future = LightIO::Future.new
        @enqueue_waiters << future
        future.value
      end
      super
      self
    end

    alias enq push
    alias << push

    def pop(non_block=false)
      result = super
      check_release_enqueue_waiter
      result
    end

    alias deq pop
    alias shift pop

    def clear
      result = super
      check_release_enqueue_waiter
      result
    end

    def max=(value)
      @max = value
      check_release_enqueue_waiter if size < max
    end

    def num_waiting
      super + @enqueue_waiters.size
    end

    private
    def check_release_enqueue_waiter
      if @enqueue_waiters.any?
        future = LightIO::Future.new
        LightIO::IOloop.current.add_callback {
          @enqueue_waiters.shift.transfer
          future.transfer
        }
        future.value
      end
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
lightio-0.4.4 lib/lightio/library/sized_queue.rb
lightio-0.4.3 lib/lightio/library/sized_queue.rb
lightio-0.4.2 lib/lightio/library/sized_queue.rb
lightio-0.4.1 lib/lightio/library/sized_queue.rb
lightio-0.4.0 lib/lightio/library/sized_queue.rb
lightio-0.4.0.pre lib/lightio/library/sized_queue.rb