Sha256: c0afec64b53718fc021ba88922f9d0cd25ef3394b766d20e0bb28895f832abe0
Contents?: true
Size: 1.18 KB
Versions: 1
Compression:
Stored size: 1.18 KB
Contents
module Arel module Nodes ### # Abstract base class for all AST nodes class Node include Enumerable ### # Factory method to create a Nodes::Not node that has the recipient of # the caller as a child. def not Nodes::Not.new self end ### # Factory method to create a Nodes::Grouping node that has an Nodes::Or # node as a child. def or right Nodes::Grouping.new Nodes::Or.new(self, right) end ### # Factory method to create an Nodes::And node. def and right Nodes::And.new self, right end # FIXME: this method should go away. I don't like people calling # to_sql on non-head nodes. This forces us to walk the AST until we # can find a node that has a "relation" member. # # Maybe we should just use `Table.engine`? :'( def to_sql engine = Table.engine viz = Visitors.for engine viz.accept self end # Iterate through AST, nodes will be yielded depth-first def each &block return enum_for(:each) unless block_given? Visitors::DepthFirst.new(block).accept self end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
arel-2.0.5 | lib/arel/nodes/node.rb |