Sha256: 542fa0d3c238d97addba7e063673307b11b4352bb55d3c4076d8025c2f8c9878

Contents?: true

Size: 1.66 KB

Versions: 7

Compression:

Stored size: 1.66 KB

Contents

module GraphQL::Relay::Walker
  class Queue
    attr_accessor :max_size, :random_idx
    attr_reader   :queue, :seen

    # Initialize a new Queue.
    #
    # max_size:   - The maximum size the queue can grow to. This helps when
    #               walking a large graph by forcing us to walk deeper.
    # random_idx: - Add frames to the queue at random indicies. This helps when
    #               walking a large graph by forcing us to walk deeper.
    #
    # Returns nothing.
    def initialize(max_size: nil, random_idx: false)
      @max_size = max_size
      @random_idx = random_idx

      @queue = []
      @seen = Set.new
    end

    # Add a frame to the queue if its GID hasn't been seen already and the queue
    # hasn't exceeded its max size.
    #
    # frame - The Frame to add to the queue.
    #
    # Returns true if the frame was added, false otherwise.
    def add(frame)
      return false if max_size && queue.length >= max_size
      return false if seen.include?(frame.gid)

      seen.add(frame.gid)
      idx = random_idx ? rand(queue.length + 1) : queue.length
      queue.insert(idx, frame)

      true
    end

    # Add a GID to the queue.
    #
    # gid    - The String GID to add to the queue.
    # parent - The frame where this GID was discovered (optional).
    #
    # Returns true if a frame was added, false otherwise.
    def add_gid(gid, parent=nil)
      frame = Frame.new(self, gid, parent)
      add(frame)
    end

    # Iterate through the queue, yielding each frame.
    #
    # Returns nothing.
    def each_frame
      return enum_for(:each_frame) unless block_given?

      while frame = queue.shift
        yield(frame)
      end
    end
  end
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
graphql-relay-walker-0.0.9 lib/graphql/relay/walker/queue.rb
graphql-relay-walker-0.0.8 lib/graphql/relay/walker/queue.rb
graphql-relay-walker-0.0.7 lib/graphql/relay/walker/queue.rb
graphql-relay-walker-0.0.6 lib/graphql/relay/walker/queue.rb
graphql-relay-walker-0.0.5 lib/graphql/relay/walker/queue.rb
graphql-relay-walker-0.0.4 lib/graphql/relay/walker/queue.rb
graphql-relay-walker-0.0.3 lib/graphql/relay/walker/queue.rb