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;h=20503488ce9802e019c99bd8e46f82e929d7f695;hb=88187167a1b7928602fd8d72cb7d4dc2b38dfa70;hp=1cfba2517f434a84266576c674cc8ba60f886b83;hpb=3c8c7171aa9a2fdf322b85cf104ae551665aa0d8;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 1cfba2517f..20503488ce 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 @@ -14,6 +14,7 @@ import java.util.HashSet; import java.util.List; import java.util.Map; import java.util.Set; +import java.util.TreeSet; import org.opendaylight.controller.yang.common.QName; import org.opendaylight.controller.yang.model.api.DataSchemaNode; @@ -23,12 +24,15 @@ import org.opendaylight.controller.yang.model.api.Status; import org.opendaylight.controller.yang.model.api.TypeDefinition; import org.opendaylight.controller.yang.model.api.UnknownSchemaNode; import org.opendaylight.controller.yang.model.api.UsesNode; +import org.opendaylight.controller.yang.parser.builder.api.Builder; import org.opendaylight.controller.yang.parser.builder.api.DataSchemaNodeBuilder; import org.opendaylight.controller.yang.parser.builder.api.GroupingBuilder; import org.opendaylight.controller.yang.parser.builder.api.TypeDefinitionBuilder; import org.opendaylight.controller.yang.parser.builder.api.UsesNodeBuilder; +import org.opendaylight.controller.yang.parser.util.Comparators; public final class GroupingBuilderImpl implements GroupingBuilder { + private Builder parent; private boolean isBuilt; private final GroupingDefinitionImpl instance; private final int line; @@ -62,6 +66,7 @@ public final class GroupingBuilderImpl implements GroupingBuilder { public GroupingBuilderImpl(GroupingBuilder builder) { qname = builder.getQName(); + parent = builder.getParent(); instance = new GroupingDefinitionImpl(qname); line = builder.getLine(); schemaPath = builder.getPath(); @@ -74,7 +79,7 @@ public final class GroupingBuilderImpl implements GroupingBuilder { groupings = builder.getGroupings(); addedGroupings.addAll(builder.getGroupingBuilders()); addedUsesNodes.addAll(builder.getUses()); - addedUnknownNodes.addAll(builder.getUnknownNodes()); + addedUnknownNodes.addAll(builder.getUnknownNodeBuilders()); } @Override @@ -100,8 +105,8 @@ public final class GroupingBuilderImpl implements GroupingBuilder { instance.setChildNodes(childs); // GROUPINGS - if(groupings == null) { - groupings = new HashSet(); + if (groupings == null) { + groupings = new TreeSet(Comparators.SCHEMA_NODE_COMP); for (GroupingBuilder builder : addedGroupings) { groupings.add(builder.build()); } @@ -109,8 +114,8 @@ public final class GroupingBuilderImpl implements GroupingBuilder { instance.setGroupings(groupings); // TYPEDEFS - if(typedefs == null) { - typedefs = new HashSet>(); + if (typedefs == null) { + typedefs = new TreeSet>(Comparators.SCHEMA_NODE_COMP); for (TypeDefinitionBuilder entry : addedTypedefs) { typedefs.add(entry.build()); } @@ -118,7 +123,7 @@ public final class GroupingBuilderImpl implements GroupingBuilder { instance.setTypeDefinitions(typedefs); // USES - if(usesNodes == null) { + if (usesNodes == null) { usesNodes = new HashSet(); for (UsesNodeBuilder builder : addedUsesNodes) { usesNodes.add(builder.build()); @@ -127,11 +132,12 @@ public final class GroupingBuilderImpl implements GroupingBuilder { instance.setUses(usesNodes); // UNKNOWN NODES - if(unknownNodes == null) { + if (unknownNodes == null) { unknownNodes = new ArrayList(); for (UnknownSchemaNodeBuilder b : addedUnknownNodes) { unknownNodes.add(b.build()); } + Collections.sort(unknownNodes, Comparators.SCHEMA_NODE_COMP); } instance.setUnknownSchemaNodes(unknownNodes); @@ -146,6 +152,16 @@ public final class GroupingBuilderImpl implements GroupingBuilder { return line; } + @Override + public Builder getParent() { + return parent; + } + + @Override + public void setParent(final Builder parent) { + this.parent = parent; + } + @Override public QName getQName() { return qname; @@ -215,18 +231,6 @@ public final class GroupingBuilderImpl implements GroupingBuilder { this.addedByUses = addedByUses; } - @Override - public DataSchemaNodeBuilder getChildNode(String name) { - DataSchemaNodeBuilder result = null; - for (DataSchemaNodeBuilder node : addedChildNodes) { - if (node.getQName().getLocalName().equals(name)) { - result = node; - break; - } - } - return result; - } - @Override public Set getChildNodes() { return childNodes; @@ -242,6 +246,16 @@ public final class GroupingBuilderImpl implements GroupingBuilder { return addedChildNodes; } + @Override + public DataSchemaNodeBuilder getDataChildByName(final String name) { + for(DataSchemaNodeBuilder child : addedChildNodes) { + if(child.getQName().getLocalName().equals(name)) { + return child; + } + } + return null; + } + public void setChildNodes(final Set childNodes) { this.childNodes = childNodes; } @@ -280,12 +294,12 @@ public final class GroupingBuilderImpl implements GroupingBuilder { } @Override - public List getUnknownNodes() { + public List getUnknownNodeBuilders() { return addedUnknownNodes; } @Override - public void addUnknownSchemaNode(final UnknownSchemaNodeBuilder unknownNode) { + public void addUnknownNodeBuilder(final UnknownSchemaNodeBuilder unknownNode) { addedUnknownNodes.add(unknownNode); } @@ -293,6 +307,10 @@ public final class GroupingBuilderImpl implements GroupingBuilder { this.unknownNodes = unknownNodes; } + @Override + public String toString() { + return "grouping " + qname.getLocalName(); + } private final class GroupingDefinitionImpl implements GroupingDefinition { private final QName qname; @@ -363,7 +381,9 @@ public final class GroupingBuilderImpl implements GroupingBuilder { @Override public Set getChildNodes() { - return new HashSet(childNodes.values()); + final Set result = new TreeSet(Comparators.SCHEMA_NODE_COMP); + result.addAll(childNodes.values()); + return result; } private void setChildNodes(Map childNodes) { @@ -465,8 +485,7 @@ public final class GroupingBuilderImpl implements GroupingBuilder { @Override public String toString() { - StringBuilder sb = new StringBuilder( - GroupingDefinitionImpl.class.getSimpleName()); + StringBuilder sb = new StringBuilder(GroupingDefinitionImpl.class.getSimpleName()); sb.append("["); sb.append("qname=" + qname); sb.append("]");