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%2FContainerSchemaNodeBuilder.java;h=421d35ff72878880c0fbf590e53fc69bae61fc95;hb=42abb28b99a02f9580f4676ce5c315628e5bcd24;hp=45bf23e721a3c8be8d188693e33947db037a6794;hpb=c6b4017ff4babad7e237c56ebe299efc90a6f990;p=yangtools.git diff --git a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/ContainerSchemaNodeBuilder.java b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/ContainerSchemaNodeBuilder.java index 45bf23e721..421d35ff72 100644 --- a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/ContainerSchemaNodeBuilder.java +++ b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/ContainerSchemaNodeBuilder.java @@ -12,21 +12,23 @@ import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableSet; import java.util.ArrayList; import java.util.List; -import java.util.Set; +import java.util.Objects; import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.model.api.AugmentationSchema; -import org.opendaylight.yangtools.yang.model.api.ConstraintDefinition; import org.opendaylight.yangtools.yang.model.api.ContainerSchemaNode; import org.opendaylight.yangtools.yang.model.api.SchemaPath; -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; 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.AbstractDocumentedDataNodeContainer; import org.opendaylight.yangtools.yang.parser.builder.util.AbstractDocumentedDataNodeContainerBuilder; +/** + * @deprecated Pre-Beryllium implementation, scheduled for removal. + */ +@Deprecated public final class ContainerSchemaNodeBuilder extends AbstractDocumentedDataNodeContainerBuilder implements AugmentationTargetBuilder, DataSchemaNodeBuilder { private ContainerSchemaNodeImpl instance; @@ -37,6 +39,8 @@ public final class ContainerSchemaNodeBuilder extends AbstractDocumentedDataNode private boolean augmenting; private boolean addedByUses; private boolean configuration; + private ContainerSchemaNode originalNode; + private ContainerSchemaNodeBuilder originalBuilder; private final ConstraintsBuilder constraints; // AugmentationTarget args private final List augmentations = new ArrayList<>(); @@ -58,6 +62,7 @@ public final class ContainerSchemaNodeBuilder extends AbstractDocumentedDataNode augmenting = base.isAugmenting(); addedByUses = base.isAddedByUses(); + originalNode = base; configuration = base.isConfiguration(); presence = base.isPresenceContainer(); @@ -82,9 +87,15 @@ public final class ContainerSchemaNodeBuilder extends AbstractDocumentedDataNode instance.augmenting = augmenting; instance.addedByUses = addedByUses; instance.configuration = configuration; - instance.constraints = constraints.toInstance(); + instance.constraints = constraints.build(); instance.presence = presence; + // ORIGINAL NODE + if (originalNode == null && originalBuilder != null) { + originalNode = originalBuilder.build(); + } + instance.original = originalNode; + // AUGMENTATIONS for (AugmentationSchemaBuilder builder : augmentationBuilders) { augmentations.add(builder.build()); @@ -139,6 +150,18 @@ public final class ContainerSchemaNodeBuilder extends AbstractDocumentedDataNode this.addedByUses = addedByUses; } + @Override + public ContainerSchemaNodeBuilder getOriginal() { + return originalBuilder; + } + + @Override + public void setOriginal(final SchemaNodeBuilder builder) { + Preconditions.checkArgument(builder instanceof ContainerSchemaNodeBuilder, "Original of container cannot be " + + builder); + this.originalBuilder = (ContainerSchemaNodeBuilder) builder; + } + @Override public boolean isConfiguration() { return configuration; @@ -166,7 +189,7 @@ public final class ContainerSchemaNodeBuilder extends AbstractDocumentedDataNode public int hashCode() { final int prime = 31; int result = 1; - result = prime * result + ((path == null) ? 0 : path.hashCode()); + result = prime * result + Objects.hashCode(path); return result; } @@ -189,8 +212,6 @@ public final class ContainerSchemaNodeBuilder extends AbstractDocumentedDataNode } else if (!path.equals(other.path)) { return false; } - // FIXME: Do we really need this? This actually triggers equals - // up to the root builder. if (getParent() == null) { if (other.getParent() != null) { return false; @@ -206,114 +227,4 @@ public final class ContainerSchemaNodeBuilder extends AbstractDocumentedDataNode return "container " + qname.getLocalName(); } - private static final class ContainerSchemaNodeImpl extends AbstractDocumentedDataNodeContainer implements - ContainerSchemaNode { - private final QName qname; - private final SchemaPath path; - - private boolean augmenting; - private boolean addedByUses; - private boolean configuration; - private ConstraintDefinition constraints; - - private ImmutableSet augmentations; - private ImmutableList unknownNodes; - - private boolean presence; - - public ContainerSchemaNodeImpl(final ContainerSchemaNodeBuilder builder) { - super(builder); - this.qname = builder.getQName(); - this.path = builder.getPath(); - } - - @Override - public QName getQName() { - return qname; - } - - @Override - public SchemaPath getPath() { - return path; - } - - @Override - public boolean isAugmenting() { - return augmenting; - } - - @Override - public boolean isAddedByUses() { - return addedByUses; - } - - @Override - public boolean isConfiguration() { - return configuration; - } - - @Override - public ConstraintDefinition getConstraints() { - return constraints; - } - - @Override - public Set getAvailableAugmentations() { - return augmentations; - } - - @Override - public boolean isPresenceContainer() { - return presence; - } - - @Override - public List getUnknownSchemaNodes() { - return 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(final Object obj) { - if (this == obj) { - return true; - } - if (obj == null) { - return false; - } - if (getClass() != obj.getClass()) { - return false; - } - ContainerSchemaNodeImpl other = (ContainerSchemaNodeImpl) 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() { - return "container " + qname.getLocalName(); - } - } - }