Class: SyntaxTree::Binary

Inherits:
Node
  • Object
show all
Defined in:
lib/syntax_tree/node.rb

Overview

Binary represents any expression that involves two sub-expressions with an operator in between. This can be something that looks like a mathematical operation:

1 + 1

but can also be something like pushing a value onto an array:

array << value

Instance Attribute Summary collapse

Attributes inherited from Node

#location

Instance Method Summary collapse

Methods inherited from Node

#construct_keys, #pretty_print, #to_json

Constructor Details

#initialize(left:, operator:, right:, location:) ⇒ Binary

Returns a new instance of Binary.



2050
2051
2052
2053
2054
2055
2056
# File 'lib/syntax_tree/node.rb', line 2050

def initialize(left:, operator:, right:, location:)
  @left = left
  @operator = operator
  @right = right
  @location = location
  @comments = []
end

Instance Attribute Details

#commentsObject (readonly)

Array[ Comment | EmbDoc ]

the comments attached to this node



2048
2049
2050
# File 'lib/syntax_tree/node.rb', line 2048

def comments
  @comments
end

#leftObject (readonly)

untyped

the left-hand side of the expression



2039
2040
2041
# File 'lib/syntax_tree/node.rb', line 2039

def left
  @left
end

#operatorObject (readonly)

Symbol

the operator used between the two expressions



2042
2043
2044
# File 'lib/syntax_tree/node.rb', line 2042

def operator
  @operator
end

#rightObject (readonly)

untyped

the right-hand side of the expression



2045
2046
2047
# File 'lib/syntax_tree/node.rb', line 2045

def right
  @right
end

Instance Method Details

#===(other) ⇒ Object



2113
2114
2115
2116
# File 'lib/syntax_tree/node.rb', line 2113

def ===(other)
  other.is_a?(Binary) && left === other.left &&
    operator === other.operator && right === other.right
end

#accept(visitor) ⇒ Object



2058
2059
2060
# File 'lib/syntax_tree/node.rb', line 2058

def accept(visitor)
  visitor.visit_binary(self)
end

#child_nodesObject Also known as: deconstruct



2062
2063
2064
# File 'lib/syntax_tree/node.rb', line 2062

def child_nodes
  [left, right]
end

#copy(left: nil, operator: nil, right: nil, location: nil) ⇒ Object



2066
2067
2068
2069
2070
2071
2072
2073
2074
2075
2076
2077
# File 'lib/syntax_tree/node.rb', line 2066

def copy(left: nil, operator: nil, right: nil, location: nil)
  node =
    Binary.new(
      left: left || self.left,
      operator: operator || self.operator,
      right: right || self.right,
      location: location || self.location
    )

  node.comments.concat(comments.map(&:copy))
  node
end

#deconstruct_keys(_keys) ⇒ Object



2081
2082
2083
2084
2085
2086
2087
2088
2089
# File 'lib/syntax_tree/node.rb', line 2081

def deconstruct_keys(_keys)
  {
    left: left,
    operator: operator,
    right: right,
    location: location,
    comments: comments
  }
end

#format(q) ⇒ Object



2091
2092
2093
2094
2095
2096
2097
2098
2099
2100
2101
2102
2103
2104
2105
2106
2107
2108
2109
2110
2111
# File 'lib/syntax_tree/node.rb', line 2091

def format(q)
  power = operator == :**

  q.group do
    q.group { q.format(left) }
    q.text(" ") unless power

    if operator == :<<
      q.text("<< ")
      q.format(right)
    else
      q.group do
        q.text(operator.name)
        q.indent do
          power ? q.breakable_empty : q.breakable_space
          q.format(right)
        end
      end
    end
  end
end