X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fsal%2Fyang-prototype%2Fcode-generator%2Fyang-model-parser-impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fyang%2Fparser%2Fbuilder%2Fapi%2FAbstractDataNodeContainerBuilder.java;h=091bfc72337e8037a1d823f81f352990d00126ec;hp=116f82e8d8ce6d51ef7011d94518675b361f61ee;hb=271b40037939f2020378be14ca13caef16276b6e;hpb=7c595c8a6f3c4dfaa11cb616b937faf414e74852 diff --git a/opendaylight/sal/yang-prototype/code-generator/yang-model-parser-impl/src/main/java/org/opendaylight/controller/yang/parser/builder/api/AbstractDataNodeContainerBuilder.java b/opendaylight/sal/yang-prototype/code-generator/yang-model-parser-impl/src/main/java/org/opendaylight/controller/yang/parser/builder/api/AbstractDataNodeContainerBuilder.java index 116f82e8d8..091bfc7233 100644 --- a/opendaylight/sal/yang-prototype/code-generator/yang-model-parser-impl/src/main/java/org/opendaylight/controller/yang/parser/builder/api/AbstractDataNodeContainerBuilder.java +++ b/opendaylight/sal/yang-prototype/code-generator/yang-model-parser-impl/src/main/java/org/opendaylight/controller/yang/parser/builder/api/AbstractDataNodeContainerBuilder.java @@ -7,12 +7,14 @@ */ package org.opendaylight.controller.yang.parser.builder.api; +import java.util.Collections; import java.util.HashSet; import java.util.Set; import org.opendaylight.controller.yang.common.QName; import org.opendaylight.controller.yang.model.api.DataSchemaNode; import org.opendaylight.controller.yang.model.api.GroupingDefinition; +import org.opendaylight.controller.yang.parser.util.YangParseException; public abstract class AbstractDataNodeContainerBuilder implements DataNodeContainerBuilder { protected final int line; @@ -52,6 +54,9 @@ public abstract class AbstractDataNodeContainerBuilder implements DataNodeContai @Override public Set getChildNodes() { + if (childNodes == null) { + return Collections.emptySet(); + } return childNodes; } @@ -66,8 +71,8 @@ public abstract class AbstractDataNodeContainerBuilder implements DataNodeContai @Override public DataSchemaNodeBuilder getDataChildByName(final String name) { - for(DataSchemaNodeBuilder child : addedChildNodes) { - if(child.getQName().getLocalName().equals(name)) { + for (DataSchemaNodeBuilder child : addedChildNodes) { + if (child.getQName().getLocalName().equals(name)) { return child; } } @@ -75,12 +80,20 @@ public abstract class AbstractDataNodeContainerBuilder implements DataNodeContai } @Override - public void addChildNode(DataSchemaNodeBuilder childNode) { - addedChildNodes.add(childNode); + public void addChildNode(DataSchemaNodeBuilder child) { + for (DataSchemaNodeBuilder childNode : addedChildNodes) { + if (childNode.getQName().getLocalName().equals(child.getQName().getLocalName())) { + throw new YangParseException(child.getLine(), "Duplicate node found at line " + childNode.getLine()); + } + } + addedChildNodes.add(child); } @Override public Set getGroupings() { + if (groupings == null) { + return Collections.emptySet(); + } return groupings; } @@ -93,8 +106,13 @@ public abstract class AbstractDataNodeContainerBuilder implements DataNodeContai } @Override - public void addGrouping(GroupingBuilder grouping) { - addedGroupings.add(grouping); + public void addGrouping(GroupingBuilder groupingBuilder) { + for (GroupingBuilder gb : addedGroupings) { + if (gb.getQName().getLocalName().equals(groupingBuilder.getQName().getLocalName())) { + throw new YangParseException(groupingBuilder.getLine(), "Duplicate node found at line " + gb.getLine()); + } + } + addedGroupings.add(groupingBuilder); } }