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.ArrayList;
11 import java.util.Collections;
12 import java.util.HashSet;
13 import java.util.List;
16 import java.util.TreeMap;
17 import java.util.TreeSet;
19 import org.opendaylight.yangtools.yang.common.QName;
20 import org.opendaylight.yangtools.yang.model.api.DataSchemaNode;
21 import org.opendaylight.yangtools.yang.model.api.GroupingDefinition;
22 import org.opendaylight.yangtools.yang.model.api.SchemaPath;
23 import org.opendaylight.yangtools.yang.model.api.Status;
24 import org.opendaylight.yangtools.yang.model.api.TypeDefinition;
25 import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode;
26 import org.opendaylight.yangtools.yang.model.api.UsesNode;
27 import org.opendaylight.yangtools.yang.parser.builder.api.AbstractDataNodeContainerBuilder;
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.YangParseException;
35 public final class GroupingBuilderImpl extends AbstractDataNodeContainerBuilder implements GroupingBuilder {
36 private boolean isBuilt;
37 private final GroupingDefinitionImpl instance;
38 private SchemaPath schemaPath;
39 private String description;
40 private String reference;
41 private Status status = Status.CURRENT;
42 private boolean addedByUses;
44 private Set<TypeDefinition<?>> typedefs;
45 private final Set<TypeDefinitionBuilder> addedTypedefs = new HashSet<TypeDefinitionBuilder>();
47 private Set<UsesNode> usesNodes;
48 private final Set<UsesNodeBuilder> addedUsesNodes = new HashSet<UsesNodeBuilder>();
50 public GroupingBuilderImpl(final String moduleName, final int line, final QName qname) {
51 super(moduleName, line, qname);
52 instance = new GroupingDefinitionImpl(qname);
56 public GroupingDefinition build() {
58 instance.setPath(schemaPath);
59 instance.setDescription(description);
60 instance.setReference(reference);
61 instance.setStatus(status);
62 instance.setAddedByUses(addedByUses);
65 final Map<QName, DataSchemaNode> childs = new TreeMap<QName, DataSchemaNode>(Comparators.QNAME_COMP);
66 if (childNodes == null || childNodes.isEmpty()) {
67 for (DataSchemaNodeBuilder node : addedChildNodes) {
68 childs.put(node.getQName(), node.build());
71 for (DataSchemaNode node : childNodes) {
72 childs.put(node.getQName(), node);
75 instance.setChildNodes(childs);
78 if (groupings == null) {
79 groupings = new TreeSet<GroupingDefinition>(Comparators.SCHEMA_NODE_COMP);
80 for (GroupingBuilder builder : addedGroupings) {
81 groupings.add(builder.build());
84 instance.setGroupings(groupings);
87 if (typedefs == null) {
88 typedefs = new TreeSet<TypeDefinition<?>>(Comparators.SCHEMA_NODE_COMP);
89 for (TypeDefinitionBuilder entry : addedTypedefs) {
90 typedefs.add(entry.build());
93 instance.setTypeDefinitions(typedefs);
96 if (usesNodes == null) {
97 usesNodes = new HashSet<UsesNode>();
98 for (UsesNodeBuilder builder : addedUsesNodes) {
99 usesNodes.add(builder.build());
102 instance.setUses(usesNodes);
105 if (unknownNodes == null) {
106 unknownNodes = new ArrayList<UnknownSchemaNode>();
107 for (UnknownSchemaNodeBuilder b : addedUnknownNodes) {
108 unknownNodes.add(b.build());
110 Collections.sort(unknownNodes, Comparators.SCHEMA_NODE_COMP);
112 instance.setUnknownSchemaNodes(unknownNodes);
122 public void setQName(QName qname) {
127 public Set<TypeDefinitionBuilder> getTypeDefinitionBuilders() {
128 return addedTypedefs;
132 public void addTypedef(final TypeDefinitionBuilder type) {
133 String typeName = type.getQName().getLocalName();
134 for (TypeDefinitionBuilder addedTypedef : addedTypedefs) {
135 throw new YangParseException(moduleName, type.getLine(), "Can not add typedef '" + typeName
136 + "': typedef with same name already declared at line " + addedTypedef.getLine());
138 addedTypedefs.add(type);
141 public void setTypedefs(final Set<TypeDefinition<?>> typedefs) {
142 this.typedefs = typedefs;
146 public SchemaPath getPath() {
151 public void setPath(SchemaPath schemaPath) {
152 this.schemaPath = schemaPath;
156 public String getDescription() {
161 public void setDescription(final String description) {
162 this.description = description;
166 public String getReference() {
171 public void setReference(final String reference) {
172 this.reference = reference;
176 public Status getStatus() {
181 public void setStatus(final Status status) {
182 this.status = status;
186 public boolean isAddedByUses() {
191 public void setAddedByUses(final boolean addedByUses) {
192 this.addedByUses = addedByUses;
196 public Set<UsesNodeBuilder> getUsesNodes() {
197 return addedUsesNodes;
201 public void addUsesNode(final UsesNodeBuilder usesBuilder) {
202 addedUsesNodes.add(usesBuilder);
205 public void setUsesnodes(final Set<UsesNode> usesNodes) {
206 this.usesNodes = usesNodes;
210 public String toString() {
211 return "grouping " + qname.getLocalName();
215 public int hashCode() {
216 final int prime = 31;
218 result = prime * result + ((parent == null) ? 0 : parent.hashCode());
219 result = prime * result + ((schemaPath == null) ? 0 : schemaPath.hashCode());
224 public boolean equals(Object obj) {
231 if (getClass() != obj.getClass()) {
234 if (!super.equals(obj)) {
237 final GroupingBuilderImpl other = (GroupingBuilderImpl) obj;
238 if (parent == null) {
239 if (other.parent != null) {
242 } else if (!parent.equals(other.parent)) {
245 if (schemaPath == null) {
246 if (other.schemaPath != null) {
249 } else if (!schemaPath.equals(other.schemaPath)) {
256 private final class GroupingDefinitionImpl implements GroupingDefinition {
257 private final QName qname;
258 private SchemaPath path;
259 private String description;
260 private String reference;
261 private Status status;
262 private boolean addedByUses;
263 private Map<QName, DataSchemaNode> childNodes = Collections.emptyMap();
264 private Set<GroupingDefinition> groupings = Collections.emptySet();
265 private Set<TypeDefinition<?>> typeDefinitions = Collections.emptySet();
266 private Set<UsesNode> uses = Collections.emptySet();
267 private List<UnknownSchemaNode> unknownNodes = Collections.emptyList();
269 private GroupingDefinitionImpl(final QName qname) {
274 public QName getQName() {
279 public SchemaPath getPath() {
283 private void setPath(SchemaPath path) {
288 public String getDescription() {
292 private void setDescription(String description) {
293 this.description = description;
297 public String getReference() {
301 private void setReference(String reference) {
302 this.reference = reference;
306 public Status getStatus() {
310 private void setStatus(Status status) {
311 this.status = status;
315 public boolean isAddedByUses() {
319 private void setAddedByUses(final boolean addedByUses) {
320 this.addedByUses = addedByUses;
324 public Set<DataSchemaNode> getChildNodes() {
325 final Set<DataSchemaNode> result = new TreeSet<DataSchemaNode>(Comparators.SCHEMA_NODE_COMP);
326 result.addAll(childNodes.values());
330 private void setChildNodes(Map<QName, DataSchemaNode> childNodes) {
331 this.childNodes = childNodes;
335 public Set<GroupingDefinition> getGroupings() {
339 private void setGroupings(Set<GroupingDefinition> groupings) {
340 this.groupings = groupings;
344 public Set<UsesNode> getUses() {
348 private void setUses(Set<UsesNode> uses) {
353 public Set<TypeDefinition<?>> getTypeDefinitions() {
354 return typeDefinitions;
357 private void setTypeDefinitions(Set<TypeDefinition<?>> typeDefinitions) {
358 this.typeDefinitions = typeDefinitions;
362 public List<UnknownSchemaNode> getUnknownSchemaNodes() {
366 private void setUnknownSchemaNodes(List<UnknownSchemaNode> unknownNodes) {
367 if (unknownNodes != null) {
368 this.unknownNodes = unknownNodes;
373 public DataSchemaNode getDataChildByName(QName name) {
374 return childNodes.get(name);
378 public DataSchemaNode getDataChildByName(String name) {
379 DataSchemaNode result = null;
380 for (Map.Entry<QName, DataSchemaNode> entry : childNodes.entrySet()) {
381 if (entry.getKey().getLocalName().equals(name)) {
382 result = entry.getValue();
390 public int hashCode() {
391 final int prime = 31;
393 result = prime * result + ((qname == null) ? 0 : qname.hashCode());
394 result = prime * result + ((path == null) ? 0 : path.hashCode());
399 public boolean equals(Object obj) {
406 if (getClass() != obj.getClass()) {
409 final GroupingDefinitionImpl other = (GroupingDefinitionImpl) obj;
411 if (other.qname != null) {
414 } else if (!qname.equals(other.qname)) {
418 if (other.path != null) {
421 } else if (!path.equals(other.path)) {
428 public String toString() {
429 StringBuilder sb = new StringBuilder(GroupingDefinitionImpl.class.getSimpleName());
431 sb.append("qname=" + qname);
433 return sb.toString();