class SyntaxTree::FndPtn
end
in [*, 7, *]
case value
array using the Ruby 3.0+ pattern matching syntax.
FndPtn represents matching against a pattern where you find a pattern in an
def ===(other)
def ===(other) other.is_a?(FndPtn) && constant === other.constant && left === other.left && ArrayMatch.call(values, other.values) && right === other.right end
def accept(visitor)
def accept(visitor) visitor.visit_fndptn(self) end
def child_nodes
def child_nodes [constant, left, *values, right] end
def copy(constant: nil, left: nil, values: nil, right: nil, location: nil)
def copy(constant: nil, left: nil, values: nil, right: nil, location: nil) node = FndPtn.new( constant: constant || self.constant, left: left || self.left, values: values || self.values, right: right || self.right, location: location || self.location ) node.comments.concat(comments.map(&:copy)) node end
def deconstruct_keys(_keys)
def deconstruct_keys(_keys) { constant: constant, left: left, values: values, right: right, location: location, comments: comments } end
def format(q)
def format(q) q.format(constant) if constant q.group do q.text("[") q.indent do q.breakable_empty q.text("*") q.format(left) q.comma_breakable q.seplist(values) { |value| q.format(value) } q.comma_breakable q.text("*") q.format(right) end q.breakable_empty q.text("]") end end
def initialize(constant:, left:, values:, right:, location:)
def initialize(constant:, left:, values:, right:, location:) @constant = constant @left = left @values = values @right = right @location = location @comments = [] end