A RetroSearch Logo

Home - News ( United States | United Kingdom | Italy | Germany ) - Football scores

Search Query:

Showing content from https://ruby-syntax-tree.github.io/syntax_tree/SyntaxTree/MLHS.html below:

class SyntaxTree::MLHS - RDoc Documentation

  1. SyntaxTree::
  2. MLHS
class SyntaxTree::MLHS

MLHS represents a list of values being destructured on the left-hand side of a multiple assignment.

first, second, third = value
Attributes
boolean

whether or not there is a trailing comma at the end of this

list, which impacts destructuring. It’s an attr_accessor so that while the syntax tree is being built it can be set by its parent node

[

Array[
  ARefField | ArgStar | ConstPathField | Field | Ident | MLHSParen |
    TopConstField | VarField
]

] the parts of the left-hand side of a multiple assignment

Public Class Methods

Source

def initialize(parts:, location:, comma: false)
  @parts = parts
  @comma = comma
  @location = location
  @comments = []
end
Public Instance Methods

Source

def ===(other)
  other.is_a?(MLHS) && ArrayMatch.call(parts, other.parts) &&
    comma === other.comma
end

Source

def accept(visitor)
  visitor.visit_mlhs(self)
end

Source

def child_nodes
  parts
end

Source

def copy(parts: nil, location: nil, comma: nil)
  node =
    MLHS.new(
      parts: parts || self.parts,
      location: location || self.location,
      comma: comma || self.comma
    )

  node.comments.concat(comments.map(&:copy))
  node
end

Source

def deconstruct_keys(_keys)
  { parts: parts, location: location, comma: comma, comments: comments }
end

Source

def format(q)
  q.seplist(parts) { |part| q.format(part) }
  q.text(",") if comma
end

RetroSearch is an open source project built by @garambo | Open a GitHub Issue

Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo

HTML: 3.2 | Encoding: UTF-8 | Version: 0.7.4