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.HashSet;
15 import java.util.List;
17 import java.util.TreeSet;
19 import org.opendaylight.yangtools.yang.common.QName;
20 import org.opendaylight.yangtools.yang.model.api.AugmentationSchema;
21 import org.opendaylight.yangtools.yang.model.api.ConstraintDefinition;
22 import org.opendaylight.yangtools.yang.model.api.DataSchemaNode;
23 import org.opendaylight.yangtools.yang.model.api.GroupingDefinition;
24 import org.opendaylight.yangtools.yang.model.api.ListSchemaNode;
25 import org.opendaylight.yangtools.yang.model.api.SchemaPath;
26 import org.opendaylight.yangtools.yang.model.api.Status;
27 import org.opendaylight.yangtools.yang.model.api.TypeDefinition;
28 import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode;
29 import org.opendaylight.yangtools.yang.model.api.UsesNode;
30 import org.opendaylight.yangtools.yang.parser.builder.api.AbstractDataNodeContainerBuilder;
31 import org.opendaylight.yangtools.yang.parser.builder.api.AugmentationSchemaBuilder;
32 import org.opendaylight.yangtools.yang.parser.builder.api.AugmentationTargetBuilder;
33 import org.opendaylight.yangtools.yang.parser.builder.api.DataSchemaNodeBuilder;
34 import org.opendaylight.yangtools.yang.parser.builder.api.GroupingBuilder;
35 import org.opendaylight.yangtools.yang.parser.builder.api.TypeDefinitionBuilder;
36 import org.opendaylight.yangtools.yang.parser.builder.api.UsesNodeBuilder;
37 import org.opendaylight.yangtools.yang.parser.util.Comparators;
38 import org.opendaylight.yangtools.yang.parser.util.ParserUtils;
39 import org.opendaylight.yangtools.yang.parser.util.YangParseException;
41 public final class ListSchemaNodeBuilder extends AbstractDataNodeContainerBuilder implements DataSchemaNodeBuilder,
42 AugmentationTargetBuilder {
43 private boolean isBuilt;
44 private final ListSchemaNodeImpl instance;
45 private List<String> keys;
47 private final SchemaPath schemaPath;
48 // DataSchemaNode args
49 private final ConstraintsBuilder constraints;
50 // AugmentationTarget args
51 private final List<AugmentationSchemaBuilder> augmentationBuilders = new ArrayList<>();
54 public ListSchemaNodeBuilder(final String moduleName, final int line, final QName qname, final SchemaPath path) {
55 super(moduleName, line, qname);
56 this.schemaPath = path;
57 instance = new ListSchemaNodeImpl(qname, path);
58 constraints = new ConstraintsBuilder(moduleName, line);
61 public ListSchemaNodeBuilder(final String moduleName, final int line, final QName qname, final SchemaPath path, final ListSchemaNode base) {
62 super(moduleName, line, qname);
64 instance = new ListSchemaNodeImpl(qname, path);
65 constraints = new ConstraintsBuilder(moduleName, line, base.getConstraints());
67 instance.keyDefinition = base.getKeyDefinition();
68 instance.userOrdered = base.isUserOrdered();
70 instance.description = base.getDescription();
71 instance.reference = base.getReference();
72 instance.status = base.getStatus();
73 instance.augmenting = base.isAugmenting();
74 instance.addedByUses = base.isAddedByUses();
75 instance.configuration = base.isConfiguration();
76 instance.constraints = base.getConstraints();
77 instance.augmentations.addAll(base.getAvailableAugmentations());
79 URI ns = qname.getNamespace();
80 Date rev = qname.getRevision();
81 String pref = qname.getPrefix();
82 addedChildNodes.addAll(ParserUtils.wrapChildNodes(moduleName, line, base.getChildNodes(), path, ns, rev, pref));
83 addedGroupings.addAll(ParserUtils.wrapGroupings(moduleName, line, base.getGroupings(), path, ns, rev, pref));
84 addedTypedefs.addAll(ParserUtils.wrapTypedefs(moduleName, line, base, path, ns, rev, pref));
85 addedUnknownNodes.addAll(ParserUtils.wrapUnknownNodes(moduleName, line, base.getUnknownSchemaNodes(), path, ns,
88 instance.uses.addAll(base.getUses());
92 public ListSchemaNode build() {
95 for (DataSchemaNodeBuilder node : addedChildNodes) {
96 childNodes.add(node.build());
98 instance.addChildNodes(childNodes);
102 instance.keyDefinition = Collections.<QName> emptyList();
104 List<QName> qnames = new ArrayList<>();
105 for (String key : keys) {
106 qnames.add(instance.getDataChildByName(key).getQName());
108 instance.keyDefinition = qnames;
112 for (TypeDefinitionBuilder entry : addedTypedefs) {
113 typedefs.add(entry.build());
115 instance.addTypeDefinitions(typedefs);
118 for (UsesNodeBuilder builder : addedUsesNodes) {
119 usesNodes.add(builder.build());
121 instance.addUses(usesNodes);
124 for (GroupingBuilder builder : addedGroupings) {
125 groupings.add(builder.build());
127 instance.addGroupings(groupings);
130 final Set<AugmentationSchema> augmentations = new HashSet<>();
131 for (AugmentationSchemaBuilder builder : augmentationBuilders) {
132 augmentations.add(builder.build());
134 instance.addAvailableAugmentations(augmentations);
137 for (UnknownSchemaNodeBuilder b : addedUnknownNodes) {
138 unknownNodes.add(b.build());
140 Collections.sort(unknownNodes, Comparators.SCHEMA_NODE_COMP);
141 instance.addUnknownSchemaNodes(unknownNodes);
143 instance.setConstraints(constraints.build());
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 if (addedTypedef.getQName().getLocalName().equals(typeName)) {
160 throw new YangParseException(moduleName, type.getLine(), "Can not add typedef '" + typeName
161 + "': typedef with same name already declared at line " + addedTypedef.getLine());
164 addedTypedefs.add(type);
168 public SchemaPath getPath() {
169 return instance.path;
173 public void setPath(final SchemaPath path) {
174 instance.path = path;
178 public String getDescription() {
179 return instance.description;
183 public void setDescription(final String description) {
184 instance.description = description;
188 public String getReference() {
189 return instance.reference;
193 public void setReference(final String reference) {
194 instance.reference = reference;
198 public Status getStatus() {
199 return instance.status;
203 public void setStatus(final Status status) {
204 if (status != null) {
205 instance.status = status;
210 public void addAugmentation(final AugmentationSchemaBuilder augment) {
211 augmentationBuilders.add(augment);
214 public List<AugmentationSchemaBuilder> getAugmentationBuilders() {
215 return augmentationBuilders;
218 public List<String> getKeys() {
222 public void setKeys(final List<String> keys) {
227 public boolean isAugmenting() {
228 return instance.augmenting;
232 public void setAugmenting(final boolean augmenting) {
233 instance.augmenting = augmenting;
237 public boolean isAddedByUses() {
238 return instance.addedByUses;
242 public void setAddedByUses(final boolean addedByUses) {
243 instance.addedByUses = addedByUses;
247 public boolean isConfiguration() {
248 return instance.configuration;
252 public void setConfiguration(final boolean configuration) {
253 instance.configuration = configuration;
257 public ConstraintsBuilder getConstraints() {
261 public boolean isUserOrdered() {
262 return instance.userOrdered;
265 public void setUserOrdered(final boolean userOrdered) {
266 instance.userOrdered = userOrdered;
270 public int hashCode() {
271 final int prime = 31;
273 result = prime * result + ((schemaPath == null) ? 0 : schemaPath.hashCode());
278 public boolean equals(final Object obj) {
285 if (getClass() != obj.getClass()) {
288 ListSchemaNodeBuilder other = (ListSchemaNodeBuilder) obj;
289 if (schemaPath == null) {
290 if (other.schemaPath != null) {
293 } else if (!schemaPath.equals(other.schemaPath)) {
296 if (parentBuilder == null) {
297 if (other.parentBuilder != null) {
300 } else if (!parentBuilder.equals(other.parentBuilder)) {
307 public String toString() {
308 return "list " + qname.getLocalName();
311 private static final class ListSchemaNodeImpl implements ListSchemaNode {
312 private final QName qname;
313 private SchemaPath path;
314 private String description;
315 private String reference;
316 private Status status = Status.CURRENT;
317 private List<QName> keyDefinition = Collections.emptyList();
318 private boolean augmenting;
319 private boolean addedByUses;
320 private boolean configuration;
321 private ConstraintDefinition constraints;
322 private final Set<AugmentationSchema> augmentations = new HashSet<>();
323 private final Set<DataSchemaNode> childNodes = new TreeSet<>(Comparators.SCHEMA_NODE_COMP);
324 private final Set<TypeDefinition<?>> typeDefinitions = new TreeSet<>(Comparators.SCHEMA_NODE_COMP);
325 private final Set<GroupingDefinition> groupings = new TreeSet<>(Comparators.SCHEMA_NODE_COMP);
326 private final Set<UsesNode> uses = new HashSet<>();
327 private boolean userOrdered;
328 private final List<UnknownSchemaNode> unknownNodes = new ArrayList<>();
330 private ListSchemaNodeImpl(final QName qname, final SchemaPath path) {
336 public QName getQName() {
341 public SchemaPath getPath() {
346 public String getDescription() {
351 public String getReference() {
356 public Status getStatus() {
361 public List<QName> getKeyDefinition() {
362 return keyDefinition;
366 public boolean isAugmenting() {
371 public boolean isAddedByUses() {
376 public boolean isConfiguration() {
377 return configuration;
381 public ConstraintDefinition getConstraints() {
385 private void setConstraints(final ConstraintDefinition constraints) {
386 this.constraints = constraints;
390 public Set<AugmentationSchema> getAvailableAugmentations() {
391 return Collections.unmodifiableSet(augmentations);
394 private void addAvailableAugmentations(final Set<AugmentationSchema> augmentations) {
395 if (augmentations != null) {
396 this.augmentations.addAll(augmentations);
401 public Set<DataSchemaNode> getChildNodes() {
402 return Collections.unmodifiableSet(childNodes);
405 private void addChildNodes(final Set<DataSchemaNode> childNodes) {
406 if (childNodes != null) {
407 this.childNodes.addAll(childNodes);
412 public Set<GroupingDefinition> getGroupings() {
413 return Collections.unmodifiableSet(groupings);
416 private void addGroupings(final Set<GroupingDefinition> groupings) {
417 if (groupings != null) {
418 this.groupings.addAll(groupings);
423 public Set<TypeDefinition<?>> getTypeDefinitions() {
424 return Collections.unmodifiableSet(typeDefinitions);
427 private void addTypeDefinitions(final Set<TypeDefinition<?>> typeDefinitions) {
428 if (typeDefinitions != null) {
429 this.typeDefinitions.addAll(typeDefinitions);
434 public Set<UsesNode> getUses() {
435 return Collections.unmodifiableSet(uses);
438 private void addUses(final Set<UsesNode> uses) {
440 this.uses.addAll(uses);
445 public DataSchemaNode getDataChildByName(final QName name) {
446 return getChildNode(childNodes, name);
450 public DataSchemaNode getDataChildByName(final String name) {
451 return getChildNode(childNodes, name);
455 public boolean isUserOrdered() {
460 public List<UnknownSchemaNode> getUnknownSchemaNodes() {
461 return Collections.unmodifiableList(unknownNodes);
464 private void addUnknownSchemaNodes(final List<UnknownSchemaNode> unknownNodes) {
465 if (unknownNodes != null) {
466 this.unknownNodes.addAll(unknownNodes);
471 public int hashCode() {
472 final int prime = 31;
474 result = prime * result + ((qname == null) ? 0 : qname.hashCode());
475 result = prime * result + ((path == null) ? 0 : path.hashCode());
480 public boolean equals(final Object obj) {
487 if (getClass() != obj.getClass()) {
490 final ListSchemaNodeImpl other = (ListSchemaNodeImpl) obj;
492 if (other.qname != null) {
495 } else if (!qname.equals(other.qname)) {
499 if (other.path != null) {
502 } else if (!path.equals(other.path)) {
509 public String toString() {
510 return "list " + qname.getLocalName();