Returns list of ancestors, starting from parent until root.
subchild1.ancestors # => [child1, root]
# File lib/sequel/plugins/tree.rb, line 94 def ancestors node, nodes = self, [] nodes << node = node.parent while node.parent nodes end
Returns list of descendants
node.descendants # => [child1, child2, subchild1_1, subchild1_2, subchild2_1, subchild2_2]
# File lib/sequel/plugins/tree.rb, line 103 def descendants nodes = children.dup children.each{|child| nodes.concat(child.descendants)} nodes end
Returns the root node of the tree that this node descends from. This node is returned if it is a root node itself.
# File lib/sequel/plugins/tree.rb, line 111 def root ancestors.last || self end
Returns true if this is a root node, false otherwise.
# File lib/sequel/plugins/tree.rb, line 116 def root? !new? && possible_root? end
Returns all siblings and a reference to the current node.
subchild1.self_and_siblings # => [subchild1, subchild2]
# File lib/sequel/plugins/tree.rb, line 123 def self_and_siblings parent ? parent.children : model.roots end
Returns all siblings of the current node.
subchild1.siblings # => [subchild2]
# File lib/sequel/plugins/tree.rb, line 130 def siblings self_and_siblings - [self] end