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.HashMap;
13 import java.util.HashSet;
14 import java.util.List;
18 import org.opendaylight.yangtools.yang.model.api.AugmentationSchema;
19 import org.opendaylight.yangtools.yang.model.api.GroupingDefinition;
20 import org.opendaylight.yangtools.yang.model.api.SchemaNode;
21 import org.opendaylight.yangtools.yang.model.api.SchemaPath;
22 import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode;
23 import org.opendaylight.yangtools.yang.model.api.UsesNode;
24 import org.opendaylight.yangtools.yang.parser.builder.api.AbstractBuilder;
25 import org.opendaylight.yangtools.yang.parser.builder.api.AugmentationSchemaBuilder;
26 import org.opendaylight.yangtools.yang.parser.builder.api.Builder;
27 import org.opendaylight.yangtools.yang.parser.builder.api.DataNodeContainerBuilder;
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.SchemaNodeBuilder;
31 import org.opendaylight.yangtools.yang.parser.builder.api.UsesNodeBuilder;
32 import org.opendaylight.yangtools.yang.parser.util.RefineHolder;
33 import org.opendaylight.yangtools.yang.parser.util.YangParseException;
35 public final class UsesNodeBuilderImpl extends AbstractBuilder implements UsesNodeBuilder {
36 private boolean isBuilt;
37 private UsesNodeImpl instance;
38 private DataNodeContainerBuilder parentBuilder;
39 private final String groupingPathString;
40 private SchemaPath groupingPath;
41 private GroupingDefinition groupingDefinition;
42 private GroupingBuilder groupingBuilder;
43 private boolean addedByUses;
44 private boolean augmenting;
45 private boolean resolved;
46 private final Set<AugmentationSchema> augments = new HashSet<>();
47 private final Set<AugmentationSchemaBuilder> addedAugments = new HashSet<>();
48 private final List<SchemaNodeBuilder> refineBuilders = new ArrayList<>();
49 private final List<RefineHolder> refines = new ArrayList<>();
52 public UsesNodeBuilderImpl(final String moduleName, final int line, final String groupingName) {
53 super(moduleName, line);
54 this.groupingPathString = groupingName;
58 public UsesNode build() {
60 instance = new UsesNodeImpl(groupingPath);
61 instance.setAddedByUses(addedByUses);
64 for (AugmentationSchemaBuilder builder : addedAugments) {
65 augments.add(builder.build());
67 instance.setAugmentations(augments);
70 final Map<SchemaPath, SchemaNode> refineNodes = new HashMap<>();
71 for (SchemaNodeBuilder refineBuilder : refineBuilders) {
72 SchemaNode refineNode = refineBuilder.build();
73 refineNodes.put(refineNode.getPath(), refineNode);
75 instance.setRefines(refineNodes);
78 for (UnknownSchemaNodeBuilder b : addedUnknownNodes) {
79 unknownNodes.add(b.build());
81 instance.setUnknownSchemaNodes(unknownNodes);
90 public DataNodeContainerBuilder getParent() {
95 public void setParent(Builder parent) {
96 if (!(parent instanceof DataNodeContainerBuilder)) {
97 throw new YangParseException(moduleName, line,
98 "Parent of 'uses' has to be instance of DataNodeContainerBuilder, but was: '" + parent + "'.");
100 this.parentBuilder = (DataNodeContainerBuilder) parent;
104 public SchemaPath getGroupingPath() {
109 public GroupingDefinition getGroupingDefinition() {
110 return groupingDefinition;
114 public void setGroupingDefinition(GroupingDefinition groupingDefinition) {
115 this.groupingDefinition = groupingDefinition;
116 if (groupingDefinition != null) {
117 this.groupingPath = groupingDefinition.getPath();
122 public GroupingBuilder getGroupingBuilder() {
123 return groupingBuilder;
127 public void setGrouping(GroupingBuilder grouping) {
128 this.groupingBuilder = grouping;
129 if (groupingBuilder != null) {
130 this.groupingPath = groupingBuilder.getPath();
135 public String getGroupingPathAsString() {
136 return groupingPathString;
140 public Set<AugmentationSchemaBuilder> getAugmentations() {
141 return addedAugments;
145 public void addAugment(final AugmentationSchemaBuilder augmentBuilder) {
146 addedAugments.add(augmentBuilder);
150 public boolean isAddedByUses() {
154 public void setAddedByUses(final boolean addedByUses) {
155 this.addedByUses = addedByUses;
159 public boolean isAugmenting() {
164 public void setAugmenting(boolean augmenting) {
165 this.augmenting = augmenting;
169 public boolean isResolved() {
174 public void setResolved(boolean resolved) {
175 this.resolved = resolved;
179 public List<SchemaNodeBuilder> getRefineNodes() {
180 return refineBuilders;
184 public void addRefineNode(DataSchemaNodeBuilder refineNode) {
185 refineBuilders.add(refineNode);
189 public List<RefineHolder> getRefines() {
194 public void addRefine(RefineHolder refine) {
199 public int hashCode() {
200 final int prime = 31;
202 result = prime * result + ((groupingPathString == null) ? 0 : groupingPathString.hashCode());
203 result = prime * result + ((parentBuilder == null) ? 0 : parentBuilder.hashCode());
208 public boolean equals(Object obj) {
215 if (getClass() != obj.getClass()) {
218 UsesNodeBuilderImpl other = (UsesNodeBuilderImpl) obj;
219 if (groupingPathString == null) {
220 if (other.groupingPathString != null) {
223 } else if (!groupingPathString.equals(other.groupingPathString)) {
226 if (parentBuilder == null) {
227 if (other.parentBuilder != null) {
230 } else if (!parentBuilder.equals(other.parentBuilder)) {
237 public String toString() {
238 return "uses '" + groupingPathString + "'";
241 public final class UsesNodeImpl implements UsesNode {
242 private final SchemaPath groupingPath;
243 private Set<AugmentationSchema> augmentations = Collections.emptySet();
244 private boolean addedByUses;
245 private Map<SchemaPath, SchemaNode> refines = Collections.emptyMap();
246 private List<UnknownSchemaNode> unknownNodes = Collections.emptyList();
248 private UsesNodeImpl(final SchemaPath groupingPath) {
249 this.groupingPath = groupingPath;
253 public SchemaPath getGroupingPath() {
258 public Set<AugmentationSchema> getAugmentations() {
259 return augmentations;
262 private void setAugmentations(final Set<AugmentationSchema> augmentations) {
263 if (augmentations != null) {
264 this.augmentations = augmentations;
269 public boolean isAugmenting() {
274 public boolean isAddedByUses() {
278 private void setAddedByUses(final boolean addedByUses) {
279 this.addedByUses = addedByUses;
283 public Map<SchemaPath, SchemaNode> getRefines() {
287 private void setRefines(Map<SchemaPath, SchemaNode> refines) {
288 if (refines != null) {
289 this.refines = refines;
293 public List<UnknownSchemaNode> getUnknownSchemaNodes() {
297 private void setUnknownSchemaNodes(List<UnknownSchemaNode> unknownSchemaNodes) {
298 if (unknownSchemaNodes != null) {
299 this.unknownNodes = unknownSchemaNodes;
303 public UsesNodeBuilder toBuilder() {
304 return UsesNodeBuilderImpl.this;
308 public int hashCode() {
309 final int prime = 31;
311 result = prime * result + ((groupingPath == null) ? 0 : groupingPath.hashCode());
312 result = prime * result + ((augmentations == null) ? 0 : augmentations.hashCode());
317 public boolean equals(Object obj) {
324 if (getClass() != obj.getClass()) {
327 final UsesNodeImpl other = (UsesNodeImpl) obj;
328 if (groupingPath == null) {
329 if (other.groupingPath != null) {
332 } else if (!groupingPath.equals(other.groupingPath)) {
335 if (augmentations == null) {
336 if (other.augmentations != null) {
339 } else if (!augmentations.equals(other.augmentations)) {
346 public String toString() {
347 StringBuilder sb = new StringBuilder(UsesNodeImpl.class.getSimpleName());
348 sb.append("[groupingPath=");
349 sb.append(groupingPath);
351 return sb.toString();