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=1cfba2517f434a84266576c674cc8ba60f886b83;hb=c9006d027a5c5b639e57aa7b8484ec1ff3497dc8;hp=19c94a3f3365bc059674c574f19e061161e2138f;hpb=39ff6ed2000232d607877311770c74cef36cf96f;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 19c94a3f33..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 @@ -28,59 +28,115 @@ 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; -public class GroupingBuilderImpl implements GroupingBuilder { +public final class GroupingBuilderImpl implements GroupingBuilder { + private boolean isBuilt; private final GroupingDefinitionImpl instance; private final int line; + private final QName qname; private SchemaPath schemaPath; - private final Set childNodes = new HashSet(); - private final Set groupings = new HashSet(); + private String description; + private String reference; + private Status status = Status.CURRENT; + private boolean addedByUses; + + private Set childNodes; + private final Set addedChildNodes = new HashSet(); + + private Set groupings; + private final Set addedGroupings = new HashSet(); + + private Set> typedefs; private final Set addedTypedefs = new HashSet(); - private final Set usesNodes = new HashSet(); + + private Set usesNodes; + private final Set addedUsesNodes = new HashSet(); + + private List unknownNodes; private final List addedUnknownNodes = new ArrayList(); - GroupingBuilderImpl(final QName qname, final int line) { - this.instance = new GroupingDefinitionImpl(qname); + public GroupingBuilderImpl(final QName qname, final int line) { + this.qname = 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() { - instance.setPath(schemaPath); + if (!isBuilt) { + instance.setPath(schemaPath); + instance.setDescription(description); + instance.setReference(reference); + instance.setStatus(status); + instance.setAddedByUses(addedByUses); + + // CHILD NODES + final Map childs = new HashMap(); + if (childNodes == null) { + for (DataSchemaNodeBuilder node : addedChildNodes) { + childs.put(node.getQName(), node.build()); + } + } else { + for (DataSchemaNode node : childNodes) { + childs.put(node.getQName(), node); + } + } + instance.setChildNodes(childs); - // CHILD NODES - final Map childs = new HashMap(); - for (DataSchemaNodeBuilder node : childNodes) { - childs.put(node.getQName(), node.build()); - } - instance.setChildNodes(childs); + // GROUPINGS + if(groupings == null) { + groupings = new HashSet(); + for (GroupingBuilder builder : addedGroupings) { + groupings.add(builder.build()); + } + } + instance.setGroupings(groupings); - // GROUPINGS - final Set groupingDefs = new HashSet(); - for (GroupingBuilder builder : groupings) { - groupingDefs.add(builder.build()); - } - instance.setGroupings(groupingDefs); + // TYPEDEFS + if(typedefs == null) { + typedefs = new HashSet>(); + for (TypeDefinitionBuilder entry : addedTypedefs) { + typedefs.add(entry.build()); + } + } + instance.setTypeDefinitions(typedefs); - // TYPEDEFS - final Set> typedefs = new HashSet>(); - for (TypeDefinitionBuilder entry : addedTypedefs) { - typedefs.add(entry.build()); - } - instance.setTypeDefinitions(typedefs); + // USES + if(usesNodes == null) { + usesNodes = new HashSet(); + for (UsesNodeBuilder builder : addedUsesNodes) { + usesNodes.add(builder.build()); + } + } + instance.setUses(usesNodes); - // USES - final Set usesNodeDefs = new HashSet(); - for (UsesNodeBuilder builder : usesNodes) { - usesNodeDefs.add(builder.build()); - } - instance.setUses(usesNodeDefs); + // UNKNOWN NODES + if(unknownNodes == null) { + unknownNodes = new ArrayList(); + for (UnknownSchemaNodeBuilder b : addedUnknownNodes) { + unknownNodes.add(b.build()); + } + } + instance.setUnknownSchemaNodes(unknownNodes); - // UNKNOWN NODES - final List unknownNodes = new ArrayList(); - for(UnknownSchemaNodeBuilder b : addedUnknownNodes) { - unknownNodes.add(b.build()); + isBuilt = true; } - instance.setUnknownSchemaNodes(unknownNodes); return instance; } @@ -90,12 +146,14 @@ public class GroupingBuilderImpl implements GroupingBuilder { return line; } - /** - * Always returns null. - */ @Override public QName getQName() { - return null; + return qname; + } + + @Override + public Set getTypeDefinitionBuilders() { + return addedTypedefs; } @Override @@ -103,6 +161,10 @@ public class GroupingBuilderImpl implements GroupingBuilder { addedTypedefs.add(type); } + public void setTypedefs(final Set> typedefs) { + this.typedefs = typedefs; + } + @Override public SchemaPath getPath() { return schemaPath; @@ -113,26 +175,51 @@ public class GroupingBuilderImpl implements GroupingBuilder { this.schemaPath = schemaPath; } + @Override + public String getDescription() { + return description; + } + @Override public void setDescription(final String description) { - instance.setDescription(description); + this.description = description; + } + + @Override + public String getReference() { + return reference; } @Override public void setReference(final String reference) { - instance.setReference(reference); + this.reference = reference; + } + + @Override + public Status getStatus() { + return status; } @Override public void setStatus(final Status status) { - instance.setStatus(status); + 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; - for(DataSchemaNodeBuilder node : childNodes) { - if(node.getQName().getLocalName().equals(name)) { + for (DataSchemaNodeBuilder node : addedChildNodes) { + if (node.getQName().getLocalName().equals(name)) { result = node; break; } @@ -140,24 +227,61 @@ public class GroupingBuilderImpl implements GroupingBuilder { return result; } + @Override + public Set getChildNodes() { + return childNodes; + } + @Override public void addChildNode(final DataSchemaNodeBuilder childNode) { - childNodes.add(childNode); + addedChildNodes.add(childNode); } @Override - public Set getChildNodes() { - return childNodes; + public Set getChildNodeBuilders() { + return addedChildNodes; + } + + public void setChildNodes(final Set childNodes) { + this.childNodes = childNodes; + } + + @Override + public Set getGroupings() { + return Collections.emptySet(); + } + + @Override + public Set getGroupingBuilders() { + return addedGroupings; } @Override public void addGrouping(final GroupingBuilder grouping) { - groupings.add(grouping); + addedGroupings.add(grouping); + } + + public void setGroupings(final Set groupings) { + this.groupings = groupings; + } + + @Override + public Set getUses() { + return addedUsesNodes; } @Override public void addUsesNode(final UsesNodeBuilder usesBuilder) { - usesNodes.add(usesBuilder); + addedUsesNodes.add(usesBuilder); + } + + public void setUsesnodes(final Set usesNodes) { + this.usesNodes = usesNodes; + } + + @Override + public List getUnknownNodes() { + return addedUnknownNodes; } @Override @@ -165,12 +289,18 @@ public class GroupingBuilderImpl implements GroupingBuilder { addedUnknownNodes.add(unknownNode); } - private static class GroupingDefinitionImpl implements GroupingDefinition { + public void setUnknownNodes(List unknownNodes) { + this.unknownNodes = unknownNodes; + } + + + private final class GroupingDefinitionImpl implements GroupingDefinition { private final QName qname; private SchemaPath path; 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(); @@ -222,6 +352,15 @@ public 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()); @@ -264,7 +403,7 @@ public class GroupingBuilderImpl implements GroupingBuilder { } private void setUnknownSchemaNodes(List unknownNodes) { - if(unknownNodes != null) { + if (unknownNodes != null) { this.unknownNodes = unknownNodes; } }