Class: PrettyPrint::GroupQueue

Inherits:
Object
  • Object
show all
Defined in:
opal/stdlib/prettyprint.rb

Overview

The GroupQueue class is used for managing the queue of Group to be pretty printed.

This queue groups the Group objects, based on their depth.

This class is intended for internal use of the PrettyPrint buffers.

Instance Method Summary collapse

Constructor Details

#initialize(*groups) ⇒ GroupQueue

Create a GroupQueue object

Arguments:

  • +groups+ - one or more PrettyPrint::Group objects
[View source]

445
446
447
448
# File 'opal/stdlib/prettyprint.rb', line 445

def initialize(*groups)
  @queue = []
  groups.each {|g| enq g}
end

Instance Method Details

#delete(group) ⇒ Object

Remote +group+ from this queue

[View source]

477
478
479
# File 'opal/stdlib/prettyprint.rb', line 477

def delete(group)
  @queue[group.depth].delete(group)
end

#deqObject

Returns the outer group of the queue

[View source]

461
462
463
464
465
466
467
468
469
470
471
472
473
474
# File 'opal/stdlib/prettyprint.rb', line 461

def deq
  @queue.each {|gs|
    (gs.length-1).downto(0) {|i|
      unless gs[i].breakables.empty?
        group = gs.slice!(i, 1).first
        group.break
        return group
      end
    }
    gs.each {|group| group.break}
    gs.clear
  }
  return nil
end

#enq(group) ⇒ Object

Enqueue +group+

This does not strictly append the group to the end of the queue, but instead adds it in line, base on the +group.depth+

[View source]

454
455
456
457
458
# File 'opal/stdlib/prettyprint.rb', line 454

def enq(group)
  depth = group.depth
  @queue << [] until depth < @queue.length
  @queue[depth] << group
end