Class: SyntaxTree::MRHS
- Inherits:
-
Node
- Object
- Node
- SyntaxTree::MRHS
show all
- Defined in:
- lib/syntax_tree/node.rb
Overview
MRHS represents the values that are being assigned on the right-hand side of a multiple assignment.
values = first, second, third
Instance Attribute Summary collapse
Attributes inherited from Node
#location
Instance Method Summary
collapse
Methods inherited from Node
#construct_keys, #end_char, #pretty_print, #start_char, #to_json, #to_mermaid
Constructor Details
#initialize(parts:, location:) ⇒ MRHS
Returns a new instance of MRHS.
7876
7877
7878
7879
7880
|
# File 'lib/syntax_tree/node.rb', line 7876
def initialize(parts:, location:)
@parts = parts
@location = location
= []
end
|
Instance Attribute Details
- Array[ Comment | EmbDoc ]
-
the comments attached to this node
7874
7875
7876
|
# File 'lib/syntax_tree/node.rb', line 7874
def
end
|
#parts ⇒ Object
- Array
-
the parts that are being assigned
7871
7872
7873
|
# File 'lib/syntax_tree/node.rb', line 7871
def parts
@parts
end
|
Instance Method Details
#===(other) ⇒ Object
7911
7912
7913
|
# File 'lib/syntax_tree/node.rb', line 7911
def ===(other)
other.is_a?(MRHS) && ArrayMatch.call(parts, other.parts)
end
|
#accept(visitor) ⇒ Object
7882
7883
7884
|
# File 'lib/syntax_tree/node.rb', line 7882
def accept(visitor)
visitor.visit_mrhs(self)
end
|
#child_nodes ⇒ Object
Also known as:
deconstruct
7886
7887
7888
|
# File 'lib/syntax_tree/node.rb', line 7886
def child_nodes
parts
end
|
#copy(parts: nil, location: nil) ⇒ Object
7890
7891
7892
7893
7894
7895
7896
7897
7898
7899
|
# File 'lib/syntax_tree/node.rb', line 7890
def copy(parts: nil, location: nil)
node =
MRHS.new(
parts: parts || self.parts,
location: location || self.location
)
node..concat(.map(&:copy))
node
end
|
#deconstruct_keys(_keys) ⇒ Object
7903
7904
7905
|
# File 'lib/syntax_tree/node.rb', line 7903
def deconstruct_keys(_keys)
{ parts: parts, location: location, comments: }
end
|
7907
7908
7909
|
# File 'lib/syntax_tree/node.rb', line 7907
def format(q)
q.seplist(parts) { |part| q.format(part) }
end
|