Class: SyntaxTree::BlockVar
Overview
BlockVar represents the parameters being declared for a block. Effectively this node is everything contained within the pipes. This includes all of the various parameter types, as well as block-local variable declarations.
method do |positional, optional = value, keyword:, █ local|
end
Defined Under Namespace
Classes: Separator
Constant Summary collapse
- SEPARATOR =
We’ll keep a single instance of this separator around for all block vars to cut down on allocations.
Separator.new.freeze
Instance Attribute Summary collapse
-
#comments ⇒ Object
readonly
- Array[ Comment | EmbDoc ]
-
the comments attached to this node.
-
#locals ⇒ Object
readonly
- Array[ Ident ]
-
the list of block-local variable declarations.
-
#params ⇒ Object
readonly
- Params
-
the parameters being declared with the block.
Attributes inherited from Node
Instance Method Summary collapse
- #===(other) ⇒ Object
- #accept(visitor) ⇒ Object
-
#arg0? ⇒ Boolean
When a single required parameter is declared for a block, it gets automatically expanded if the values being yielded into it are an array.
- #child_nodes ⇒ Object (also: #deconstruct)
- #copy(params: nil, locals: nil, location: nil) ⇒ Object
- #deconstruct_keys(_keys) ⇒ Object
- #format(q) ⇒ Object
-
#initialize(params:, locals:, location:) ⇒ BlockVar
constructor
A new instance of BlockVar.
Methods inherited from Node
#construct_keys, #end_char, #pretty_print, #start_char, #to_json, #to_mermaid
Constructor Details
#initialize(params:, locals:, location:) ⇒ BlockVar
Returns a new instance of BlockVar.
2151 2152 2153 2154 2155 2156 |
# File 'lib/syntax_tree/node.rb', line 2151 def initialize(params:, locals:, location:) @params = params @locals = locals @location = location @comments = [] end |
Instance Attribute Details
#comments ⇒ Object (readonly)
- Array[ Comment | EmbDoc ]
-
the comments attached to this node
2149 2150 2151 |
# File 'lib/syntax_tree/node.rb', line 2149 def comments @comments end |
#locals ⇒ Object (readonly)
- Array[ Ident ]
-
the list of block-local variable declarations
2146 2147 2148 |
# File 'lib/syntax_tree/node.rb', line 2146 def locals @locals end |
#params ⇒ Object (readonly)
- Params
-
the parameters being declared with the block
2143 2144 2145 |
# File 'lib/syntax_tree/node.rb', line 2143 def params @params end |
Instance Method Details
#===(other) ⇒ Object
2209 2210 2211 2212 |
# File 'lib/syntax_tree/node.rb', line 2209 def ===(other) other.is_a?(BlockVar) && params === other.params && ArrayMatch.call(locals, other.locals) end |
#accept(visitor) ⇒ Object
2158 2159 2160 |
# File 'lib/syntax_tree/node.rb', line 2158 def accept(visitor) visitor.visit_block_var(self) end |
#arg0? ⇒ Boolean
When a single required parameter is declared for a block, it gets automatically expanded if the values being yielded into it are an array.
2216 2217 2218 2219 2220 |
# File 'lib/syntax_tree/node.rb', line 2216 def arg0? params.requireds.length == 1 && params.optionals.empty? && params.rest.nil? && params.posts.empty? && params.keywords.empty? && params.keyword_rest.nil? && params.block.nil? end |
#child_nodes ⇒ Object Also known as: deconstruct
2162 2163 2164 |
# File 'lib/syntax_tree/node.rb', line 2162 def child_nodes [params, *locals] end |
#copy(params: nil, locals: nil, location: nil) ⇒ Object
2166 2167 2168 2169 2170 2171 2172 2173 2174 2175 2176 |
# File 'lib/syntax_tree/node.rb', line 2166 def copy(params: nil, locals: nil, location: nil) node = BlockVar.new( params: params || self.params, locals: locals || self.locals, location: location || self.location ) node.comments.concat(comments.map(&:copy)) node end |
#deconstruct_keys(_keys) ⇒ Object
2180 2181 2182 |
# File 'lib/syntax_tree/node.rb', line 2180 def deconstruct_keys(_keys) { params: params, locals: locals, location: location, comments: comments } end |
#format(q) ⇒ Object
2196 2197 2198 2199 2200 2201 2202 2203 2204 2205 2206 2207 |
# File 'lib/syntax_tree/node.rb', line 2196 def format(q) q.text("|") q.group do q.remove_breaks(q.format(params)) if locals.any? q.text("; ") q.seplist(locals, SEPARATOR) { |local| q.format(local) } end end q.text("|") end |