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;
11 import java.util.ArrayList;
12 import java.util.Collections;
13 import java.util.Date;
14 import java.util.HashMap;
15 import java.util.HashSet;
16 import java.util.List;
19 import java.util.TreeSet;
21 import org.opendaylight.yangtools.yang.common.QName;
22 import org.opendaylight.yangtools.yang.model.api.*;
23 import org.opendaylight.yangtools.yang.parser.builder.api.AbstractDataNodeContainerBuilder;
24 import org.opendaylight.yangtools.yang.parser.builder.api.AugmentationSchemaBuilder;
25 import org.opendaylight.yangtools.yang.parser.builder.api.AugmentationTargetBuilder;
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.ParserUtils;
32 import org.opendaylight.yangtools.yang.parser.util.YangParseException;
34 public final class ListSchemaNodeBuilder extends AbstractDataNodeContainerBuilder implements DataSchemaNodeBuilder,
35 AugmentationTargetBuilder {
36 private boolean isBuilt;
37 private final ListSchemaNodeImpl instance;
39 private SchemaPath schemaPath;
40 // DataSchemaNode args
41 private final ConstraintsBuilder constraints;
42 // AugmentationTarget args
43 private final List<AugmentationSchema> augmentations = new ArrayList<>();
44 private final List<AugmentationSchemaBuilder> augmentationBuilders = new ArrayList<>();
47 public ListSchemaNodeBuilder(final String moduleName, final int line, final QName qname, final SchemaPath path) {
48 super(moduleName, line, qname);
49 this.schemaPath = path;
50 instance = new ListSchemaNodeImpl(qname, path);
51 constraints = new ConstraintsBuilder(moduleName, line);
54 public ListSchemaNodeBuilder(final String moduleName, final int line, final QName qname, final SchemaPath path, final ListSchemaNode base) {
55 super(moduleName, line, qname);
57 instance = new ListSchemaNodeImpl(qname, path);
58 constraints = new ConstraintsBuilder(moduleName, line, base.getConstraints());
60 instance.keyDefinition = base.getKeyDefinition();
61 instance.userOrdered = base.isUserOrdered();
63 instance.description = base.getDescription();
64 instance.reference = base.getReference();
65 instance.status = base.getStatus();
66 instance.augmenting = base.isAugmenting();
67 instance.addedByUses = base.isAddedByUses();
68 instance.configuration = base.isConfiguration();
69 instance.constraints = base.getConstraints();
70 instance.augmentations.addAll(base.getAvailableAugmentations());
72 URI ns = qname.getNamespace();
73 Date rev = qname.getRevision();
74 String pref = qname.getPrefix();
75 addedChildNodes.addAll(ParserUtils.wrapChildNodes(moduleName, line, base.getChildNodes(), path, ns, rev, pref));
76 addedGroupings.addAll(ParserUtils.wrapGroupings(moduleName, line, base.getGroupings(), path, ns, rev, pref));
77 addedTypedefs.addAll(ParserUtils.wrapTypedefs(moduleName, line, base, path, ns, rev, pref));
78 addedUnknownNodes.addAll(ParserUtils.wrapUnknownNodes(moduleName, line, base.getUnknownSchemaNodes(), path, ns,
81 instance.uses.addAll(base.getUses());
85 public ListSchemaNode build() {
88 for (DataSchemaNodeBuilder node : addedChildNodes) {
89 DataSchemaNode child = node.build();
90 childNodes.put(child.getQName(), child);
92 instance.addChildNodes(childNodes);
95 for (TypeDefinitionBuilder entry : addedTypedefs) {
96 typedefs.add(entry.build());
98 instance.addTypeDefinitions(typedefs);
101 for (UsesNodeBuilder builder : addedUsesNodes) {
102 usesNodes.add(builder.build());
104 instance.addUses(usesNodes);
107 for (GroupingBuilder builder : addedGroupings) {
108 groupings.add(builder.build());
110 instance.addGroupings(groupings);
113 for (AugmentationSchemaBuilder builder : augmentationBuilders) {
114 augmentations.add(builder.build());
116 instance.addAvailableAugmentations(new HashSet<>(augmentations));
119 for (UnknownSchemaNodeBuilder b : addedUnknownNodes) {
120 unknownNodes.add(b.build());
122 Collections.sort(unknownNodes, Comparators.SCHEMA_NODE_COMP);
123 instance.addUnknownSchemaNodes(unknownNodes);
125 instance.setConstraints(constraints.build());
133 public Set<TypeDefinitionBuilder> getTypeDefinitionBuilders() {
134 return addedTypedefs;
138 public void addTypedef(final TypeDefinitionBuilder type) {
139 String typeName = type.getQName().getLocalName();
140 for (TypeDefinitionBuilder addedTypedef : addedTypedefs) {
141 if (addedTypedef.getQName().getLocalName().equals(typeName)) {
142 throw new YangParseException(moduleName, type.getLine(), "Can not add typedef '" + typeName
143 + "': typedef with same name already declared at line " + addedTypedef.getLine());
146 addedTypedefs.add(type);
150 public SchemaPath getPath() {
151 return instance.path;
155 public void setPath(SchemaPath path) {
156 instance.path = path;
160 public String getDescription() {
161 return instance.description;
165 public void setDescription(final String description) {
166 instance.description = description;
170 public String getReference() {
171 return instance.reference;
175 public void setReference(final String reference) {
176 instance.reference = reference;
180 public Status getStatus() {
181 return instance.status;
185 public void setStatus(Status status) {
186 if (status != null) {
187 instance.status = status;
192 public void addAugmentation(AugmentationSchemaBuilder augment) {
193 augmentationBuilders.add(augment);
196 public List<AugmentationSchemaBuilder> getAugmentationBuilders() {
197 return augmentationBuilders;
200 public List<QName> getKeyDefinition() {
201 return instance.keyDefinition;
204 public void setKeyDefinition(final List<QName> keyDefinition) {
205 instance.keyDefinition = keyDefinition;
209 public boolean isAugmenting() {
210 return instance.augmenting;
214 public void setAugmenting(boolean augmenting) {
215 instance.augmenting = augmenting;
219 public boolean isAddedByUses() {
220 return instance.addedByUses;
224 public void setAddedByUses(final boolean addedByUses) {
225 instance.addedByUses = addedByUses;
229 public Boolean isConfiguration() {
230 return instance.configuration;
234 public void setConfiguration(Boolean configuration) {
235 instance.configuration = configuration;
239 public ConstraintsBuilder getConstraints() {
243 public boolean isUserOrdered() {
244 return instance.userOrdered;
247 public void setUserOrdered(final boolean userOrdered) {
248 instance.userOrdered = userOrdered;
252 public int hashCode() {
253 final int prime = 31;
255 result = prime * result + ((schemaPath == null) ? 0 : schemaPath.hashCode());
260 public boolean equals(Object obj) {
267 if (getClass() != obj.getClass()) {
270 ListSchemaNodeBuilder other = (ListSchemaNodeBuilder) obj;
271 if (schemaPath == null) {
272 if (other.schemaPath != null) {
275 } else if (!schemaPath.equals(other.schemaPath)) {
278 if (parentBuilder == null) {
279 if (other.parentBuilder != null) {
282 } else if (!parentBuilder.equals(other.parentBuilder)) {
289 public String toString() {
290 return "list " + qname.getLocalName();
293 public final class ListSchemaNodeImpl implements ListSchemaNode {
294 private final QName qname;
295 private SchemaPath path;
296 private String description;
297 private String reference;
298 private Status status = Status.CURRENT;
299 private List<QName> keyDefinition = Collections.emptyList();
300 private boolean augmenting;
301 private boolean addedByUses;
302 private boolean configuration;
303 private ConstraintDefinition constraints;
304 private final Set<AugmentationSchema> augmentations = new HashSet<>();
305 private final Map<QName, DataSchemaNode> childNodes = new HashMap<>();
306 private final Set<TypeDefinition<?>> typeDefinitions = new TreeSet<>(Comparators.SCHEMA_NODE_COMP);
307 private final Set<GroupingDefinition> groupings = new TreeSet<>(Comparators.SCHEMA_NODE_COMP);
308 private final Set<UsesNode> uses = new HashSet<>();
309 private boolean userOrdered;
310 private final List<UnknownSchemaNode> unknownNodes = new ArrayList<>();
312 private ListSchemaNodeImpl(final QName qname, final SchemaPath path) {
318 public QName getQName() {
323 public SchemaPath getPath() {
328 public String getDescription() {
333 public String getReference() {
338 public Status getStatus() {
343 public List<QName> getKeyDefinition() {
344 return keyDefinition;
348 public boolean isAugmenting() {
353 public boolean isAddedByUses() {
358 public boolean isConfiguration() {
359 return configuration;
363 public ConstraintDefinition getConstraints() {
367 private void setConstraints(ConstraintDefinition constraints) {
368 this.constraints = constraints;
372 public Set<AugmentationSchema> getAvailableAugmentations() {
373 return Collections.unmodifiableSet(augmentations);
376 private void addAvailableAugmentations(Set<AugmentationSchema> augmentations) {
377 if (augmentations != null) {
378 this.augmentations.addAll(augmentations);
383 public Set<DataSchemaNode> getChildNodes() {
384 final Set<DataSchemaNode> result = new TreeSet<>(Comparators.SCHEMA_NODE_COMP);
385 result.addAll(childNodes.values());
386 return Collections.unmodifiableSet(result);
389 private void addChildNodes(Map<QName, DataSchemaNode> childNodes) {
390 if (childNodes != null) {
391 this.childNodes.putAll(childNodes);
396 public Set<GroupingDefinition> getGroupings() {
397 return Collections.unmodifiableSet(groupings);
400 private void addGroupings(Set<GroupingDefinition> groupings) {
401 if (groupings != null) {
402 this.groupings.addAll(groupings);
407 public Set<TypeDefinition<?>> getTypeDefinitions() {
408 return Collections.unmodifiableSet(typeDefinitions);
411 private void addTypeDefinitions(Set<TypeDefinition<?>> typeDefinitions) {
412 if (typeDefinitions != null) {
413 this.typeDefinitions.addAll(typeDefinitions);
418 public Set<UsesNode> getUses() {
419 return Collections.unmodifiableSet(uses);
422 private void addUses(Set<UsesNode> uses) {
424 this.uses.addAll(uses);
429 public DataSchemaNode getDataChildByName(QName name) {
430 return childNodes.get(name);
434 public DataSchemaNode getDataChildByName(String name) {
435 DataSchemaNode result = null;
436 for (Map.Entry<QName, DataSchemaNode> entry : childNodes.entrySet()) {
437 if (entry.getKey().getLocalName().equals(name)) {
438 result = entry.getValue();
446 public boolean isUserOrdered() {
451 public List<UnknownSchemaNode> getUnknownSchemaNodes() {
452 return Collections.unmodifiableList(unknownNodes);
455 private void addUnknownSchemaNodes(List<UnknownSchemaNode> unknownNodes) {
456 if (unknownNodes != null) {
457 this.unknownNodes.addAll(unknownNodes);
462 public int hashCode() {
463 final int prime = 31;
465 result = prime * result + ((qname == null) ? 0 : qname.hashCode());
466 result = prime * result + ((path == null) ? 0 : path.hashCode());
471 public boolean equals(Object obj) {
478 if (getClass() != obj.getClass()) {
481 final ListSchemaNodeImpl other = (ListSchemaNodeImpl) obj;
483 if (other.qname != null) {
486 } else if (!qname.equals(other.qname)) {
490 if (other.path != null) {
493 } else if (!path.equals(other.path)) {
500 public String toString() {
501 return "list " + qname.getLocalName();