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.List;
14 import java.util.TreeSet;
16 import org.opendaylight.yangtools.yang.common.QName;
17 import org.opendaylight.yangtools.yang.model.api.DataSchemaNode;
18 import org.opendaylight.yangtools.yang.model.api.GroupingDefinition;
19 import org.opendaylight.yangtools.yang.model.api.SchemaPath;
20 import org.opendaylight.yangtools.yang.model.api.Status;
21 import org.opendaylight.yangtools.yang.model.api.TypeDefinition;
22 import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode;
23 import org.opendaylight.yangtools.yang.model.api.UsesNode;
24 import org.opendaylight.yangtools.yang.model.api.YangNode;
25 import org.opendaylight.yangtools.yang.parser.builder.api.AbstractDataNodeContainerBuilder;
26 import org.opendaylight.yangtools.yang.parser.builder.api.DataSchemaNodeBuilder;
27 import org.opendaylight.yangtools.yang.parser.builder.api.GroupingBuilder;
28 import org.opendaylight.yangtools.yang.parser.builder.api.TypeDefinitionBuilder;
29 import org.opendaylight.yangtools.yang.parser.builder.api.UsesNodeBuilder;
30 import org.opendaylight.yangtools.yang.parser.util.Comparators;
31 import org.opendaylight.yangtools.yang.parser.util.YangParseException;
33 public final class GroupingBuilderImpl extends AbstractDataNodeContainerBuilder implements GroupingBuilder {
34 private boolean isBuilt;
35 private final GroupingDefinitionImpl instance;
36 private SchemaPath schemaPath;
37 private String description;
38 private String reference;
39 private Status status = Status.CURRENT;
40 private boolean addedByUses;
42 public GroupingBuilderImpl(final String moduleName, final int line, final QName qname) {
43 super(moduleName, line, qname);
44 instance = new GroupingDefinitionImpl(qname);
48 public GroupingDefinition build(YangNode parent) {
50 instance.setParent(parent);
51 instance.setPath(schemaPath);
52 instance.setDescription(description);
53 instance.setReference(reference);
54 instance.setStatus(status);
55 instance.setAddedByUses(addedByUses);
58 for (DataSchemaNodeBuilder node : addedChildNodes) {
59 DataSchemaNode child = node.build(instance);
60 childNodes.put(child.getQName(), child);
62 instance.setChildNodes(childNodes);
65 for (GroupingBuilder builder : addedGroupings) {
66 groupings.add(builder.build(instance));
68 instance.setGroupings(groupings);
71 for (TypeDefinitionBuilder entry : addedTypedefs) {
72 typedefs.add(entry.build(instance));
74 instance.setTypeDefinitions(typedefs);
77 for (UsesNodeBuilder builder : addedUsesNodes) {
78 usesNodes.add(builder.build(instance));
80 instance.setUses(usesNodes);
83 for (UnknownSchemaNodeBuilder b : addedUnknownNodes) {
84 unknownNodes.add(b.build(instance));
86 Collections.sort(unknownNodes, Comparators.SCHEMA_NODE_COMP);
87 instance.setUnknownSchemaNodes(unknownNodes);
97 public void setQName(QName qname) {
102 public Set<TypeDefinitionBuilder> getTypeDefinitionBuilders() {
103 return addedTypedefs;
107 public void addTypedef(final TypeDefinitionBuilder type) {
108 String typeName = type.getQName().getLocalName();
109 for (TypeDefinitionBuilder addedTypedef : addedTypedefs) {
110 throw new YangParseException(moduleName, type.getLine(), "Can not add typedef '" + typeName
111 + "': typedef with same name already declared at line " + addedTypedef.getLine());
113 addedTypedefs.add(type);
116 public void setTypedefs(final Set<TypeDefinition<?>> typedefs) {
117 this.typedefs = typedefs;
121 public SchemaPath getPath() {
126 public void setPath(SchemaPath schemaPath) {
127 this.schemaPath = schemaPath;
131 public String getDescription() {
136 public void setDescription(final String description) {
137 this.description = description;
141 public String getReference() {
146 public void setReference(final String reference) {
147 this.reference = reference;
151 public Status getStatus() {
156 public void setStatus(final Status status) {
157 this.status = status;
161 public boolean isAddedByUses() {
166 public void setAddedByUses(final boolean addedByUses) {
167 this.addedByUses = addedByUses;
171 public String toString() {
172 return "grouping " + qname.getLocalName();
176 public int hashCode() {
177 final int prime = 31;
179 result = prime * result + ((parentBuilder == null) ? 0 : parentBuilder.hashCode());
180 result = prime * result + ((schemaPath == null) ? 0 : schemaPath.hashCode());
185 public boolean equals(Object obj) {
192 if (getClass() != obj.getClass()) {
195 if (!super.equals(obj)) {
198 final GroupingBuilderImpl other = (GroupingBuilderImpl) obj;
199 if (parentBuilder == null) {
200 if (other.parentBuilder != null) {
203 } else if (!parentBuilder.equals(other.parentBuilder)) {
206 if (schemaPath == null) {
207 if (other.schemaPath != null) {
210 } else if (!schemaPath.equals(other.schemaPath)) {
217 private final class GroupingDefinitionImpl implements GroupingDefinition {
218 private final QName qname;
219 private SchemaPath path;
220 private YangNode parent;
221 private String description;
222 private String reference;
223 private Status status;
224 private boolean addedByUses;
225 private Map<QName, DataSchemaNode> childNodes = Collections.emptyMap();
226 private Set<GroupingDefinition> groupings = Collections.emptySet();
227 private Set<TypeDefinition<?>> typeDefinitions = Collections.emptySet();
228 private Set<UsesNode> uses = Collections.emptySet();
229 private List<UnknownSchemaNode> unknownNodes = Collections.emptyList();
231 private GroupingDefinitionImpl(final QName qname) {
236 public QName getQName() {
241 public SchemaPath getPath() {
245 private void setPath(SchemaPath path) {
250 public YangNode getParent() {
254 private void setParent(YangNode parent) {
255 this.parent = parent;
259 public String getDescription() {
263 private void setDescription(String description) {
264 this.description = description;
268 public String getReference() {
272 private void setReference(String reference) {
273 this.reference = reference;
277 public Status getStatus() {
281 private void setStatus(Status status) {
282 this.status = status;
286 public boolean isAddedByUses() {
290 private void setAddedByUses(final boolean addedByUses) {
291 this.addedByUses = addedByUses;
295 public Set<DataSchemaNode> getChildNodes() {
296 final Set<DataSchemaNode> result = new TreeSet<DataSchemaNode>(Comparators.SCHEMA_NODE_COMP);
297 result.addAll(childNodes.values());
301 private void setChildNodes(Map<QName, DataSchemaNode> childNodes) {
302 this.childNodes = childNodes;
306 public Set<GroupingDefinition> getGroupings() {
310 private void setGroupings(Set<GroupingDefinition> groupings) {
311 this.groupings = groupings;
315 public Set<UsesNode> getUses() {
319 private void setUses(Set<UsesNode> uses) {
324 public Set<TypeDefinition<?>> getTypeDefinitions() {
325 return typeDefinitions;
328 private void setTypeDefinitions(Set<TypeDefinition<?>> typeDefinitions) {
329 this.typeDefinitions = typeDefinitions;
333 public List<UnknownSchemaNode> getUnknownSchemaNodes() {
337 private void setUnknownSchemaNodes(List<UnknownSchemaNode> unknownNodes) {
338 if (unknownNodes != null) {
339 this.unknownNodes = unknownNodes;
344 public DataSchemaNode getDataChildByName(QName name) {
345 return childNodes.get(name);
349 public DataSchemaNode getDataChildByName(String name) {
350 DataSchemaNode result = null;
351 for (Map.Entry<QName, DataSchemaNode> entry : childNodes.entrySet()) {
352 if (entry.getKey().getLocalName().equals(name)) {
353 result = entry.getValue();
361 public int hashCode() {
362 final int prime = 31;
364 result = prime * result + ((qname == null) ? 0 : qname.hashCode());
365 result = prime * result + ((path == null) ? 0 : path.hashCode());
370 public boolean equals(Object obj) {
377 if (getClass() != obj.getClass()) {
380 final GroupingDefinitionImpl other = (GroupingDefinitionImpl) obj;
382 if (other.qname != null) {
385 } else if (!qname.equals(other.qname)) {
389 if (other.path != null) {
392 } else if (!path.equals(other.path)) {
399 public String toString() {
400 StringBuilder sb = new StringBuilder(GroupingDefinitionImpl.class.getSimpleName());
402 sb.append("qname=" + qname);
404 return sb.toString();