Represents a set of statements contained within some scope.
foo; bar; baz ^^^^^^^^^^^^^
Attributes
Class Methods
4.0
View on GitHub
# File tmp/rubies/ruby-4.0.0/lib/prism/node.rb, line 17006
def initialize(source, node_id, location, flags, body)
@source = source
@node_id = node_id
@location = location
@flags = flags
@body = body
end
Initialize a new StatementsNode node.
.
4.0
View on GitHub
# File tmp/rubies/ruby-4.0.0/lib/prism/node.rb, line 17061
def self.type
:statements_node
end
Return a symbol representation of this node type. See Node::type.
Instance Methods
4.0
View on GitHub
# File tmp/rubies/ruby-4.0.0/lib/prism/node.rb, line 17067
def ===(other)
other.is_a?(StatementsNode) &&
(body.length == other.body.length) &&
body.zip(other.body).all? { |left, right| left === right }
end
Implements case-equality for the node. This is effectively == but without comparing the value of locations. Locations are checked only for presence.
4.0
View on GitHub
# File tmp/rubies/ruby-4.0.0/lib/prism/node.rb, line 17015
def accept(visitor)
visitor.visit_statements_node(self)
end
def accept: (Visitor visitor) -> void
4.0
View on GitHub
# File tmp/rubies/ruby-4.0.0/lib/prism/node.rb, line 17020
def child_nodes
[*body]
end
def child_nodes: () -> Array
4.0
View on GitHub
# File tmp/rubies/ruby-4.0.0/lib/prism/node.rb, line 17030
def comment_targets
[*body] #: Array[Prism::node | Location]
end
def comment_targets: () -> Array[Node | Location]
4.0
View on GitHub
# File tmp/rubies/ruby-4.0.0/lib/prism/node.rb, line 17025
def compact_child_nodes
[*body]
end
def compact_child_nodes: () -> Array
4.0
View on GitHub
# File tmp/rubies/ruby-4.0.0/lib/prism/node.rb, line 17035
def copy(node_id: self.node_id, location: self.location, flags: self.flags, body: self.body)
StatementsNode.new(source, node_id, location, flags, body)
end
def copy: (?node_id: Integer, ?location: Location, ?flags: Integer, ?body: Array) -> StatementsNode
4.0
View on GitHub
# File tmp/rubies/ruby-4.0.0/lib/prism/node.rb, line 17043
def deconstruct_keys(keys)
{ node_id: node_id, location: location, body: body }
end
def deconstruct_keys: (Array keys) -> { node_id: Integer, location: Location, body: Array }
#
4.0
View on GitHub
# File tmp/rubies/ruby-4.0.0/lib/prism/node.rb, line 17051
def inspect
InspectVisitor.compose(self)
end
def inspect -> String
#
4.0
View on GitHub
# File tmp/rubies/ruby-4.0.0/lib/prism/node.rb, line 17056
def type
:statements_node
end
Return a symbol representation of this node type. See Node#type.