X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=yang%2Fyang-data-impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fyangtools%2Fyang%2Fdata%2Fimpl%2Fschema%2Ftree%2FNoopDataTreeCandidate.java;h=608d1d9273b271c9b97d4e3cfd1039746fda6ce0;hb=bb92c633b41a636162f4f14cf818f4f66d9eaab4;hp=a936b2c7781dde639f12eedf7b74be0f0137d354;hpb=ece16db3db0f3599ee0ab92899ac42316414e032;p=yangtools.git diff --git a/yang/yang-data-impl/src/main/java/org/opendaylight/yangtools/yang/data/impl/schema/tree/NoopDataTreeCandidate.java b/yang/yang-data-impl/src/main/java/org/opendaylight/yangtools/yang/data/impl/schema/tree/NoopDataTreeCandidate.java index a936b2c778..608d1d9273 100644 --- a/yang/yang-data-impl/src/main/java/org/opendaylight/yangtools/yang/data/impl/schema/tree/NoopDataTreeCandidate.java +++ b/yang/yang-data-impl/src/main/java/org/opendaylight/yangtools/yang/data/impl/schema/tree/NoopDataTreeCandidate.java @@ -9,13 +9,15 @@ package org.opendaylight.yangtools.yang.data.impl.schema.tree; import com.google.common.base.Optional; import com.google.common.base.Preconditions; -import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier; -import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.PathArgument; +import java.util.Collection; +import java.util.Collections; +import javax.annotation.Nonnull; +import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; +import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.PathArgument; import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; import org.opendaylight.yangtools.yang.data.api.schema.tree.DataTreeCandidateNode; import org.opendaylight.yangtools.yang.data.api.schema.tree.ModificationType; - -import java.util.Collections; +import org.opendaylight.yangtools.yang.data.api.schema.tree.spi.TreeNode; /** * Internal utility class for an empty candidate. We instantiate this class @@ -25,38 +27,55 @@ import java.util.Collections; final class NoopDataTreeCandidate extends AbstractDataTreeCandidate { private static final DataTreeCandidateNode ROOT = new DataTreeCandidateNode() { @Override + @Nonnull public ModificationType getModificationType() { return ModificationType.UNMODIFIED; } @Override - public Iterable getChildNodes() { + public Collection getChildNodes() { return Collections.emptyList(); } @Override + @Nonnull public PathArgument getIdentifier() { throw new IllegalStateException("Attempted to read identifier of the no-operation change"); } @Override + @Nonnull public Optional> getDataAfter() { return Optional.absent(); } @Override + @Nonnull public Optional> getDataBefore() { return Optional.absent(); } + + @Override + public DataTreeCandidateNode getModifiedChild(final PathArgument identifier) { + return null; + } }; + private final TreeNode afterRoot; - protected NoopDataTreeCandidate(final InstanceIdentifier rootPath, final ModifiedNode modificationRoot) { + protected NoopDataTreeCandidate(final YangInstanceIdentifier rootPath, final ModifiedNode modificationRoot, final TreeNode afterRoot) { super(rootPath); - Preconditions.checkArgument(modificationRoot.getType() == ModificationType.UNMODIFIED); + Preconditions.checkArgument(modificationRoot.getOperation() == LogicalOperation.NONE); + this.afterRoot = Preconditions.checkNotNull(afterRoot); } @Override public DataTreeCandidateNode getRootNode() { return ROOT; } + + @Override + @Nonnull + protected TreeNode getTipRoot() { + return afterRoot; + } }