class SyntaxTree::RAssign
value => pattern
value in pattern
RAssign represents a single-line pattern match.
def ===(other)
def ===(other) other.is_a?(RAssign) && value === other.value && operator === other.operator && pattern === other.pattern end
def accept(visitor)
def accept(visitor) visitor.visit_rassign(self) end
def child_nodes
def child_nodes [value, operator, pattern] end
def copy(value: nil, operator: nil, pattern: nil, location: nil)
def copy(value: nil, operator: nil, pattern: nil, location: nil) node = RAssign.new( value: value || self.value, operator: operator || self.operator, pattern: pattern || self.pattern, location: location || self.location ) node.comments.concat(comments.map(&:copy)) node end
def deconstruct_keys(_keys)
def deconstruct_keys(_keys) { value: value, operator: operator, pattern: pattern, location: location, comments: comments } end
def format(q)
def format(q) q.group do q.format(value) q.text(" ") q.format(operator) case pattern when AryPtn, FndPtn, HshPtn q.text(" ") q.format(pattern) else q.group do q.indent do q.breakable_space q.format(pattern) end end end end end
def initialize(value:, operator:, pattern:, location:)
def initialize(value:, operator:, pattern:, location:) @value = value @operator = operator @pattern = pattern @location = location @comments = [] end