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%2FAnyXmlBuilder.java;h=2a9e4cde7aa2bb3717015236b7e22613d9037d05;hb=cd03b372e88961a8783473ae585039d53a45a6c8;hp=eed982e88bde3dee5e273bd4bb24d143c09732a4;hpb=c1e1c4777e6fbf3ccde612469f100e677ff36184;p=yangtools.git diff --git a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/AnyXmlBuilder.java b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/AnyXmlBuilder.java index eed982e88b..2a9e4cde7a 100644 --- a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/AnyXmlBuilder.java +++ b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/AnyXmlBuilder.java @@ -7,67 +7,79 @@ */ package org.opendaylight.yangtools.yang.parser.builder.impl; -import java.util.ArrayList; -import java.util.Collections; -import java.util.List; - +import com.google.common.base.Preconditions; +import com.google.common.collect.ImmutableList; +import java.util.Objects; import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.model.api.AnyXmlSchemaNode; -import org.opendaylight.yangtools.yang.model.api.ConstraintDefinition; 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.AbstractSchemaNodeBuilder; +import org.opendaylight.yangtools.yang.parser.builder.api.ConstraintsBuilder; import org.opendaylight.yangtools.yang.parser.builder.api.DataSchemaNodeBuilder; -import org.opendaylight.yangtools.yang.parser.builder.api.GroupingMember; -import org.opendaylight.yangtools.yang.parser.util.Comparators; +import org.opendaylight.yangtools.yang.parser.builder.api.SchemaNodeBuilder; +import org.opendaylight.yangtools.yang.parser.builder.api.UnknownSchemaNodeBuilder; +import org.opendaylight.yangtools.yang.parser.builder.util.AbstractSchemaNodeBuilder; -public final class AnyXmlBuilder extends AbstractSchemaNodeBuilder implements DataSchemaNodeBuilder, GroupingMember { - private boolean built; - private final AnyXmlSchemaNodeImpl instance; - private final ConstraintsBuilder constraints; +public final class AnyXmlBuilder extends AbstractSchemaNodeBuilder implements DataSchemaNodeBuilder { + private AnyXmlSchemaNodeImpl instance; - private Boolean configuration; private boolean augmenting; private boolean addedByUses; + private boolean configuration; + private AnyXmlSchemaNode originalNode; + private AnyXmlBuilder originalBuilder; + private final ConstraintsBuilder constraints; + + public AnyXmlBuilder(final String moduleName, final int line, final QName qname, final SchemaPath path) { + super(moduleName, line, qname); + this.schemaPath = path; + constraints = new ConstraintsBuilderImpl(moduleName, line); + } - public AnyXmlBuilder(final String moduleName, final int line, final QName qname, final SchemaPath schemaPath) { + public AnyXmlBuilder(final String moduleName, final int line, final QName qname, final SchemaPath path, + final AnyXmlSchemaNode base) { super(moduleName, line, qname); - this.schemaPath = schemaPath; - instance = new AnyXmlSchemaNodeImpl(qname); - constraints = new ConstraintsBuilder(moduleName, line); + this.schemaPath = path; + constraints = new ConstraintsBuilderImpl(moduleName, line, base.getConstraints()); + + description = base.getDescription(); + reference = base.getReference(); + status = base.getStatus(); + augmenting = base.isAugmenting(); + addedByUses = base.isAddedByUses(); + originalNode = base; + configuration = base.isConfiguration(); + unknownNodes.addAll(base.getUnknownSchemaNodes()); } @Override public AnyXmlSchemaNode build() { - if (!built) { - instance.setPath(schemaPath); - instance.setConstraints(constraints.build()); - instance.setDescription(description); - instance.setReference(reference); - instance.setStatus(status); - instance.setConfiguration(configuration); - instance.setAugmenting(augmenting); - instance.setAddedByUses(addedByUses); + if (instance != null) { + return instance; + } - // UNKNOWN NODES - if (unknownNodes == null) { - unknownNodes = new ArrayList(); - for (UnknownSchemaNodeBuilder b : addedUnknownNodes) { - unknownNodes.add(b.build()); - } - } - Collections.sort(unknownNodes, Comparators.SCHEMA_NODE_COMP); - instance.setUnknownSchemaNodes(unknownNodes); + instance = new AnyXmlSchemaNodeImpl(qname, schemaPath); + + instance.description = description; + instance.reference = reference; + instance.status = status; + instance.augmenting = augmenting; + instance.addedByUses = addedByUses; + instance.configuration = configuration; + instance.constraintsDef = constraints.build(); - built = true; + // ORIGINAL NODE + if (originalNode == null && originalBuilder != null) { + originalNode = originalBuilder.build(); } - return instance; - } + instance.original = originalNode; - @Override - public void setQName(QName qname) { - this.qname = qname; + // UNKNOWN NODES + for (UnknownSchemaNodeBuilder b : addedUnknownNodes) { + unknownNodes.add(b.build()); + } + instance.unknownNodes = ImmutableList.copyOf(unknownNodes); + + return instance; } @Override @@ -75,10 +87,6 @@ public final class AnyXmlBuilder extends AbstractSchemaNodeBuilder implements Da return constraints; } - public List getUnknownNodes() { - return addedUnknownNodes; - } - @Override public boolean isAugmenting() { return augmenting; @@ -100,12 +108,23 @@ public final class AnyXmlBuilder extends AbstractSchemaNodeBuilder implements Da } @Override - public Boolean isConfiguration() { + public AnyXmlBuilder getOriginal() { + return originalBuilder; + } + + @Override + public void setOriginal(final SchemaNodeBuilder builder) { + Preconditions.checkArgument(builder instanceof AnyXmlBuilder, "Original of anyxml cannot be " + builder); + this.originalBuilder = (AnyXmlBuilder) builder; + } + + @Override + public boolean isConfiguration() { return configuration; } @Override - public void setConfiguration(final Boolean configuration) { + public void setConfiguration(final boolean configuration) { this.configuration = configuration; } @@ -113,12 +132,12 @@ public final class AnyXmlBuilder extends AbstractSchemaNodeBuilder implements Da 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; } @Override - public boolean equals(Object obj) { + public boolean equals(final Object obj) { if (this == obj) { return true; } @@ -136,11 +155,11 @@ public final class AnyXmlBuilder extends AbstractSchemaNodeBuilder implements Da } else if (!schemaPath.equals(other.schemaPath)) { return false; } - if (parent == null) { - if (other.parent != null) { + if (getParent() == null) { + if (other.getParent() != null) { return false; } - } else if (!parent.equals(other.parent)) { + } else if (!getParent().equals(other.getParent())) { return false; } return true; @@ -151,159 +170,4 @@ public final class AnyXmlBuilder extends AbstractSchemaNodeBuilder implements Da return "anyxml " + qname.getLocalName(); } - private final class AnyXmlSchemaNodeImpl implements AnyXmlSchemaNode { - private final QName qname; - private SchemaPath path; - private String description; - private String reference; - private Status status = Status.CURRENT; - private boolean configuration; - private ConstraintDefinition constraintsDef; - private boolean augmenting; - private boolean addedByUses; - private List unknownNodes = Collections.emptyList(); - - private AnyXmlSchemaNodeImpl(final QName qname) { - this.qname = qname; - } - - @Override - public QName getQName() { - return qname; - } - - @Override - public SchemaPath getPath() { - return path; - } - - private void setPath(final SchemaPath path) { - this.path = path; - } - - @Override - public String getDescription() { - return description; - } - - private void setDescription(String description) { - this.description = description; - } - - @Override - public String getReference() { - return reference; - } - - private void setReference(String reference) { - this.reference = reference; - } - - @Override - public Status getStatus() { - return status; - } - - private void setStatus(Status status) { - if (status != null) { - this.status = status; - } - } - - @Override - public boolean isAugmenting() { - return augmenting; - } - - private void setAugmenting(boolean augmenting) { - this.augmenting = augmenting; - } - - @Override - public boolean isAddedByUses() { - return addedByUses; - } - - private void setAddedByUses(boolean addedByUses) { - this.addedByUses = addedByUses; - } - - @Override - public boolean isConfiguration() { - return configuration; - } - - private void setConfiguration(boolean configuration) { - this.configuration = configuration; - } - - @Override - public ConstraintDefinition getConstraints() { - return constraintsDef; - } - - private void setConstraints(ConstraintDefinition constraintsDef) { - this.constraintsDef = constraintsDef; - } - - @Override - public List getUnknownSchemaNodes() { - return unknownNodes; - } - - private void setUnknownSchemaNodes(List unknownNodes) { - if (unknownNodes != null) { - this.unknownNodes = unknownNodes; - } - } - - @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(Object obj) { - if (this == obj) { - return true; - } - if (obj == null) { - return false; - } - if (getClass() != obj.getClass()) { - return false; - } - AnyXmlSchemaNodeImpl other = (AnyXmlSchemaNodeImpl) 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(AnyXmlSchemaNodeImpl.class.getSimpleName()); - sb.append("["); - sb.append("qname=" + qname); - sb.append(", path=" + path); - sb.append("]"); - return sb.toString(); - } - } - }