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%2FLeafSchemaNodeBuilder.java;h=1d6fe186755e39ce953b572a86488dbedef4d9a3;hb=42abb28b99a02f9580f4676ce5c315628e5bcd24;hp=201705392b1be3edf919c12e596a0af296f10669;hpb=c6b4017ff4babad7e237c56ebe299efc90a6f990;p=yangtools.git diff --git a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/LeafSchemaNodeBuilder.java b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/LeafSchemaNodeBuilder.java index 201705392b..1d6fe18675 100644 --- a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/LeafSchemaNodeBuilder.java +++ b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/LeafSchemaNodeBuilder.java @@ -9,20 +9,22 @@ package org.opendaylight.yangtools.yang.parser.builder.impl; import com.google.common.base.Preconditions; import com.google.common.collect.ImmutableList; -import java.util.List; +import java.util.Objects; import org.opendaylight.yangtools.yang.common.QName; -import org.opendaylight.yangtools.yang.model.api.ConstraintDefinition; import org.opendaylight.yangtools.yang.model.api.LeafSchemaNode; import org.opendaylight.yangtools.yang.model.api.SchemaPath; import org.opendaylight.yangtools.yang.model.api.Status; -import org.opendaylight.yangtools.yang.model.api.TypeDefinition; -import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode; 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.SchemaNodeBuilder; import org.opendaylight.yangtools.yang.parser.builder.api.UnknownSchemaNodeBuilder; import org.opendaylight.yangtools.yang.parser.builder.util.AbstractTypeAwareBuilder; import org.opendaylight.yangtools.yang.parser.util.YangParseException; +/** + * @deprecated Pre-Beryllium implementation, scheduled for removal. + */ +@Deprecated public final class LeafSchemaNodeBuilder extends AbstractTypeAwareBuilder implements DataSchemaNodeBuilder { private LeafSchemaNodeImpl instance; private String defaultStr; @@ -35,6 +37,8 @@ public final class LeafSchemaNodeBuilder extends AbstractTypeAwareBuilder implem // DataSchemaNode args private boolean augmenting; private boolean addedByUses; + private LeafSchemaNode originalNode; + private LeafSchemaNodeBuilder originalBuilder; private boolean configuration; private final ConstraintsBuilder constraints; @@ -54,6 +58,7 @@ public final class LeafSchemaNodeBuilder extends AbstractTypeAwareBuilder implem status = base.getStatus(); augmenting = base.isAugmenting(); addedByUses = base.isAddedByUses(); + originalNode =base; configuration = base.isConfiguration(); this.type = base.getType(); unknownNodes.addAll(base.getUnknownSchemaNodes()); @@ -76,7 +81,7 @@ public final class LeafSchemaNodeBuilder extends AbstractTypeAwareBuilder implem instance.augmenting = augmenting; instance.addedByUses = addedByUses; instance.configuration = configuration; - instance.constraintsDef = constraints.toInstance(); + instance.constraintsDef = constraints.build(); instance.defaultStr = defaultStr; instance.unitsStr = unitsStr; @@ -91,6 +96,12 @@ public final class LeafSchemaNodeBuilder extends AbstractTypeAwareBuilder implem instance.type = type; } + // ORIGINAL NODE + if (originalNode == null && originalBuilder != null) { + originalNode = originalBuilder.build(); + } + instance.original = originalNode; + // UNKNOWN NODES for (UnknownSchemaNodeBuilder b : addedUnknownNodes) { unknownNodes.add(b.build()); @@ -165,6 +176,17 @@ public final class LeafSchemaNodeBuilder extends AbstractTypeAwareBuilder implem this.addedByUses = addedByUses; } + @Override + public LeafSchemaNodeBuilder getOriginal() { + return originalBuilder; + } + + @Override + public void setOriginal(final SchemaNodeBuilder builder) { + Preconditions.checkArgument(builder instanceof LeafSchemaNodeBuilder, "Original of leaf cannot be " + builder); + this.originalBuilder = (LeafSchemaNodeBuilder) builder; + } + @Override public boolean isConfiguration() { return configuration; @@ -195,7 +217,7 @@ public final class LeafSchemaNodeBuilder extends AbstractTypeAwareBuilder implem 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; } @@ -233,138 +255,4 @@ public final class LeafSchemaNodeBuilder extends AbstractTypeAwareBuilder implem return "leaf " + qname.getLocalName(); } - private static final class LeafSchemaNodeImpl implements LeafSchemaNode { - private final QName qname; - private final SchemaPath path; - private String description; - private String reference; - private Status status; - private boolean augmenting; - private boolean addedByUses; - private boolean configuration; - private ConstraintDefinition constraintsDef; - private TypeDefinition type; - private ImmutableList unknownNodes; - private String defaultStr; - private String unitsStr; - - private LeafSchemaNodeImpl(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 boolean isConfiguration() { - return configuration; - } - - @Override - public ConstraintDefinition getConstraints() { - return constraintsDef; - } - - @Override - public TypeDefinition getType() { - return type; - } - - @Override - public List getUnknownSchemaNodes() { - return unknownNodes; - } - - @Override - public String getDefault() { - return defaultStr; - } - - @Override - public String getUnits() { - return unitsStr; - } - - @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; - } - LeafSchemaNodeImpl other = (LeafSchemaNodeImpl) 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(LeafSchemaNodeImpl.class.getSimpleName()); - sb.append("["); - sb.append("qname=").append(qname); - sb.append(", path=").append(path); - sb.append("]"); - return sb.toString(); - } - } - }