X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;ds=sidebyside;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;hb=ac39de5a9b96438d30df745895454c02e15e51e3;hp=8ca88d8d6110aa6807da562ff3c2543c10faeb57;hpb=586e8148730acc468c1d82cbac370f51c4c11681;p=controller.git 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 8ca88d8d61..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,16 +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 { - - private final QName qname; +/** + * Basic implementation of DataNodeContainerBuilder. + */ +public abstract class AbstractDataNodeContainerBuilder extends AbstractBuilder implements DataNodeContainerBuilder { + protected final QName qname; protected Set childNodes; protected final Set addedChildNodes = new HashSet(); @@ -24,7 +28,8 @@ public abstract class AbstractDataNodeContainerBuilder implements DataNodeContai protected Set groupings; protected final Set addedGroupings = new HashSet(); - protected AbstractDataNodeContainerBuilder(QName qname) { + protected AbstractDataNodeContainerBuilder(final String moduleName, final int line, final QName qname) { + super(moduleName, line); this.qname = qname; } @@ -34,30 +39,72 @@ public abstract class AbstractDataNodeContainerBuilder implements DataNodeContai } @Override - public Set getChildNodes() { - return addedChildNodes; + public Set getChildNodes() { + if (childNodes == null) { + return Collections.emptySet(); + } + return childNodes; + } + + public void setChildNodes(Set childNodes) { + this.childNodes = childNodes; } @Override - public void addChildNode(DataSchemaNodeBuilder childNode) { - addedChildNodes.add(childNode); + public Set getChildNodeBuilders() { + return addedChildNodes; } - public void setChildNodes(Set childNodes) { - this.childNodes = childNodes; + @Override + public DataSchemaNodeBuilder getDataChildByName(final String name) { + for (DataSchemaNodeBuilder child : addedChildNodes) { + if (child.getQName().getLocalName().equals(name)) { + return child; + } + } + return null; } - public Set getGroupings() { - return addedGroupings; + @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 void addGrouping(GroupingBuilder grouping) { - addedGroupings.add(grouping); + public Set getGroupings() { + if (groupings == null) { + return Collections.emptySet(); + } + return groupings; } public void setGroupings(final Set groupings) { this.groupings = groupings; } + public Set getGroupingBuilders() { + return addedGroupings; + } + + @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); + } + }