2 * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.yangtools.yang.parser.builder.impl;
10 import java.util.Collections;
11 import java.util.HashSet;
12 import java.util.List;
15 import java.util.TreeSet;
17 import org.opendaylight.yangtools.yang.common.QName;
18 import org.opendaylight.yangtools.yang.model.api.DataSchemaNode;
19 import org.opendaylight.yangtools.yang.model.api.GroupingDefinition;
20 import org.opendaylight.yangtools.yang.model.api.SchemaPath;
21 import org.opendaylight.yangtools.yang.model.api.Status;
22 import org.opendaylight.yangtools.yang.model.api.TypeDefinition;
23 import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode;
24 import org.opendaylight.yangtools.yang.model.api.UsesNode;
25 import org.opendaylight.yangtools.yang.model.api.YangNode;
26 import org.opendaylight.yangtools.yang.parser.builder.api.AbstractDataNodeContainerBuilder;
27 import org.opendaylight.yangtools.yang.parser.builder.api.Builder;
28 import org.opendaylight.yangtools.yang.parser.builder.api.DataSchemaNodeBuilder;
29 import org.opendaylight.yangtools.yang.parser.builder.api.GroupingBuilder;
30 import org.opendaylight.yangtools.yang.parser.builder.api.TypeDefinitionBuilder;
31 import org.opendaylight.yangtools.yang.parser.builder.api.UsesNodeBuilder;
32 import org.opendaylight.yangtools.yang.parser.util.Comparators;
33 import org.opendaylight.yangtools.yang.parser.util.CopyUtils;
34 import org.opendaylight.yangtools.yang.parser.util.ParserUtils;
35 import org.opendaylight.yangtools.yang.parser.util.YangParseException;
37 public final class GroupingBuilderImpl extends AbstractDataNodeContainerBuilder implements GroupingBuilder {
38 private boolean isBuilt;
39 private final GroupingDefinitionImpl instance;
40 private SchemaPath schemaPath;
41 private String description;
42 private String reference;
43 private Status status = Status.CURRENT;
44 private boolean addedByUses;
46 public GroupingBuilderImpl(final String moduleName, final int line, final QName qname) {
47 super(moduleName, line, qname);
48 instance = new GroupingDefinitionImpl(qname);
52 public GroupingDefinition build(YangNode parent) {
54 instance.setParent(parent);
55 instance.setPath(schemaPath);
56 instance.setDescription(description);
57 instance.setReference(reference);
58 instance.setStatus(status);
59 instance.setAddedByUses(addedByUses);
62 for (DataSchemaNodeBuilder node : addedChildNodes) {
63 DataSchemaNode child = node.build(instance);
64 childNodes.put(child.getQName(), child);
66 instance.setChildNodes(childNodes);
69 for (GroupingBuilder builder : addedGroupings) {
70 groupings.add(builder.build(instance));
72 instance.setGroupings(groupings);
75 for (TypeDefinitionBuilder entry : addedTypedefs) {
76 typedefs.add(entry.build(instance));
78 instance.setTypeDefinitions(typedefs);
81 for (UsesNodeBuilder builder : addedUsesNodes) {
82 usesNodes.add(builder.build(instance));
84 instance.setUses(usesNodes);
87 for (UnknownSchemaNodeBuilder b : addedUnknownNodes) {
88 unknownNodes.add(b.build(instance));
90 Collections.sort(unknownNodes, Comparators.SCHEMA_NODE_COMP);
91 instance.setUnknownSchemaNodes(unknownNodes);
100 public Set<DataSchemaNodeBuilder> instantiateChildNodes(Builder newParent) {
101 final Set<DataSchemaNodeBuilder> nodes = new HashSet<>();
102 for (DataSchemaNodeBuilder node : addedChildNodes) {
103 DataSchemaNodeBuilder copy = CopyUtils.copy(node, newParent, true);
104 ParserUtils.setNodeAddedByUses(copy);
111 public Set<TypeDefinitionBuilder> instantiateTypedefs(Builder newParent) {
112 final Set<TypeDefinitionBuilder> nodes = new HashSet<>();
113 for (TypeDefinitionBuilder node : addedTypedefs) {
114 TypeDefinitionBuilder copy = CopyUtils.copy(node, newParent, true);
121 public Set<GroupingBuilder> instantiateGroupings(Builder newParent) {
122 final Set<GroupingBuilder> nodes = new HashSet<>();
123 for (GroupingBuilder node : addedGroupings) {
124 GroupingBuilder copy = CopyUtils.copy(node, newParent, true);
125 copy.setAddedByUses(true);
126 for (DataSchemaNodeBuilder childNode : copy.getChildNodeBuilders()) {
127 ParserUtils.setNodeAddedByUses(childNode);
135 public Set<UnknownSchemaNodeBuilder> instantiateUnknownNodes(Builder newParent) {
136 final Set<UnknownSchemaNodeBuilder> nodes = new HashSet<>();
137 for (UnknownSchemaNodeBuilder node : addedUnknownNodes) {
138 UnknownSchemaNodeBuilder copy = CopyUtils.copy(node, newParent, true);
139 copy.setAddedByUses(true);
146 public void setQName(QName qname) {
151 public Set<TypeDefinitionBuilder> getTypeDefinitionBuilders() {
152 return addedTypedefs;
156 public void addTypedef(final TypeDefinitionBuilder type) {
157 String typeName = type.getQName().getLocalName();
158 for (TypeDefinitionBuilder addedTypedef : addedTypedefs) {
159 throw new YangParseException(moduleName, type.getLine(), "Can not add typedef '" + typeName
160 + "': typedef with same name already declared at line " + addedTypedef.getLine());
162 addedTypedefs.add(type);
165 public void setTypedefs(final Set<TypeDefinition<?>> typedefs) {
166 this.typedefs = typedefs;
170 public SchemaPath getPath() {
175 public void setPath(SchemaPath schemaPath) {
176 this.schemaPath = schemaPath;
180 public String getDescription() {
185 public void setDescription(final String description) {
186 this.description = description;
190 public String getReference() {
195 public void setReference(final String reference) {
196 this.reference = reference;
200 public Status getStatus() {
205 public void setStatus(final Status status) {
206 this.status = status;
210 public boolean isAddedByUses() {
215 public void setAddedByUses(final boolean addedByUses) {
216 this.addedByUses = addedByUses;
220 public String toString() {
221 return "grouping " + qname.getLocalName();
225 public int hashCode() {
226 final int prime = 31;
228 result = prime * result + ((parentBuilder == null) ? 0 : parentBuilder.hashCode());
229 result = prime * result + ((schemaPath == null) ? 0 : schemaPath.hashCode());
234 public boolean equals(Object obj) {
241 if (getClass() != obj.getClass()) {
244 if (!super.equals(obj)) {
247 final GroupingBuilderImpl other = (GroupingBuilderImpl) obj;
248 if (parentBuilder == null) {
249 if (other.parentBuilder != null) {
252 } else if (!parentBuilder.equals(other.parentBuilder)) {
255 if (schemaPath == null) {
256 if (other.schemaPath != null) {
259 } else if (!schemaPath.equals(other.schemaPath)) {
266 private final class GroupingDefinitionImpl implements GroupingDefinition {
267 private final QName qname;
268 private SchemaPath path;
269 private YangNode parent;
270 private String description;
271 private String reference;
272 private Status status;
273 private boolean addedByUses;
274 private Map<QName, DataSchemaNode> childNodes = Collections.emptyMap();
275 private Set<GroupingDefinition> groupings = Collections.emptySet();
276 private Set<TypeDefinition<?>> typeDefinitions = Collections.emptySet();
277 private Set<UsesNode> uses = Collections.emptySet();
278 private List<UnknownSchemaNode> unknownNodes = Collections.emptyList();
280 private GroupingDefinitionImpl(final QName qname) {
285 public QName getQName() {
290 public SchemaPath getPath() {
294 private void setPath(SchemaPath path) {
299 public YangNode getParent() {
303 private void setParent(YangNode parent) {
304 this.parent = parent;
308 public String getDescription() {
312 private void setDescription(String description) {
313 this.description = description;
317 public String getReference() {
321 private void setReference(String reference) {
322 this.reference = reference;
326 public Status getStatus() {
330 private void setStatus(Status status) {
331 this.status = status;
335 public boolean isAddedByUses() {
339 private void setAddedByUses(final boolean addedByUses) {
340 this.addedByUses = addedByUses;
344 public Set<DataSchemaNode> getChildNodes() {
345 final Set<DataSchemaNode> result = new TreeSet<DataSchemaNode>(Comparators.SCHEMA_NODE_COMP);
346 result.addAll(childNodes.values());
350 private void setChildNodes(Map<QName, DataSchemaNode> childNodes) {
351 this.childNodes = childNodes;
355 public Set<GroupingDefinition> getGroupings() {
359 private void setGroupings(Set<GroupingDefinition> groupings) {
360 this.groupings = groupings;
364 public Set<UsesNode> getUses() {
368 private void setUses(Set<UsesNode> uses) {
373 public Set<TypeDefinition<?>> getTypeDefinitions() {
374 return typeDefinitions;
377 private void setTypeDefinitions(Set<TypeDefinition<?>> typeDefinitions) {
378 this.typeDefinitions = typeDefinitions;
382 public List<UnknownSchemaNode> getUnknownSchemaNodes() {
386 private void setUnknownSchemaNodes(List<UnknownSchemaNode> unknownNodes) {
387 if (unknownNodes != null) {
388 this.unknownNodes = unknownNodes;
393 public DataSchemaNode getDataChildByName(QName name) {
394 return childNodes.get(name);
398 public DataSchemaNode getDataChildByName(String name) {
399 DataSchemaNode result = null;
400 for (Map.Entry<QName, DataSchemaNode> entry : childNodes.entrySet()) {
401 if (entry.getKey().getLocalName().equals(name)) {
402 result = entry.getValue();
410 public int hashCode() {
411 final int prime = 31;
413 result = prime * result + ((qname == null) ? 0 : qname.hashCode());
414 result = prime * result + ((path == null) ? 0 : path.hashCode());
419 public boolean equals(Object obj) {
426 if (getClass() != obj.getClass()) {
429 final GroupingDefinitionImpl other = (GroupingDefinitionImpl) obj;
431 if (other.qname != null) {
434 } else if (!qname.equals(other.qname)) {
438 if (other.path != null) {
441 } else if (!path.equals(other.path)) {
448 public String toString() {
449 StringBuilder sb = new StringBuilder(GroupingDefinitionImpl.class.getSimpleName());
451 sb.append("qname=" + qname);
453 return sb.toString();