X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=yang%2Fyang-parser-impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fyangtools%2Fyang%2Fparser%2Fbuilder%2Fimpl%2FChoiceBuilder.java;h=5ec23d1000054b34aa52a873c4ce892f8f17c957;hb=aa0d59e9afecc484e8d0e219d3156e7817266e28;hp=f4aabb19445df58cf9cf8fd4ee1832244c9fab06;hpb=e0cbcd46bb6bdd6dc36da7e160df9dcd9f45f42a;p=yangtools.git diff --git a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/ChoiceBuilder.java b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/ChoiceBuilder.java index f4aabb1944..5ec23d1000 100644 --- a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/ChoiceBuilder.java +++ b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/ChoiceBuilder.java @@ -7,22 +7,21 @@ */ package org.opendaylight.yangtools.yang.parser.builder.impl; +import com.google.common.base.Preconditions; +import com.google.common.collect.ImmutableList; +import com.google.common.collect.ImmutableSet; import java.util.ArrayList; import java.util.HashSet; import java.util.List; +import java.util.Objects; import java.util.Set; import java.util.TreeSet; - import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.model.api.AugmentationSchema; import org.opendaylight.yangtools.yang.model.api.ChoiceCaseNode; -import org.opendaylight.yangtools.yang.model.api.ChoiceNode; -import org.opendaylight.yangtools.yang.model.api.ConstraintDefinition; +import org.opendaylight.yangtools.yang.model.api.ChoiceSchemaNode; import org.opendaylight.yangtools.yang.model.api.DataSchemaNode; -import org.opendaylight.yangtools.yang.model.api.DerivableSchemaNode; import org.opendaylight.yangtools.yang.model.api.SchemaPath; -import org.opendaylight.yangtools.yang.model.api.Status; -import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode; import org.opendaylight.yangtools.yang.parser.builder.api.AugmentationSchemaBuilder; import org.opendaylight.yangtools.yang.parser.builder.api.AugmentationTargetBuilder; import org.opendaylight.yangtools.yang.parser.builder.api.ConstraintsBuilder; @@ -33,20 +32,15 @@ import org.opendaylight.yangtools.yang.parser.builder.util.AbstractSchemaNodeBui import org.opendaylight.yangtools.yang.parser.builder.util.Comparators; import org.opendaylight.yangtools.yang.parser.util.YangParseException; -import com.google.common.base.Optional; -import com.google.common.base.Preconditions; -import com.google.common.collect.ImmutableList; -import com.google.common.collect.ImmutableSet; - public final class ChoiceBuilder extends AbstractSchemaNodeBuilder implements DataSchemaNodeBuilder, AugmentationTargetBuilder { - private ChoiceNodeImpl instance; + private ChoiceSchemaNodeImpl instance; // DataSchemaNode args private boolean augmenting; private boolean addedByUses; private boolean configuration; - private ChoiceNode originalNode; + private ChoiceSchemaNode originalNode; private ChoiceBuilder originalBuilder; private final ConstraintsBuilder constraints; // AugmentationTarget args @@ -63,7 +57,7 @@ AugmentationTargetBuilder { } public ChoiceBuilder(final String moduleName, final int line, final QName qname, final SchemaPath path, - final ChoiceNode base) { + final ChoiceSchemaNode base) { super(moduleName, line, qname); this.schemaPath = path; constraints = new ConstraintsBuilderImpl(moduleName, line, base.getConstraints()); @@ -90,12 +84,12 @@ AugmentationTargetBuilder { } @Override - public ChoiceNode build() { + public ChoiceSchemaNode build() { if (instance != null) { return instance; } - instance = new ChoiceNodeImpl(qname, schemaPath); + instance = new ChoiceSchemaNodeImpl(qname, schemaPath); instance.description = description; instance.reference = reference; @@ -104,7 +98,7 @@ AugmentationTargetBuilder { instance.addedByUses = addedByUses; instance.configuration = configuration; - instance.constraints = constraints.toInstance(); + instance.constraints = constraints.build(); instance.defaultCase = defaultCase; // ORIGINAL NODE @@ -261,7 +255,7 @@ AugmentationTargetBuilder { public int hashCode() { final int prime = 31; int result = 1; - result = prime * result + ((schemaPath == null) ? 0 : schemaPath.hashCode()); + result = prime * result + Objects.hashCode(schemaPath); return result; } @@ -299,171 +293,4 @@ AugmentationTargetBuilder { return "choice " + qname.getLocalName(); } - private static final class ChoiceNodeImpl implements ChoiceNode, DerivableSchemaNode { - private final QName qname; - private final SchemaPath path; - private String description; - private String reference; - private Status status; - private boolean augmenting; - private boolean addedByUses; - private ChoiceNode original; - private boolean configuration; - private ConstraintDefinition constraints; - private ImmutableSet cases; - private ImmutableSet augmentations; - private ImmutableList unknownNodes; - private String defaultCase; - - private ChoiceNodeImpl(final QName qname, final SchemaPath path) { - this.qname = qname; - this.path = path; - } - - @Override - public QName getQName() { - return qname; - } - - @Override - public SchemaPath getPath() { - return path; - } - - @Override - public String getDescription() { - return description; - } - - @Override - public String getReference() { - return reference; - } - - @Override - public Status getStatus() { - return status; - } - - @Override - public boolean isAugmenting() { - return augmenting; - } - - @Override - public boolean isAddedByUses() { - return addedByUses; - } - - @Override - public Optional getOriginal() { - return Optional.fromNullable(original); - } - - @Override - public boolean isConfiguration() { - return configuration; - } - - @Override - public ConstraintDefinition getConstraints() { - return constraints; - } - - @Override - public Set getAvailableAugmentations() { - return augmentations; - } - - @Override - public List getUnknownSchemaNodes() { - return unknownNodes; - } - - @Override - public Set getCases() { - return cases; - } - - @Override - public ChoiceCaseNode getCaseNodeByName(final QName name) { - if (name == null) { - throw new IllegalArgumentException("Choice Case QName cannot be NULL!"); - } - for (final ChoiceCaseNode caseNode : cases) { - if (caseNode != null && name.equals(caseNode.getQName())) { - return caseNode; - } - } - return null; - } - - @Override - public ChoiceCaseNode getCaseNodeByName(final String name) { - if (name == null) { - throw new IllegalArgumentException("Choice Case string Name cannot be NULL!"); - } - for (final ChoiceCaseNode caseNode : cases) { - if (caseNode != null && (caseNode.getQName() != null) - && name.equals(caseNode.getQName().getLocalName())) { - return caseNode; - } - } - return null; - } - - @Override - public String getDefaultCase() { - return defaultCase; - } - - @Override - public int hashCode() { - final int prime = 31; - int result = 1; - result = prime * result + ((qname == null) ? 0 : qname.hashCode()); - result = prime * result + ((path == null) ? 0 : path.hashCode()); - return result; - } - - @Override - public boolean equals(final Object obj) { - if (this == obj) { - return true; - } - if (obj == null) { - return false; - } - if (getClass() != obj.getClass()) { - return false; - } - ChoiceNodeImpl other = (ChoiceNodeImpl) obj; - if (qname == null) { - if (other.qname != null) { - return false; - } - } else if (!qname.equals(other.qname)) { - return false; - } - if (path == null) { - if (other.path != null) { - return false; - } - } else if (!path.equals(other.path)) { - return false; - } - return true; - } - - @Override - public String toString() { - StringBuilder sb = new StringBuilder(ChoiceNodeImpl.class.getSimpleName()); - sb.append("["); - sb.append("qname=").append(qname); - sb.append("]"); - return sb.toString(); - } - - } - }