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=d6867ce73592a3a3511e88ef451628cd915602a7;hp=6e804a199d3a829646cfa951120910543128d9c5;hb=ac39de5a9b96438d30df745895454c02e15e51e3;hpb=154b5dde1af41aff2ae0cc6e08400153162a4a3c 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 6e804a199d..d6867ce735 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,17 +7,20 @@ */ 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; +/** + * Basic implementation of DataNodeContainerBuilder. + */ +public abstract class AbstractDataNodeContainerBuilder extends AbstractBuilder implements DataNodeContainerBuilder { protected final QName qname; - protected Builder parent; protected Set childNodes; protected final Set addedChildNodes = new HashSet(); @@ -25,26 +28,11 @@ public abstract class AbstractDataNodeContainerBuilder implements DataNodeContai protected Set groupings; protected final Set addedGroupings = new HashSet(); - protected AbstractDataNodeContainerBuilder(final int line, final QName qname) { - this.line = line; + protected AbstractDataNodeContainerBuilder(final String moduleName, final int line, final QName qname) { + super(moduleName, line); this.qname = qname; } - @Override - public int getLine() { - return line; - } - - @Override - public Builder getParent() { - return parent; - } - - @Override - public void setParent(final Builder parent) { - this.parent = parent; - } - @Override public QName getQName() { return qname; @@ -52,6 +40,9 @@ public abstract class AbstractDataNodeContainerBuilder implements DataNodeContai @Override public Set getChildNodes() { + if (childNodes == null) { + return Collections.emptySet(); + } return childNodes; } @@ -65,12 +56,33 @@ public abstract class AbstractDataNodeContainerBuilder implements DataNodeContai } @Override - public void addChildNode(DataSchemaNodeBuilder childNode) { - addedChildNodes.add(childNode); + public DataSchemaNodeBuilder getDataChildByName(final String name) { + for (DataSchemaNodeBuilder child : addedChildNodes) { + if (child.getQName().getLocalName().equals(name)) { + return child; + } + } + return null; + } + + @Override + public void addChildNode(DataSchemaNodeBuilder child) { + String childName = child.getQName().getLocalName(); + for (DataSchemaNodeBuilder addedChildNode : addedChildNodes) { + if (addedChildNode.getQName().getLocalName().equals(childName)) { + throw new YangParseException(child.getModuleName(), child.getLine(), "Can not add '" + child + + "' to node '" + qname.getLocalName() + "' in module '" + moduleName + + "': node with same name already declared at line " + addedChildNode.getLine()); + } + } + addedChildNodes.add(child); } @Override public Set getGroupings() { + if (groupings == null) { + return Collections.emptySet(); + } return groupings; } @@ -84,6 +96,14 @@ public abstract class AbstractDataNodeContainerBuilder implements DataNodeContai @Override public void addGrouping(GroupingBuilder grouping) { + String groupingName = grouping.getQName().getLocalName(); + for (GroupingBuilder addedGrouping : addedGroupings) { + if (addedGrouping.getQName().getLocalName().equals(groupingName)) { + throw new YangParseException(grouping.getModuleName(), grouping.getLine(), "Can not add '" + grouping + + "': grouping with same name already declared in module '" + moduleName + "' at line " + + addedGrouping.getLine()); + } + } addedGroupings.add(grouping); }