Class: SyntaxTree::Rescue
Overview
Rescue represents the use of the rescue keyword inside of a BodyStmt node.
begin
rescue
end
Instance Attribute Summary collapse
-
#comments ⇒ Object
readonly
- Array[ Comment | EmbDoc ]
-
the comments attached to this node.
-
#consequent ⇒ Object
readonly
- nil | Rescue
-
the optional next clause in the chain.
-
#exception ⇒ Object
readonly
- nil | RescueEx
-
the exceptions being rescued.
-
#keyword ⇒ Object
readonly
- Kw
-
the rescue keyword.
-
#statements ⇒ Object
readonly
- Statements
-
the expressions to evaluate when an error is rescued.
Attributes inherited from Node
Instance Method Summary collapse
- #===(other) ⇒ Object
- #accept(visitor) ⇒ Object
- #bind_end(end_char, end_column) ⇒ Object
- #child_nodes ⇒ Object (also: #deconstruct)
- #copy(keyword: nil, exception: nil, statements: nil, consequent: nil, location: nil) ⇒ Object
- #deconstruct_keys(_keys) ⇒ Object
- #format(q) ⇒ Object
-
#initialize(keyword:, exception:, statements:, consequent:, location:) ⇒ Rescue
constructor
A new instance of Rescue.
Methods inherited from Node
#construct_keys, #end_char, #pretty_print, #start_char, #to_json, #to_mermaid
Constructor Details
#initialize(keyword:, exception:, statements:, consequent:, location:) ⇒ Rescue
Returns a new instance of Rescue.
9424 9425 9426 9427 9428 9429 9430 9431 |
# File 'lib/syntax_tree/node.rb', line 9424 def initialize(keyword:, exception:, statements:, consequent:, location:) @keyword = keyword @exception = exception @statements = statements @consequent = consequent @location = location @comments = [] end |
Instance Attribute Details
#comments ⇒ Object (readonly)
- Array[ Comment | EmbDoc ]
-
the comments attached to this node
9422 9423 9424 |
# File 'lib/syntax_tree/node.rb', line 9422 def comments @comments end |
#consequent ⇒ Object (readonly)
- nil | Rescue
-
the optional next clause in the chain
9419 9420 9421 |
# File 'lib/syntax_tree/node.rb', line 9419 def consequent @consequent end |
#exception ⇒ Object (readonly)
- nil | RescueEx
-
the exceptions being rescued
9413 9414 9415 |
# File 'lib/syntax_tree/node.rb', line 9413 def exception @exception end |
#keyword ⇒ Object (readonly)
- Kw
-
the rescue keyword
9410 9411 9412 |
# File 'lib/syntax_tree/node.rb', line 9410 def keyword @keyword end |
#statements ⇒ Object (readonly)
- Statements
-
the expressions to evaluate when an error is rescued
9416 9417 9418 |
# File 'lib/syntax_tree/node.rb', line 9416 def statements @statements end |
Instance Method Details
#===(other) ⇒ Object
9520 9521 9522 9523 9524 |
# File 'lib/syntax_tree/node.rb', line 9520 def ===(other) other.is_a?(Rescue) && keyword === other.keyword && exception === other.exception && statements === other.statements && consequent === other.consequent end |
#accept(visitor) ⇒ Object
9455 9456 9457 |
# File 'lib/syntax_tree/node.rb', line 9455 def accept(visitor) visitor.visit_rescue(self) end |
#bind_end(end_char, end_column) ⇒ Object
9433 9434 9435 9436 9437 9438 9439 9440 9441 9442 9443 9444 9445 9446 9447 9448 9449 9450 9451 9452 9453 |
# File 'lib/syntax_tree/node.rb', line 9433 def bind_end(end_char, end_column) @location = Location.new( start_line: location.start_line, start_char: location.start_char, start_column: location.start_column, end_line: location.end_line, end_char: end_char, end_column: end_column ) if (next_node = consequent) next_node.bind_end(end_char, end_column) statements.bind_end( next_node.location.start_char, next_node.location.start_column ) else statements.bind_end(end_char, end_column) end end |
#child_nodes ⇒ Object Also known as: deconstruct
9459 9460 9461 |
# File 'lib/syntax_tree/node.rb', line 9459 def child_nodes [keyword, exception, statements, consequent] end |
#copy(keyword: nil, exception: nil, statements: nil, consequent: nil, location: nil) ⇒ Object
9463 9464 9465 9466 9467 9468 9469 9470 9471 9472 9473 9474 9475 9476 9477 9478 9479 9480 9481 |
# File 'lib/syntax_tree/node.rb', line 9463 def copy( keyword: nil, exception: nil, statements: nil, consequent: nil, location: nil ) node = Rescue.new( keyword: keyword || self.keyword, exception: exception || self.exception, statements: statements || self.statements, consequent: consequent || self.consequent, location: location || self.location ) node.comments.concat(comments.map(&:copy)) node end |
#deconstruct_keys(_keys) ⇒ Object
9485 9486 9487 9488 9489 9490 9491 9492 9493 9494 |
# File 'lib/syntax_tree/node.rb', line 9485 def deconstruct_keys(_keys) { keyword: keyword, exception: exception, statements: statements, consequent: consequent, location: location, comments: comments } end |
#format(q) ⇒ Object
9496 9497 9498 9499 9500 9501 9502 9503 9504 9505 9506 9507 9508 9509 9510 9511 9512 9513 9514 9515 9516 9517 9518 |
# File 'lib/syntax_tree/node.rb', line 9496 def format(q) q.group do q.format(keyword) if exception q.nest(keyword.value.length + 1) { q.format(exception) } else q.text(" StandardError") end unless statements.empty? q.indent do q.breakable_force q.format(statements) end end if consequent q.breakable_force q.format(consequent) end end end |