X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fsal%2Fyang-prototype%2Fcode-generator%2Fyang-model-parser-impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fyang%2Fparser%2Fbuilder%2Fimpl%2FGroupingBuilderImpl.java;fp=opendaylight%2Fsal%2Fyang-prototype%2Fcode-generator%2Fyang-model-parser-impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fyang%2Fparser%2Fbuilder%2Fimpl%2FGroupingBuilderImpl.java;h=1cfba2517f434a84266576c674cc8ba60f886b83;hb=3c8c7171aa9a2fdf322b85cf104ae551665aa0d8;hp=5428259324a700a5c65ed9ac8378d0dd4df4e7ef;hpb=a954bf75193626833a2bd8b7395514a8b1aec032;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/impl/GroupingBuilderImpl.java b/opendaylight/sal/yang-prototype/code-generator/yang-model-parser-impl/src/main/java/org/opendaylight/controller/yang/parser/builder/impl/GroupingBuilderImpl.java index 5428259324..1cfba2517f 100644 --- a/opendaylight/sal/yang-prototype/code-generator/yang-model-parser-impl/src/main/java/org/opendaylight/controller/yang/parser/builder/impl/GroupingBuilderImpl.java +++ b/opendaylight/sal/yang-prototype/code-generator/yang-model-parser-impl/src/main/java/org/opendaylight/controller/yang/parser/builder/impl/GroupingBuilderImpl.java @@ -37,6 +37,7 @@ public final class GroupingBuilderImpl implements GroupingBuilder { private String description; private String reference; private Status status = Status.CURRENT; + private boolean addedByUses; private Set childNodes; private final Set addedChildNodes = new HashSet(); @@ -55,10 +56,27 @@ public final class GroupingBuilderImpl implements GroupingBuilder { public GroupingBuilderImpl(final QName qname, final int line) { this.qname = qname; - this.instance = new GroupingDefinitionImpl(qname); + instance = new GroupingDefinitionImpl(qname); this.line = line; } + public GroupingBuilderImpl(GroupingBuilder builder) { + qname = builder.getQName(); + instance = new GroupingDefinitionImpl(qname); + line = builder.getLine(); + schemaPath = builder.getPath(); + description = builder.getDescription(); + reference = builder.getReference(); + status = builder.getStatus(); + addedByUses = builder.isAddedByUses(); + childNodes = builder.getChildNodes(); + addedChildNodes.addAll(builder.getChildNodeBuilders()); + groupings = builder.getGroupings(); + addedGroupings.addAll(builder.getGroupingBuilders()); + addedUsesNodes.addAll(builder.getUses()); + addedUnknownNodes.addAll(builder.getUnknownNodes()); + } + @Override public GroupingDefinition build() { if (!isBuilt) { @@ -66,15 +84,16 @@ public final class GroupingBuilderImpl implements GroupingBuilder { instance.setDescription(description); instance.setReference(reference); instance.setStatus(status); + instance.setAddedByUses(addedByUses); // CHILD NODES final Map childs = new HashMap(); - if(childNodes == null) { + if (childNodes == null) { for (DataSchemaNodeBuilder node : addedChildNodes) { childs.put(node.getQName(), node.build()); } } else { - for(DataSchemaNode node : childNodes) { + for (DataSchemaNode node : childNodes) { childs.put(node.getQName(), node); } } @@ -133,7 +152,7 @@ public final class GroupingBuilderImpl implements GroupingBuilder { } @Override - public Set getTypeDefinitions() { + public Set getTypeDefinitionBuilders() { return addedTypedefs; } @@ -186,6 +205,16 @@ public final class GroupingBuilderImpl implements GroupingBuilder { this.status = status; } + @Override + public boolean isAddedByUses() { + return addedByUses; + } + + @Override + public void setAddedByUses(final boolean addedByUses) { + this.addedByUses = addedByUses; + } + @Override public DataSchemaNodeBuilder getChildNode(String name) { DataSchemaNodeBuilder result = null; @@ -198,13 +227,18 @@ public final class GroupingBuilderImpl implements GroupingBuilder { return result; } + @Override + public Set getChildNodes() { + return childNodes; + } + @Override public void addChildNode(final DataSchemaNodeBuilder childNode) { addedChildNodes.add(childNode); } @Override - public Set getChildNodes() { + public Set getChildNodeBuilders() { return addedChildNodes; } @@ -213,7 +247,12 @@ public final class GroupingBuilderImpl implements GroupingBuilder { } @Override - public Set getGroupings() { + public Set getGroupings() { + return Collections.emptySet(); + } + + @Override + public Set getGroupingBuilders() { return addedGroupings; } @@ -261,6 +300,7 @@ public final class GroupingBuilderImpl implements GroupingBuilder { private String description; private String reference; private Status status; + private boolean addedByUses; private Map childNodes = Collections.emptyMap(); private Set groupings = Collections.emptySet(); private Set> typeDefinitions = Collections.emptySet(); @@ -312,6 +352,15 @@ public final class GroupingBuilderImpl implements GroupingBuilder { this.status = status; } + @Override + public boolean isAddedByUses() { + return addedByUses; + } + + private void setAddedByUses(final boolean addedByUses) { + this.addedByUses = addedByUses; + } + @Override public Set getChildNodes() { return new HashSet(childNodes.values());