2 * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
\r
4 * This program and the accompanying materials are made available under the
\r
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
\r
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
\r
8 package org.opendaylight.controller.model.parser.builder;
\r
10 import java.util.HashMap;
\r
11 import java.util.HashSet;
\r
12 import java.util.List;
\r
13 import java.util.Map;
\r
14 import java.util.Set;
\r
16 import org.opendaylight.controller.model.parser.api.AbstractChildNodeBuilder;
\r
17 import org.opendaylight.controller.model.parser.api.AugmentationTargetBuilder;
\r
18 import org.opendaylight.controller.model.parser.api.DataSchemaNodeBuilder;
\r
19 import org.opendaylight.controller.model.parser.api.GroupingBuilder;
\r
20 import org.opendaylight.controller.model.parser.api.SchemaNodeBuilder;
\r
21 import org.opendaylight.controller.model.parser.api.TypeDefinitionAwareBuilder;
\r
22 import org.opendaylight.controller.model.parser.api.TypeDefinitionBuilder;
\r
23 import org.opendaylight.controller.model.parser.api.UsesNodeBuilder;
\r
24 import org.opendaylight.controller.yang.common.QName;
\r
25 import org.opendaylight.controller.yang.model.api.AugmentationSchema;
\r
26 import org.opendaylight.controller.yang.model.api.ConstraintDefinition;
\r
27 import org.opendaylight.controller.yang.model.api.DataSchemaNode;
\r
28 import org.opendaylight.controller.yang.model.api.ExtensionDefinition;
\r
29 import org.opendaylight.controller.yang.model.api.GroupingDefinition;
\r
30 import org.opendaylight.controller.yang.model.api.ListSchemaNode;
\r
31 import org.opendaylight.controller.yang.model.api.SchemaPath;
\r
32 import org.opendaylight.controller.yang.model.api.Status;
\r
33 import org.opendaylight.controller.yang.model.api.TypeDefinition;
\r
34 import org.opendaylight.controller.yang.model.api.UsesNode;
\r
37 public class ListSchemaNodeBuilder extends AbstractChildNodeBuilder implements DataSchemaNodeBuilder, SchemaNodeBuilder, AugmentationTargetBuilder, TypeDefinitionAwareBuilder {
\r
39 private final ListSchemaNodeImpl instance;
\r
41 private final Set<TypeDefinitionBuilder> addedTypedefs = new HashSet<TypeDefinitionBuilder>();
\r
42 private final Set<AugmentationSchema> augmentations = new HashSet<AugmentationSchema>();
\r
43 private final Set<UsesNodeBuilder> usesNodes = new HashSet<UsesNodeBuilder>();
\r
45 ListSchemaNodeBuilder(QName qname) {
\r
47 instance = new ListSchemaNodeImpl(qname);
\r
51 public ListSchemaNode build() {
\r
53 Map<QName, DataSchemaNode> childs = new HashMap<QName, DataSchemaNode>();
\r
54 for(DataSchemaNodeBuilder node : childNodes) {
\r
55 childs.put(node.getQName(), node.build());
\r
57 instance.setChildNodes(childs);
\r
60 Set<TypeDefinition<?>> typedefs = new HashSet<TypeDefinition<?>>();
\r
61 for (TypeDefinitionBuilder entry : addedTypedefs) {
\r
62 typedefs.add(entry.build());
\r
64 instance.setTypeDefinitions(typedefs);
\r
67 Set<UsesNode> usesNodeDefinitions = new HashSet<UsesNode>();
\r
68 for(UsesNodeBuilder builder : usesNodes) {
\r
69 usesNodeDefinitions.add(builder.build());
\r
71 instance.setUses(usesNodeDefinitions);
\r
74 Set<GroupingDefinition> groupingDefinitions = new HashSet<GroupingDefinition>();
\r
75 for (GroupingBuilder builder : groupings) {
\r
76 groupingDefinitions.add(builder.build());
\r
78 instance.setGroupings(groupingDefinitions);
\r
80 instance.setAvailableAugmentations(augmentations);
\r
87 public void addTypedef(TypeDefinitionBuilder type) {
\r
88 addedTypedefs.add(type);
\r
92 public void setPath(SchemaPath path) {
\r
93 instance.setPath(path);
\r
97 public void setDescription(String description) {
\r
98 instance.setDescription(description);
\r
102 public void setReference(String reference) {
\r
103 instance.setReference(reference);
\r
107 public void setStatus(Status status) {
\r
108 instance.setStatus(status);
\r
112 public void addUsesNode(UsesNodeBuilder usesBuilder) {
\r
113 usesNodes.add(usesBuilder);
\r
117 public void addAugmentation(AugmentationSchema augmentationSchema) {
\r
118 augmentations.add(augmentationSchema);
\r
121 public void setKeyDefinition(List<QName> keyDefinition) {
\r
122 instance.setKeyDefinition(keyDefinition);
\r
124 public void setAugmenting(boolean augmenting) {
\r
125 instance.setAugmenting(augmenting);
\r
127 public void setConfiguration(boolean configuration) {
\r
128 instance.setConfiguration(configuration);
\r
130 public void setConstraints(ConstraintDefinition constraints) {
\r
131 instance.setConstraints(constraints);
\r
133 public void setUserOrdered(boolean userOrdered) {
\r
134 instance.setUserOrdered(userOrdered);
\r
138 private class ListSchemaNodeImpl implements ListSchemaNode {
\r
139 private final QName qname;
\r
140 private SchemaPath path;
\r
141 private String description;
\r
142 private String reference;
\r
143 private Status status = Status.CURRENT;
\r
145 private List<QName> keyDefinition;
\r
147 private boolean augmenting;
\r
148 private boolean configuration;
\r
149 private ConstraintDefinition constraints;
\r
151 private Set<AugmentationSchema> augmentations;
\r
153 private Map<QName, DataSchemaNode> childNodes;
\r
154 private Set<TypeDefinition<?>> typeDefinitions;
\r
155 private Set<GroupingDefinition> groupings;
\r
156 private Set<UsesNode> uses;
\r
158 private boolean userOrdered;
\r
160 private ListSchemaNodeImpl(QName qname) {
\r
161 this.qname = qname;
\r
166 public QName getQName() {
\r
171 public SchemaPath getPath() {
\r
174 private void setPath(SchemaPath path) {
\r
179 public String getDescription() {
\r
180 return description;
\r
182 private void setDescription(String description) {
\r
183 this.description = description;
\r
187 public String getReference() {
\r
190 private void setReference(String reference) {
\r
191 this.reference = reference;
\r
195 public Status getStatus() {
\r
198 private void setStatus(Status status) {
\r
199 this.status = status;
\r
203 public List<QName> getKeyDefinition() {
\r
204 return keyDefinition;
\r
206 private void setKeyDefinition(List<QName> keyDefinition) {
\r
207 this.keyDefinition = keyDefinition;
\r
211 public boolean isAugmenting() {
\r
214 private void setAugmenting(boolean augmenting) {
\r
215 this.augmenting = augmenting;
\r
219 public boolean isConfiguration() {
\r
220 return configuration;
\r
222 private void setConfiguration(boolean configuration) {
\r
223 this.configuration = configuration;
\r
227 public ConstraintDefinition getConstraints() {
\r
228 return constraints;
\r
230 private void setConstraints(ConstraintDefinition constraints) {
\r
231 this.constraints = constraints;
\r
235 public Set<AugmentationSchema> getAvailableAugmentations() {
\r
236 return augmentations;
\r
238 private void setAvailableAugmentations(Set<AugmentationSchema> augmentations) {
\r
239 this.augmentations = augmentations;
\r
243 public Set<DataSchemaNode> getChildNodes() {
\r
244 return new HashSet<DataSchemaNode>(childNodes.values());
\r
246 void setChildNodes(Map<QName, DataSchemaNode> childNodes) {
\r
247 this.childNodes = childNodes;
\r
251 public Set<GroupingDefinition> getGroupings() {
\r
254 private void setGroupings(Set<GroupingDefinition> groupings) {
\r
255 this.groupings = groupings;
\r
259 public Set<TypeDefinition<?>> getTypeDefinitions() {
\r
260 return typeDefinitions;
\r
262 private void setTypeDefinitions(Set<TypeDefinition<?>> typeDefinitions) {
\r
263 this.typeDefinitions = typeDefinitions;
\r
267 public Set<UsesNode> getUses() {
\r
270 private void setUses(Set<UsesNode> uses) {
\r
275 public DataSchemaNode getDataChildByName(QName name) {
\r
276 return childNodes.get(name);
\r
280 public DataSchemaNode getDataChildByName(String name) {
\r
281 DataSchemaNode result = null;
\r
282 for(Map.Entry<QName, DataSchemaNode> entry : childNodes.entrySet()) {
\r
283 if(entry.getKey().getLocalName().equals(name)) {
\r
284 result = entry.getValue();
\r
292 public boolean isUserOrdered() {
\r
293 return userOrdered;
\r
295 private void setUserOrdered(boolean userOrdered) {
\r
296 this.userOrdered = userOrdered;
\r
300 public List<ExtensionDefinition> getExtensionSchemaNodes() {
\r
301 // TODO Auto-generated method stub
\r
306 public int hashCode() {
\r
307 final int prime = 31;
\r
309 result = prime * result + ((qname == null) ? 0 : qname.hashCode());
\r
310 result = prime * result + ((path == null) ? 0 : path.hashCode());
\r
311 result = prime * result + ((description == null) ? 0 : description.hashCode());
\r
312 result = prime * result + ((reference == null) ? 0 : reference.hashCode());
\r
313 result = prime * result + ((status == null) ? 0 : status.hashCode());
\r
314 result = prime * result + ((keyDefinition == null) ? 0 : keyDefinition.hashCode());
\r
315 result = prime * result + (augmenting ? 1231 : 1237);
\r
316 result = prime * result + (configuration ? 1231 : 1237);
\r
317 result = prime * result + ((constraints == null) ? 0 : constraints.hashCode());
\r
318 result = prime * result + ((augmentations == null) ? 0 : augmentations.hashCode());
\r
319 result = prime * result + ((childNodes == null) ? 0 : childNodes.hashCode());
\r
320 result = prime * result + ((typeDefinitions == null) ? 0 : typeDefinitions.hashCode());
\r
321 result = prime * result + ((groupings == null) ? 0 : groupings.hashCode());
\r
322 result = prime * result + ((uses == null) ? 0 : uses.hashCode());
\r
323 result = prime * result + (userOrdered ? 1231 : 1237);
\r
329 public boolean equals(Object obj) {
\r
336 if (getClass() != obj.getClass()) {
\r
339 ListSchemaNodeImpl other = (ListSchemaNodeImpl) obj;
\r
340 if (qname == null) {
\r
341 if (other.qname != null) {
\r
344 } else if (!qname.equals(other.qname)) {
\r
347 if (path == null) {
\r
348 if (other.path != null) {
\r
351 } else if (!path.equals(other.path)) {
\r
354 if (description == null) {
\r
355 if (other.description != null) {
\r
358 } else if (!description.equals(other.description)) {
\r
361 if (reference == null) {
\r
362 if (other.reference != null) {
\r
365 } else if (!reference.equals(other.reference)) {
\r
368 if (status == null) {
\r
369 if (other.status != null) {
\r
372 } else if (!status.equals(other.status)) {
\r
375 if (keyDefinition == null) {
\r
376 if (other.keyDefinition != null) {
\r
379 } else if (!keyDefinition.equals(other.keyDefinition)) {
\r
382 if(augmenting != other.augmenting) {
\r
385 if(configuration != other.configuration) {
\r
388 if (constraints == null) {
\r
389 if (other.constraints != null) {
\r
392 } else if (!constraints.equals(other.constraints)) {
\r
395 if (augmentations == null) {
\r
396 if (other.augmentations != null) {
\r
399 } else if (!augmentations.equals(other.augmentations)) {
\r
402 if (childNodes == null) {
\r
403 if (other.childNodes != null) {
\r
406 } else if (!childNodes.equals(other.childNodes)) {
\r
409 if (typeDefinitions == null) {
\r
410 if (other.typeDefinitions != null) {
\r
413 } else if (!typeDefinitions.equals(other.typeDefinitions)) {
\r
416 if (groupings == null) {
\r
417 if (other.groupings != null) {
\r
420 } else if (!groupings.equals(other.groupings)) {
\r
423 if (uses == null) {
\r
424 if (other.uses != null) {
\r
427 } else if (!uses.equals(other.uses)) {
\r
430 if(userOrdered != other.userOrdered) {
\r
440 public String toString() {
\r
441 StringBuilder sb = new StringBuilder(ListSchemaNodeImpl.class.getSimpleName());
\r
443 sb.append("qname="+ qname);
\r
444 sb.append(", path="+ path);
\r
445 sb.append(", description="+ description);
\r
446 sb.append(", reference="+ reference);
\r
447 sb.append(", status="+ status);
\r
448 sb.append(", keyDefinition="+ keyDefinition);
\r
449 sb.append(", augmenting="+ augmenting);
\r
450 sb.append(", configuration="+ configuration);
\r
451 sb.append(", constraints="+ constraints);
\r
452 sb.append(", augmentations="+ augmentations);
\r
453 sb.append(", childNodes="+ childNodes.values());
\r
454 sb.append(", typedefinitions="+ typeDefinitions);
\r
455 sb.append(", groupings="+ groupings);
\r
456 sb.append(", uses="+ uses);
\r
457 sb.append(", userOrdered="+ userOrdered);
\r
459 return sb.toString();
\r