Sha256: 490966fbe26043e2a843e528184090cf435ca54ce166d3832a28a534cc9e37c2
Contents?: true
Size: 1.12 KB
Versions: 68
Compression:
Stored size: 1.12 KB
Contents
# frozen_string_literal: true module GraphQL module InternalRepresentation # Traverse a re-written query tree, calling handlers for each node module Visit module_function def visit_each_node(operations, handlers) return if handlers.empty? # Post-validation: make some assertions about the rewritten query tree operations.each do |op_name, op_node| # Yield each node to listeners which were attached by validators op_node.typed_children.each do |obj_type, children| children.each do |name, op_child_node| each_node(op_child_node) do |node| for h in handlers h.call(node) end end end end end end # Traverse a node in a rewritten query tree, # visiting the node itself and each of its typed children. def each_node(node, &block) yield(node) node.typed_children.each do |obj_type, children| children.each do |name, node| each_node(node, &block) end end end end end end
Version data entries
68 entries across 68 versions & 2 rubygems