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=df85c5cbf09fe166630da10f8ae5f3347cabd055;hb=ac39de5a9b96438d30df745895454c02e15e51e3;hpb=0df356fd6dd1e24f82a4afaa6c824517d354fb20 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 df85c5cbf0..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,26 +7,20 @@ */ package org.opendaylight.controller.yang.parser.builder.api; -import java.util.ArrayList; import java.util.Collections; import java.util.HashSet; -import java.util.List; 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.model.api.UnknownSchemaNode; -import org.opendaylight.controller.yang.parser.builder.impl.UnknownSchemaNodeBuilder; import org.opendaylight.controller.yang.parser.util.YangParseException; /** * Basic implementation of DataNodeContainerBuilder. */ -public abstract class AbstractDataNodeContainerBuilder implements DataNodeContainerBuilder { - protected final int line; +public abstract class AbstractDataNodeContainerBuilder extends AbstractBuilder implements DataNodeContainerBuilder { protected final QName qname; - protected Builder parent; protected Set childNodes; protected final Set addedChildNodes = new HashSet(); @@ -34,29 +28,11 @@ public abstract class AbstractDataNodeContainerBuilder implements DataNodeContai protected Set groupings; protected final Set addedGroupings = new HashSet(); - protected List unknownNodes; - protected final List addedUnknownNodes = new ArrayList(); - - 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; @@ -91,9 +67,12 @@ public abstract class AbstractDataNodeContainerBuilder implements DataNodeContai @Override 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()); + 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); @@ -116,27 +95,16 @@ public abstract class AbstractDataNodeContainerBuilder implements DataNodeContai } @Override - 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()); + 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(groupingBuilder); - } - - @Override - public List getUnknownNodeBuilders() { - return addedUnknownNodes; - } - - @Override - public void addUnknownNodeBuilder(UnknownSchemaNodeBuilder unknownNode) { - addedUnknownNodes.add(unknownNode); - } - - public void setUnknownNodes(List unknownNodes) { - this.unknownNodes = unknownNodes; + addedGroupings.add(grouping); } }