*/
package org.opendaylight.yangtools.yang.parser.builder.impl;
-import java.util.ArrayList;
import java.util.Collections;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
-import java.util.TreeMap;
import java.util.TreeSet;
import org.opendaylight.yangtools.yang.common.QName;
import org.opendaylight.yangtools.yang.model.api.TypeDefinition;
import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode;
import org.opendaylight.yangtools.yang.model.api.UsesNode;
+import org.opendaylight.yangtools.yang.model.api.YangNode;
import org.opendaylight.yangtools.yang.parser.builder.api.AbstractDataNodeContainerBuilder;
+import org.opendaylight.yangtools.yang.parser.builder.api.Builder;
import org.opendaylight.yangtools.yang.parser.builder.api.DataSchemaNodeBuilder;
import org.opendaylight.yangtools.yang.parser.builder.api.GroupingBuilder;
import org.opendaylight.yangtools.yang.parser.builder.api.TypeDefinitionBuilder;
import org.opendaylight.yangtools.yang.parser.builder.api.UsesNodeBuilder;
import org.opendaylight.yangtools.yang.parser.util.Comparators;
+import org.opendaylight.yangtools.yang.parser.util.CopyUtils;
+import org.opendaylight.yangtools.yang.parser.util.ParserUtils;
import org.opendaylight.yangtools.yang.parser.util.YangParseException;
public final class GroupingBuilderImpl extends AbstractDataNodeContainerBuilder implements GroupingBuilder {
private Status status = Status.CURRENT;
private boolean addedByUses;
- private Set<TypeDefinition<?>> typedefs;
- private final Set<TypeDefinitionBuilder> addedTypedefs = new HashSet<TypeDefinitionBuilder>();
-
- private Set<UsesNode> usesNodes;
- private final Set<UsesNodeBuilder> addedUsesNodes = new HashSet<UsesNodeBuilder>();
-
public GroupingBuilderImpl(final String moduleName, final int line, final QName qname) {
super(moduleName, line, qname);
instance = new GroupingDefinitionImpl(qname);
}
@Override
- public GroupingDefinition build() {
+ public GroupingDefinition build(YangNode parent) {
if (!isBuilt) {
+ instance.setParent(parent);
instance.setPath(schemaPath);
instance.setDescription(description);
instance.setReference(reference);
instance.setAddedByUses(addedByUses);
// CHILD NODES
- final Map<QName, DataSchemaNode> childs = new TreeMap<QName, DataSchemaNode>(Comparators.QNAME_COMP);
- if (childNodes == null || childNodes.isEmpty()) {
- for (DataSchemaNodeBuilder node : addedChildNodes) {
- childs.put(node.getQName(), node.build());
- }
- } else {
- for (DataSchemaNode node : childNodes) {
- childs.put(node.getQName(), node);
- }
+ for (DataSchemaNodeBuilder node : addedChildNodes) {
+ DataSchemaNode child = node.build(instance);
+ childNodes.put(child.getQName(), child);
}
- instance.setChildNodes(childs);
+ instance.setChildNodes(childNodes);
// GROUPINGS
- if (groupings == null) {
- groupings = new TreeSet<GroupingDefinition>(Comparators.SCHEMA_NODE_COMP);
- for (GroupingBuilder builder : addedGroupings) {
- groupings.add(builder.build());
- }
+ for (GroupingBuilder builder : addedGroupings) {
+ groupings.add(builder.build(instance));
}
instance.setGroupings(groupings);
// TYPEDEFS
- if (typedefs == null) {
- typedefs = new TreeSet<TypeDefinition<?>>(Comparators.SCHEMA_NODE_COMP);
- for (TypeDefinitionBuilder entry : addedTypedefs) {
- typedefs.add(entry.build());
- }
+ for (TypeDefinitionBuilder entry : addedTypedefs) {
+ typedefs.add(entry.build(instance));
}
instance.setTypeDefinitions(typedefs);
// USES
- if (usesNodes == null) {
- usesNodes = new HashSet<UsesNode>();
- for (UsesNodeBuilder builder : addedUsesNodes) {
- usesNodes.add(builder.build());
- }
+ for (UsesNodeBuilder builder : addedUsesNodes) {
+ usesNodes.add(builder.build(instance));
}
instance.setUses(usesNodes);
// UNKNOWN NODES
- if (unknownNodes == null) {
- unknownNodes = new ArrayList<UnknownSchemaNode>();
- for (UnknownSchemaNodeBuilder b : addedUnknownNodes) {
- unknownNodes.add(b.build());
- }
- Collections.sort(unknownNodes, Comparators.SCHEMA_NODE_COMP);
+ for (UnknownSchemaNodeBuilder b : addedUnknownNodes) {
+ unknownNodes.add(b.build(instance));
}
+ Collections.sort(unknownNodes, Comparators.SCHEMA_NODE_COMP);
instance.setUnknownSchemaNodes(unknownNodes);
isBuilt = true;
return instance;
}
+ @Override
+ public Set<DataSchemaNodeBuilder> instantiateChildNodes(Builder newParent) {
+ final Set<DataSchemaNodeBuilder> nodes = new HashSet<>();
+ for (DataSchemaNodeBuilder node : addedChildNodes) {
+ DataSchemaNodeBuilder copy = CopyUtils.copy(node, newParent, true);
+ ParserUtils.setNodeAddedByUses(copy);
+ nodes.add(copy);
+ }
+ return nodes;
+ }
+
+ @Override
+ public Set<TypeDefinitionBuilder> instantiateTypedefs(Builder newParent) {
+ final Set<TypeDefinitionBuilder> nodes = new HashSet<>();
+ for (TypeDefinitionBuilder node : addedTypedefs) {
+ TypeDefinitionBuilder copy = CopyUtils.copy(node, newParent, true);
+ nodes.add(copy);
+ }
+ return nodes;
+ }
+
+ @Override
+ public Set<GroupingBuilder> instantiateGroupings(Builder newParent) {
+ final Set<GroupingBuilder> nodes = new HashSet<>();
+ for (GroupingBuilder node : addedGroupings) {
+ GroupingBuilder copy = CopyUtils.copy(node, newParent, true);
+ copy.setAddedByUses(true);
+ for (DataSchemaNodeBuilder childNode : copy.getChildNodeBuilders()) {
+ ParserUtils.setNodeAddedByUses(childNode);
+ }
+ nodes.add(copy);
+ }
+ return nodes;
+ }
+
+ @Override
+ public Set<UnknownSchemaNodeBuilder> instantiateUnknownNodes(Builder newParent) {
+ final Set<UnknownSchemaNodeBuilder> nodes = new HashSet<>();
+ for (UnknownSchemaNodeBuilder node : addedUnknownNodes) {
+ UnknownSchemaNodeBuilder copy = CopyUtils.copy(node, newParent, true);
+ copy.setAddedByUses(true);
+ nodes.add(copy);
+ }
+ return nodes;
+ }
@Override
public void setQName(QName qname) {
this.addedByUses = addedByUses;
}
- @Override
- public Set<UsesNodeBuilder> getUsesNodes() {
- return addedUsesNodes;
- }
-
- @Override
- public void addUsesNode(final UsesNodeBuilder usesBuilder) {
- addedUsesNodes.add(usesBuilder);
- }
-
- public void setUsesnodes(final Set<UsesNode> usesNodes) {
- this.usesNodes = usesNodes;
- }
-
@Override
public String toString() {
return "grouping " + qname.getLocalName();
public int hashCode() {
final int prime = 31;
int result = 1;
- result = prime * result + ((parent == null) ? 0 : parent.hashCode());
+ result = prime * result + ((parentBuilder == null) ? 0 : parentBuilder.hashCode());
result = prime * result + ((schemaPath == null) ? 0 : schemaPath.hashCode());
return result;
}
return false;
}
final GroupingBuilderImpl other = (GroupingBuilderImpl) obj;
- if (parent == null) {
- if (other.parent != null) {
+ if (parentBuilder == null) {
+ if (other.parentBuilder != null) {
return false;
}
- } else if (!parent.equals(other.parent)) {
+ } else if (!parentBuilder.equals(other.parentBuilder)) {
return false;
}
if (schemaPath == null) {
private final class GroupingDefinitionImpl implements GroupingDefinition {
private final QName qname;
private SchemaPath path;
+ private YangNode parent;
private String description;
private String reference;
private Status status;
this.path = path;
}
+ @Override
+ public YangNode getParent() {
+ return parent;
+ }
+
+ private void setParent(YangNode parent) {
+ this.parent = parent;
+ }
+
@Override
public String getDescription() {
return description;