Class: SyntaxTree::MAssign
Overview
MAssign is a parent node of any kind of multiple assignment. This includes splitting out variables on the left like:
first, second, third = value
as well as splitting out variables on the right, as in:
value = first, second, third
Both sides support splats, as well as variables following them. There’s also destructuring behavior that you can achieve with the following:
first, = value
Instance Attribute Summary collapse
-
#comments ⇒ Object
readonly
- Array[ Comment | EmbDoc ]
-
the comments attached to this node.
-
#target ⇒ Object
readonly
- MLHS | MLHSParen
-
the target of the multiple assignment.
-
#value ⇒ Object
readonly
- Node
-
the value being assigned.
Attributes inherited from Node
Instance Method Summary collapse
- #===(other) ⇒ Object
- #accept(visitor) ⇒ Object
- #child_nodes ⇒ Object (also: #deconstruct)
- #copy(target: nil, value: nil, location: nil) ⇒ Object
- #deconstruct_keys(_keys) ⇒ Object
- #format(q) ⇒ Object
-
#initialize(target:, value:, location:) ⇒ MAssign
constructor
A new instance of MAssign.
Methods inherited from Node
#construct_keys, #end_char, #pretty_print, #start_char, #to_json, #to_mermaid
Constructor Details
#initialize(target:, value:, location:) ⇒ MAssign
Returns a new instance of MAssign.
7510 7511 7512 7513 7514 7515 |
# File 'lib/syntax_tree/node.rb', line 7510 def initialize(target:, value:, location:) @target = target @value = value @location = location @comments = [] end |
Instance Attribute Details
#comments ⇒ Object (readonly)
- Array[ Comment | EmbDoc ]
-
the comments attached to this node
7508 7509 7510 |
# File 'lib/syntax_tree/node.rb', line 7508 def comments @comments end |
#target ⇒ Object (readonly)
- MLHS | MLHSParen
-
the target of the multiple assignment
7502 7503 7504 |
# File 'lib/syntax_tree/node.rb', line 7502 def target @target end |
#value ⇒ Object (readonly)
- Node
-
the value being assigned
7505 7506 7507 |
# File 'lib/syntax_tree/node.rb', line 7505 def value @value end |
Instance Method Details
#===(other) ⇒ Object
7554 7555 7556 |
# File 'lib/syntax_tree/node.rb', line 7554 def ===(other) other.is_a?(MAssign) && target === other.target && value === other.value end |
#accept(visitor) ⇒ Object
7517 7518 7519 |
# File 'lib/syntax_tree/node.rb', line 7517 def accept(visitor) visitor.visit_massign(self) end |
#child_nodes ⇒ Object Also known as: deconstruct
7521 7522 7523 |
# File 'lib/syntax_tree/node.rb', line 7521 def child_nodes [target, value] end |
#copy(target: nil, value: nil, location: nil) ⇒ Object
7525 7526 7527 7528 7529 7530 7531 7532 7533 7534 7535 |
# File 'lib/syntax_tree/node.rb', line 7525 def copy(target: nil, value: nil, location: nil) node = MAssign.new( target: target || self.target, value: value || self.value, location: location || self.location ) node.comments.concat(comments.map(&:copy)) node end |
#deconstruct_keys(_keys) ⇒ Object
7539 7540 7541 |
# File 'lib/syntax_tree/node.rb', line 7539 def deconstruct_keys(_keys) { target: target, value: value, location: location, comments: comments } end |
#format(q) ⇒ Object
7543 7544 7545 7546 7547 7548 7549 7550 7551 7552 |
# File 'lib/syntax_tree/node.rb', line 7543 def format(q) q.group do q.group { q.format(target) } q.text(" =") q.indent do q.breakable_space q.format(value) end end end |