class Crystal::Macros::TupleLiteral

Overview

A tuple literal.

Its macro methods are nearly the same asArrayLiteral.

Defined in:

compiler/crystal/macros.cr

Instance Method Summary

Instance methods inherited from class Crystal::Macros::ASTNode

!=(other : ASTNode) : BoolLiteral !=, ==(other : ASTNode) : BoolLiteral ==, class_name : StringLiteral class_name, column_number : StringLiteral | NilLiteral column_number, doc : StringLiteral doc, doc_comment : MacroId doc_comment, end_column_number : StringLiteral | NilLiteral end_column_number, end_line_number : StringLiteral | NilLiteral end_line_number, filename : StringLiteral | NilLiteral filename, id : MacroId id, is_a?(type : TypeNode) : BoolLiteral is_a?, line_number : StringLiteral | NilLiteral line_number, nil? : BoolLiteral nil?, raise(message) : NoReturn raise, stringify : StringLiteral stringify, symbolize : SymbolLiteral symbolize, warning(message : StringLiteral) : NilLiteral warning

Instance Method Detail

def *(other : NumberLiteral) : TupleLiteral #

Similar toTuple#*


def +(other : TupleLiteral) : TupleLiteral #

Similar toTuple#+.


def -(other : TupleLiteral) : TupleLiteral #

Similar toArray#-.


def <<(value : ASTNode) : TupleLiteral #

Similar toArray#<<.


def [](start : NumberLiteral, count : NumberLiteral) : TupleLiteral | NilLiteral #

Similar toArray#[]?(Int, Int), but returns anotherTupleLiteral instead of anArrayLiteral.


def [](index : NumberLiteral) : ASTNode #

Similar toTuple#[]?(Int).


def [](index : RangeLiteral) : TupleLiteral | NilLiteral #

Similar toTuple#[]?(Range).


def []=(index : NumberLiteral, value : ASTNode) : ASTNode #

Similar toArray#[]=.


def all?(&) : BoolLiteral #

Similar toEnumerable#all?


def any?(&) : BoolLiteral #

Similar toEnumerable#any?


def each(&) : NilLiteral #

Similar toTuple#each


def each_with_index(&) : NilLiteral #

def empty? : BoolLiteral #

Similar toTuple#empty?


def find(&) : ASTNode | NilLiteral #

Similar toEnumerable#find


def first : ASTNode | NilLiteral #

Similar toTuple#first, but returns aNilLiteral if the tuple is empty.


def includes?(node : ASTNode) : BoolLiteral #

def join(separator) : StringLiteral #

Similar toEnumerable#join


def last : ASTNode | NilLiteral #

Similar toTuple#last, but returns aNilLiteral if the tuple is empty.


def map(&) : TupleLiteral #

Similar toEnumerable#map


def map_with_index(&) : TupleLiteral #

def push(value : ASTNode) : TupleLiteral #

Similar toArray#push.


def reduce(memo : ASTNode, &) : ASTNode #

Similar toEnumerable#reduce


def reduce(&) : ASTNode #

Similar toEnumerable#reduce


def reject(&) : TupleLiteral #

Similar toEnumerable#reject


def select(&) : TupleLiteral #

Similar toEnumerable#select


def shuffle : TupleLiteral #

Similar toArray#shuffle


def size : NumberLiteral #

Similar toTuple#size


def sort : TupleLiteral #

Similar toArray#sort


def sort_by(&) : TupleLiteral #

Similar toArray#sort_by


def splat(trailing_string : StringLiteral = nil) : MacroId #

Returns aMacroId with all of this tuple's elements joined by commas.

Iftrailing_string is given, it will be appended to the result unless this tuple is empty. This lets you splat a tuple and optionally write a trailing comma if needed.


def uniq : TupleLiteral #

Similar toArray#uniq


def unshift(value : ASTNode) : TupleLiteral #

Similar toArray#unshift.