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/Args.html below:

class SyntaxTree::Args - RDoc Documentation

  1. SyntaxTree::
  2. Args
class SyntaxTree::Args

Args represents a list of arguments being passed to a method call or array literal.

method(first, second, third)
Attributes
Array[ Node ]

the arguments that this node wraps

Public Class Methods

Source

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

Source

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

Source

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

Source

def arity
  parts.sum do |part|
    case part
    when ArgStar, ArgsForward
      Float::INFINITY
    when BareAssocHash
      part.assocs.sum do |assoc|
        assoc.is_a?(AssocSplat) ? Float::INFINITY : 1
      end
    else
      1
    end
  end
end

Source

def child_nodes
  parts
end

Source

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

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

Source

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

Source

def format(q)
  q.seplist(parts) { |part| q.format(part) }
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