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%2Futil%2FAbstractDocumentedDataNodeContainer.java;h=766b61fbce1605e094f920187822eeecc9d186e5;hb=24b697d9f464bf5557796c2a7a6bfc5c14f50796;hp=259a48e471b47005bce8dbb8d7bb9e1871956542;hpb=0dab204f1b81c5f0f500bc7f4bc3301b321288c3;p=yangtools.git diff --git a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/util/AbstractDocumentedDataNodeContainer.java b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/util/AbstractDocumentedDataNodeContainer.java index 259a48e471..766b61fbce 100644 --- a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/util/AbstractDocumentedDataNodeContainer.java +++ b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/util/AbstractDocumentedDataNodeContainer.java @@ -1,9 +1,18 @@ +/* + * Copyright (c) 2014 Cisco Systems, Inc. and others. All rights reserved. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v1.0 which accompanies this distribution, + * and is available at http://www.eclipse.org/legal/epl-v10.html + */ package org.opendaylight.yangtools.yang.parser.builder.util; import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableSet; + import java.util.Map; import java.util.Set; + import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.model.api.DataNodeContainer; import org.opendaylight.yangtools.yang.model.api.DataSchemaNode; @@ -17,6 +26,7 @@ public abstract class AbstractDocumentedDataNodeContainer extends AbstractDocume private final Set groupings; private final Set uses; private final Set> typeDefinitions; + private final Set publicChildNodes; protected AbstractDocumentedDataNodeContainer(final AbstractDocumentedDataNodeContainerBuilder data) { super(data); @@ -27,6 +37,7 @@ public abstract class AbstractDocumentedDataNodeContainer extends AbstractDocume groupings = ImmutableSet.copyOf(data.getGroupings()); uses = ImmutableSet.copyOf(data.getUsesNodes()); typeDefinitions = ImmutableSet.copyOf(data.getTypeDefinitions()); + publicChildNodes = ImmutableSet.copyOf(childNodes.values()); } @Override @@ -36,7 +47,7 @@ public abstract class AbstractDocumentedDataNodeContainer extends AbstractDocume @Override public final Set getChildNodes() { - return ImmutableSet.copyOf(childNodes.values()); + return publicChildNodes; } @Override @@ -46,12 +57,8 @@ public abstract class AbstractDocumentedDataNodeContainer extends AbstractDocume @Override public final DataSchemaNode getDataChildByName(final QName name) { - for (DataSchemaNode node : childNodes.values()) { - if (node.getQName().equals(name)) { - return node; - } - } - return null; + // Child nodes are keyed by their container name, so we can do a direct lookup + return childNodes.get(name); } @Override