All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
graphql.language.FieldDefinition Maven / Gradle / Ivy
package graphql.language;
import com.google.common.collect.ImmutableList;
import graphql.Internal;
import graphql.PublicApi;
import graphql.collect.ImmutableKit;
import graphql.util.TraversalControl;
import graphql.util.TraverserContext;
import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.function.Consumer;
import static graphql.Assert.assertNotNull;
import static graphql.collect.ImmutableKit.emptyList;
import static graphql.collect.ImmutableKit.emptyMap;
import static graphql.language.NodeChildrenContainer.newNodeChildrenContainer;
@PublicApi
public class FieldDefinition extends AbstractDescribedNode implements DirectivesContainer, NamedNode {
private final String name;
private final Type type;
private final ImmutableList inputValueDefinitions;
private final ImmutableList directives;
public static final String CHILD_TYPE = "type";
public static final String CHILD_INPUT_VALUE_DEFINITION = "inputValueDefinition";
public static final String CHILD_DIRECTIVES = "directives";
@Internal
protected FieldDefinition(String name,
Type type,
List inputValueDefinitions,
List directives,
Description description,
SourceLocation sourceLocation,
List comments,
IgnoredChars ignoredChars,
Map additionalData) {
super(sourceLocation, comments, ignoredChars, additionalData, description);
this.name = name;
this.type = type;
this.inputValueDefinitions = ImmutableList.copyOf(inputValueDefinitions);
this.directives = ImmutableList.copyOf(directives);
}
public FieldDefinition(String name,
Type type) {
this(name, type, emptyList(), emptyList(), null, null, emptyList(), IgnoredChars.EMPTY, emptyMap());
}
public Type getType() {
return type;
}
@Override
public String getName() {
return name;
}
public List getInputValueDefinitions() {
return inputValueDefinitions;
}
@Override
public List getDirectives() {
return directives;
}
@Override
public List getChildren() {
List result = new ArrayList<>();
result.add(type);
result.addAll(inputValueDefinitions);
result.addAll(directives);
return result;
}
@Override
public NodeChildrenContainer getNamedChildren() {
return newNodeChildrenContainer()
.child(CHILD_TYPE, type)
.children(CHILD_INPUT_VALUE_DEFINITION, inputValueDefinitions)
.children(CHILD_DIRECTIVES, directives)
.build();
}
@Override
public FieldDefinition withNewChildren(NodeChildrenContainer newChildren) {
return transform(builder -> builder
.type(newChildren.getChildOrNull(CHILD_TYPE))
.inputValueDefinitions(newChildren.getChildren(CHILD_INPUT_VALUE_DEFINITION))
.directives(newChildren.getChildren(CHILD_DIRECTIVES))
);
}
@Override
public boolean isEqualTo(Node o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
FieldDefinition that = (FieldDefinition) o;
return Objects.equals(this.name, that.name);
}
@Override
public FieldDefinition deepCopy() {
return new FieldDefinition(name,
deepCopy(type),
deepCopy(inputValueDefinitions),
deepCopy(directives),
description,
getSourceLocation(),
getComments(),
getIgnoredChars(),
getAdditionalData());
}
@Override
public String toString() {
return "FieldDefinition{" +
"name='" + name + '\'' +
", type=" + type +
", inputValueDefinitions=" + inputValueDefinitions +
", directives=" + directives +
'}';
}
@Override
public TraversalControl accept(TraverserContext context, NodeVisitor visitor) {
return visitor.visitFieldDefinition(this, context);
}
public static Builder newFieldDefinition() {
return new Builder();
}
public FieldDefinition transform(Consumer builderConsumer) {
Builder builder = new Builder(this);
builderConsumer.accept(builder);
return builder.build();
}
public static final class Builder implements NodeDirectivesBuilder {
private SourceLocation sourceLocation;
private String name;
private ImmutableList comments = emptyList();
private Type type;
private Description description;
private ImmutableList inputValueDefinitions = emptyList();
private ImmutableList directives = emptyList();
private IgnoredChars ignoredChars = IgnoredChars.EMPTY;
private Map additionalData = new LinkedHashMap<>();
private Builder() {
}
private Builder(FieldDefinition existing) {
this.sourceLocation = existing.getSourceLocation();
this.name = existing.getName();
this.comments = ImmutableList.copyOf(existing.getComments());
this.type = existing.getType();
this.description = existing.getDescription();
this.inputValueDefinitions = ImmutableList.copyOf(existing.getInputValueDefinitions());
this.directives = ImmutableList.copyOf(existing.getDirectives());
this.ignoredChars = existing.getIgnoredChars();
this.additionalData = new LinkedHashMap<>(existing.getAdditionalData());
}
public Builder sourceLocation(SourceLocation sourceLocation) {
this.sourceLocation = sourceLocation;
return this;
}
public Builder name(String name) {
this.name = name;
return this;
}
public Builder comments(List comments) {
this.comments = ImmutableList.copyOf(comments);
return this;
}
public Builder type(Type type) {
this.type = type;
return this;
}
public Builder description(Description description) {
this.description = description;
return this;
}
public Builder inputValueDefinitions(List inputValueDefinitions) {
this.inputValueDefinitions = ImmutableList.copyOf(inputValueDefinitions);
return this;
}
public Builder inputValueDefinition(InputValueDefinition inputValueDefinition) {
this.inputValueDefinitions = ImmutableKit.addToList(inputValueDefinitions, inputValueDefinition);
return this;
}
@Override
public Builder directives(List directives) {
this.directives = ImmutableList.copyOf(directives);
return this;
}
public Builder directive(Directive directive) {
this.directives = ImmutableKit.addToList(directives, directive);
return this;
}
public Builder ignoredChars(IgnoredChars ignoredChars) {
this.ignoredChars = ignoredChars;
return this;
}
public Builder additionalData(Map additionalData) {
this.additionalData = assertNotNull(additionalData);
return this;
}
public Builder additionalData(String key, String value) {
this.additionalData.put(key, value);
return this;
}
public FieldDefinition build() {
return new FieldDefinition(name, type, inputValueDefinitions, directives, description, sourceLocation, comments, ignoredChars, additionalData);
}
}
}