Sha256: e62b2789ea31cdab4958d68889b6338920213d94300439ce1269c4c5eb3ac018

Contents?: true

Size: 566 Bytes

Versions: 2

Compression:

Stored size: 566 Bytes

Contents

require "tsort"

module Ykytils
  class TreeManager
    include TSort

    def initialize
      @table = {}
    end

    def add(parent_name, name)
      if parent_name
        parent = @table[parent_name]
        if parent
          @table[parent_name] << name
        else
          @table[parent_name] = [name]
        end
      else
        @table[name] = []
      end
    end

    def tsort_each_child(node, &block)
      ary = @table[node]
      ary.each(&block) if ary
    end

    def tsort_each_node(&block)
      @table.keys.each(&block)
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
ykutils-0.1.7 lib/ykutils/treemanager.rb
ykutils-0.1.6 lib/ykutils/treemanager.rb