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=c77444269c297c75acacc650254dc2cc26a1a707;hb=c7f01a26828345591366693478d2285cbf004c48;hp=45bf23e721a3c8be8d188693e33947db037a6794;hpb=3732594ea24d5f39f742631e0a38e3f917f3658a;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..c77444269c 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 @@ -7,26 +7,31 @@ */ 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.List; import java.util.Set; + 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.DerivableSchemaNode; 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; +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 ContainerSchemaNodeBuilder extends AbstractDocumentedDataNodeContainerBuilder implements AugmentationTargetBuilder, DataSchemaNodeBuilder { private ContainerSchemaNodeImpl instance; @@ -37,6 +42,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 +65,7 @@ public final class ContainerSchemaNodeBuilder extends AbstractDocumentedDataNode augmenting = base.isAugmenting(); addedByUses = base.isAddedByUses(); + originalNode = base; configuration = base.isConfiguration(); presence = base.isPresenceContainer(); @@ -85,6 +93,12 @@ public final class ContainerSchemaNodeBuilder extends AbstractDocumentedDataNode instance.constraints = constraints.toInstance(); 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 +153,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; @@ -189,8 +215,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; @@ -207,13 +231,14 @@ public final class ContainerSchemaNodeBuilder extends AbstractDocumentedDataNode } private static final class ContainerSchemaNodeImpl extends AbstractDocumentedDataNodeContainer implements - ContainerSchemaNode { + ContainerSchemaNode, DerivableSchemaNode { private final QName qname; private final SchemaPath path; private boolean augmenting; private boolean addedByUses; private boolean configuration; + private ContainerSchemaNode original; private ConstraintDefinition constraints; private ImmutableSet augmentations; @@ -247,6 +272,11 @@ public final class ContainerSchemaNodeBuilder extends AbstractDocumentedDataNode return addedByUses; } + @Override + public Optional getOriginal() { + return Optional.fromNullable(original); + } + @Override public boolean isConfiguration() { return configuration; @@ -314,6 +344,7 @@ public final class ContainerSchemaNodeBuilder extends AbstractDocumentedDataNode public String toString() { return "container " + qname.getLocalName(); } + } }