Class: SyntaxTree::StringConcat
Overview
StringConcat represents concatenating two strings together using a backward slash.
"first" \
"second"
Instance Attribute Summary collapse
-
#comments ⇒ Object
readonly
- Array[ Comment | EmbDoc ]
-
the comments attached to this node.
-
#left ⇒ Object
readonly
- Heredoc | StringConcat | StringLiteral
-
the left side of the concatenation.
-
#right ⇒ Object
readonly
- StringLiteral
-
the right side of the concatenation.
Attributes inherited from Node
Instance Method Summary collapse
- #===(other) ⇒ Object
- #accept(visitor) ⇒ Object
- #child_nodes ⇒ Object (also: #deconstruct)
- #copy(left: nil, right: nil, location: nil) ⇒ Object
- #deconstruct_keys(_keys) ⇒ Object
- #format(q) ⇒ Object
-
#initialize(left:, right:, location:) ⇒ StringConcat
constructor
A new instance of StringConcat.
Methods inherited from Node
#construct_keys, #end_char, #pretty_print, #start_char, #to_json, #to_mermaid
Constructor Details
#initialize(left:, right:, location:) ⇒ StringConcat
Returns a new instance of StringConcat.
10135 10136 10137 10138 10139 10140 |
# File 'lib/syntax_tree/node.rb', line 10135 def initialize(left:, right:, location:) @left = left @right = right @location = location @comments = [] end |
Instance Attribute Details
#comments ⇒ Object (readonly)
- Array[ Comment | EmbDoc ]
-
the comments attached to this node
10133 10134 10135 |
# File 'lib/syntax_tree/node.rb', line 10133 def comments @comments end |
#left ⇒ Object (readonly)
- Heredoc | StringConcat | StringLiteral
-
the left side of the
concatenation
10127 10128 10129 |
# File 'lib/syntax_tree/node.rb', line 10127 def left @left end |
#right ⇒ Object (readonly)
- StringLiteral
-
the right side of the concatenation
10130 10131 10132 |
# File 'lib/syntax_tree/node.rb', line 10130 def right @right end |
Instance Method Details
#===(other) ⇒ Object
10179 10180 10181 |
# File 'lib/syntax_tree/node.rb', line 10179 def ===(other) other.is_a?(StringConcat) && left === other.left && right === other.right end |
#accept(visitor) ⇒ Object
10142 10143 10144 |
# File 'lib/syntax_tree/node.rb', line 10142 def accept(visitor) visitor.visit_string_concat(self) end |
#child_nodes ⇒ Object Also known as: deconstruct
10146 10147 10148 |
# File 'lib/syntax_tree/node.rb', line 10146 def child_nodes [left, right] end |
#copy(left: nil, right: nil, location: nil) ⇒ Object
10150 10151 10152 10153 10154 10155 10156 10157 10158 10159 10160 |
# File 'lib/syntax_tree/node.rb', line 10150 def copy(left: nil, right: nil, location: nil) node = StringConcat.new( left: left || self.left, right: right || self.right, location: location || self.location ) node.comments.concat(comments.map(&:copy)) node end |
#deconstruct_keys(_keys) ⇒ Object
10164 10165 10166 |
# File 'lib/syntax_tree/node.rb', line 10164 def deconstruct_keys(_keys) { left: left, right: right, location: location, comments: comments } end |
#format(q) ⇒ Object
10168 10169 10170 10171 10172 10173 10174 10175 10176 10177 |
# File 'lib/syntax_tree/node.rb', line 10168 def format(q) q.group do q.format(left) q.text(" \\") q.indent do q.breakable_force q.format(right) end end end |