class GraphQL::Language::Argument

Defined in:

graphql-crystal/language/nodes.cr

Constant Summary

GRAPHQL_FIELDS = [{:__typename, "", args, ""}] of Tuple(Symbol, String, Hash(String, String) | ::Nil, String)
VALUES = [{name, String}, {value, ArgumentValue}] of Tuple(Symbol, Object.class)
VISITS = [] of Tuple(Symbol, Array(Symbol))

Constructors

Class Method Summary

Instance Method Summary

Macro Summary

Instance methods inherited from class GraphQL::Language::AbstractNode

==(other : GraphQL::Language::AbstractNode) ==, clone clone, resolve_field(name : String, arguments, context : GraphQL::Schema::Context) resolve_field, values values, visit(name, visited_ids = [] of UInt64, block = Proc(ASTNode, ASTNode | ::Nil).new do end) visit

Constructor methods inherited from class GraphQL::Language::AbstractNode

new(**rest) new

Class methods inherited from class GraphQL::Language::AbstractNode

values values

Instance methods inherited from module GraphQL::ObjectType

graphql_type graphql_type, resolve_field(name, arguments, context) resolve_field

Instance methods inherited from class GraphQL::Language::ASTNode

==(other) ==, clone clone, values values

Class methods inherited from class GraphQL::Language::ASTNode

values values

Instance methods inherited from class Object

debug debug

Constructor Detail

def self.new(name, value, **rest) #

Class Method Detail

def self.values #

Instance Method Detail

def ==(other : GraphQL::Language::Argument) #

def clone #

Returns a copy of self with all instance variables cloned.


def name : String #

def name=(name : String) #

def resolve_field(name : String, arguments, context : GraphQL::Schema::Context) #

resolve a named field on this object with query arguments and context


def to_value #

[View source]
def value : ArgumentValue #

def value=(value : ArgumentValue) #

def values #

def visit(name, visited_ids = [] of UInt64, block = Proc(ASTNode, ASTNode | ::Nil).new do end) #

Recursively apply the given block to each node that gets visited with the given key which nodes get traverses for a given key can be set on a class via the: traverse :name, :child_1, :child2 macro. If no children are defined for a given traversal path name the block is invoked only with self.


Macro Detail

macro accessors(name, type, default) #

macro field(name, &block) #

macro field(name, description, args, typename, &block) #

macro inject #

macro injection #

macro traverse(name, *values) #

macro values(args) #