All Downloads are FREE. Search and download functionalities are using the official Maven repository.

graphql.language.Node Maven / Gradle / Ivy

package graphql.language;


import graphql.PublicApi;
import graphql.util.TraversalControl;
import graphql.util.TraverserContext;

import java.io.Serializable;
import java.util.List;
import java.util.Map;

/**
 * The base interface for virtually all graphql language elements
 *
 * NOTE: This class implements {@link java.io.Serializable} and hence it can be serialised and placed into a distributed cache.  However we
 * are not aiming to provide long term compatibility and do not intend for you to place this serialised data into permanent storage,
 * with times frames that cross graphql-java versions.  While we don't change things unnecessarily,  we may inadvertently break
 * the serialised compatibility across versions.
 *
 * Every Node is immutable
 */
@PublicApi
public interface Node extends Serializable {

    /**
     * @return a list of the children of this node
     */
    List getChildren();

    /**
     * Alternative to {@link #getChildren()} where the children are not all in one list regardless of type
     * but grouped by name/type of the child.
     *
     * @return a container of the child nodes
     */
    NodeChildrenContainer getNamedChildren();

    /**
     * Replaces the specified children and returns a new Node.
     *
     * @param newChildren must be empty for Nodes without children
     *
     * @return a new node
     */
    T withNewChildren(NodeChildrenContainer newChildren);

    /**
     * @return the source location where this node occurs
     */
    SourceLocation getSourceLocation();

    /**
     * Nodes can have comments made on them, the following is one comment per line before a node.
     *
     * @return the list of comments or an empty list of there are none
     */
    List getComments();

    /**
     * The chars which are ignored by the parser. (Before and after the current node)
     *
     * @return the ignored chars
     */
    IgnoredChars getIgnoredChars();

    /**
     * A node can have a map of additional data associated with it.
     *
     * 

* NOTE: The reason this is a map of strings is so the Node * can stay an immutable object, which Map String,Object would not allow * say. * * @return the map of additional data about this node */ Map getAdditionalData(); /** * Compares just the content and not the children. * * @param node the other node to compare to * * @return isEqualTo */ boolean isEqualTo(Node node); /** * @return a deep copy of this node */ T deepCopy(); /** * Double-dispatch entry point. * A node receives a Visitor instance and then calls a method on a Visitor * that corresponds to a actual type of this Node. This binding however happens * at the compile time and therefore it allows to save on rather expensive * reflection based {@code instanceOf} check when decision based on the actual * type of Node is needed, which happens redundantly during traversing AST. * * Additional advantage of this pattern is to decouple tree traversal mechanism * from the code that needs to be executed when traversal "visits" a particular Node * in the tree. This leads to a better code re-usability and maintainability. * * @param context TraverserContext bound to this Node object * @param visitor Visitor instance that performs actual processing on the Nodes(s) * * @return Result of Visitor's operation. * Note! Visitor's operation might return special results to control traversal process. */ TraversalControl accept(TraverserContext context, NodeVisitor visitor); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy