class BasicTree include Enumerable VERSION = "1.0.0" def initialize(object, parent = nil, &block) self.object = object if parent self.parent = parent parent.children << self end instance_eval(&block) if block_given? end attr_accessor :object, :parent def add(object, &block) self.class.new(object, self, &block) end def path ancestors << self end def ancestors root? ? [] : (parent.ancestors << parent) end def descendants children.map { |c| [c] + c.descendants }.flatten end def subtree [self] + descendants end def siblings root? ? [] : parent.children.select { |child| child != self } end def root path.first end def level path.size end def root? !parent end def leaf? children.empty? end def children @children ||= [] end end