class Prism::ImplicitRestNode
Represents using a trailing comma to indicate an implicit rest parameter.
foo { |bar,| }
^
foo in [bar,]
^
for foo, in bar do end
^
foo, = bar
^
Public Class Methods
Source
# File lib/prism/node.rb, line 8953 def initialize(source, node_id, location, flags) @source = source @node_id = node_id @location = location @flags = flags end
Initialize a new ImplicitRestNode node.
Source
# File lib/prism/node.rb, line 9004 def self.type :implicit_rest_node end
Return a symbol representation of this node type. See Node::type.
Public Instance Methods
Source
# File lib/prism/node.rb, line 9010 def ===(other) other.is_a?(ImplicitRestNode) end
Implements case-equality for the node. This is effectively == but without comparing the value of locations. Locations are checked only for presence.
Source
# File lib/prism/node.rb, line 8961 def accept(visitor) visitor.visit_implicit_rest_node(self) end
def accept: (Visitor visitor) -> void
Source
# File lib/prism/node.rb, line 8966 def child_nodes [] end
def child_nodes: () -> Array
Also aliased as: deconstruct
Source
# File lib/prism/node.rb, line 8976 def comment_targets [] #: Array[Prism::node | Location] end
def comment_targets: () -> Array[Node | Location]
Source
# File lib/prism/node.rb, line 8971 def compact_child_nodes [] end
def compact_child_nodes: () -> Array
Source
# File lib/prism/node.rb, line 8981 def copy(node_id: self.node_id, location: self.location, flags: self.flags) ImplicitRestNode.new(source, node_id, location, flags) end
def copy: (?node_id: Integer, ?location: Location, ?flags: Integer) -> ImplicitRestNode
Source
# File lib/prism/node.rb, line 8989 def deconstruct_keys(keys) { node_id: node_id, location: location } end
def deconstruct_keys: (Array keys) -> { node_id: Integer, location: Location }
Source
# File lib/prism/node.rb, line 8994 def inspect InspectVisitor.compose(self) end
def inspect -> String