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%2Fnodes%2FAbstractImmutableDataContainerNode.java;h=ea6e954da79685bb471d5bde4ae39750d08ffe1f;hb=24d06767f3a0ead8152a745fb05eda1d4a37ba77;hp=a3de4638061851c87a8b93d593cf52bda6d0b8af;hpb=eedbf1abb168811cf17d44cce4af736e689288ff;p=yangtools.git diff --git a/yang/yang-data-impl/src/main/java/org/opendaylight/yangtools/yang/data/impl/schema/nodes/AbstractImmutableDataContainerNode.java b/yang/yang-data-impl/src/main/java/org/opendaylight/yangtools/yang/data/impl/schema/nodes/AbstractImmutableDataContainerNode.java index a3de463806..ea6e954da7 100644 --- a/yang/yang-data-impl/src/main/java/org/opendaylight/yangtools/yang/data/impl/schema/nodes/AbstractImmutableDataContainerNode.java +++ b/yang/yang-data-impl/src/main/java/org/opendaylight/yangtools/yang/data/impl/schema/nodes/AbstractImmutableDataContainerNode.java @@ -7,27 +7,25 @@ */ package org.opendaylight.yangtools.yang.data.impl.schema.nodes; +import com.google.common.base.Optional; +import java.util.Collection; import java.util.Map; - import org.opendaylight.yangtools.concepts.Immutable; -import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.PathArgument; +import org.opendaylight.yangtools.util.ImmutableOffsetMap; +import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.PathArgument; import org.opendaylight.yangtools.yang.data.api.schema.DataContainerChild; import org.opendaylight.yangtools.yang.data.api.schema.DataContainerNode; -import com.google.common.base.Optional; -import com.google.common.collect.Iterables; - -public abstract class AbstractImmutableDataContainerNode // - extends AbstractImmutableNormalizedNode>> // +public abstract class AbstractImmutableDataContainerNode + extends AbstractImmutableNormalizedNode>> implements Immutable, DataContainerNode { - - protected final Map> children; - + private final Map> children; public AbstractImmutableDataContainerNode( final Map> children, final K nodeIdentifier) { - super(nodeIdentifier, Iterables.unmodifiableIterable(children.values())); - this.children = children; + super(nodeIdentifier); + + this.children = ImmutableOffsetMap.unorderedCopyOf(children); } @Override @@ -35,11 +33,29 @@ public abstract class AbstractImmutableDataContainerNode return Optional.> fromNullable(children.get(child)); } + @Override + public final Collection> getValue() { + return children.values(); + } + @Override protected int valueHashCode() { return children.hashCode(); } + /** + * DO NOT USE THIS METHOD. + * + * This is an implementation-internal API and no outside users should use it. If you do, + * you are asking for trouble, as the returned object is not guaranteed to conform to + * java.util.Map interface. + * + * @return An unmodifiable view if this node's children. + */ + public final Map> getChildren() { + return children; + } + @Override protected boolean valueEquals(final AbstractImmutableNormalizedNode other) { if (!(other instanceof AbstractImmutableDataContainerNode)) {