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.HashMap;
12 import java.util.HashSet;
13 import java.util.List;
17 import org.opendaylight.yangtools.yang.model.api.AugmentationSchema;
18 import org.opendaylight.yangtools.yang.model.api.GroupingDefinition;
19 import org.opendaylight.yangtools.yang.model.api.SchemaNode;
20 import org.opendaylight.yangtools.yang.model.api.SchemaPath;
21 import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode;
22 import org.opendaylight.yangtools.yang.model.api.UsesNode;
23 import org.opendaylight.yangtools.yang.parser.builder.api.AbstractBuilder;
24 import org.opendaylight.yangtools.yang.parser.builder.api.AugmentationSchemaBuilder;
25 import org.opendaylight.yangtools.yang.parser.builder.api.Builder;
26 import org.opendaylight.yangtools.yang.parser.builder.api.DataNodeContainerBuilder;
27 import org.opendaylight.yangtools.yang.parser.builder.api.DataSchemaNodeBuilder;
28 import org.opendaylight.yangtools.yang.parser.builder.api.GroupingBuilder;
29 import org.opendaylight.yangtools.yang.parser.builder.api.SchemaNodeBuilder;
30 import org.opendaylight.yangtools.yang.parser.builder.api.UsesNodeBuilder;
31 import org.opendaylight.yangtools.yang.parser.util.RefineHolder;
32 import org.opendaylight.yangtools.yang.parser.util.YangParseException;
34 import com.google.common.collect.ImmutableList;
35 import com.google.common.collect.ImmutableMap;
36 import com.google.common.collect.ImmutableSet;
38 public final class UsesNodeBuilderImpl extends AbstractBuilder implements UsesNodeBuilder {
39 private UsesNodeImpl instance;
40 private DataNodeContainerBuilder parentBuilder;
41 private final String groupingPathString;
42 private SchemaPath groupingPath;
43 private GroupingDefinition groupingDefinition;
44 private GroupingBuilder groupingBuilder;
45 private boolean addedByUses;
46 private boolean augmenting;
47 private boolean resolved;
48 private final Set<AugmentationSchemaBuilder> augmentationBuilders = new HashSet<>();
49 private final List<SchemaNodeBuilder> refineBuilders = new ArrayList<>();
50 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() {
59 if (instance != null) {
63 instance = new UsesNodeImpl(groupingPath);
64 instance.setAddedByUses(addedByUses);
67 final Set<AugmentationSchema> augments = new HashSet<>();
68 for (AugmentationSchemaBuilder builder : augmentationBuilders) {
69 augments.add(builder.build());
71 instance.augmentations = ImmutableSet.copyOf(augments);
74 final Map<SchemaPath, SchemaNode> refineNodes = new HashMap<>();
75 for (SchemaNodeBuilder refineBuilder : refineBuilders) {
76 SchemaNode refineNode = refineBuilder.build();
77 refineNodes.put(refineNode.getPath(), refineNode);
79 instance.refines = ImmutableMap.copyOf(refineNodes);
82 for (UnknownSchemaNodeBuilder b : addedUnknownNodes) {
83 unknownNodes.add(b.build());
85 instance.unknownNodes = ImmutableList.copyOf(unknownNodes);
91 public DataNodeContainerBuilder getParent() {
96 public void setParent(final Builder parent) {
97 if (!(parent instanceof DataNodeContainerBuilder)) {
98 throw new YangParseException(moduleName, line,
99 "Parent of 'uses' has to be instance of DataNodeContainerBuilder, but was: '" + parent + "'.");
101 this.parentBuilder = (DataNodeContainerBuilder) parent;
105 public SchemaPath getGroupingPath() {
110 public GroupingDefinition getGroupingDefinition() {
111 return groupingDefinition;
115 public void setGroupingDefinition(final GroupingDefinition groupingDefinition) {
116 this.groupingDefinition = groupingDefinition;
117 if (groupingDefinition != null) {
118 this.groupingPath = groupingDefinition.getPath();
123 public GroupingBuilder getGroupingBuilder() {
124 return groupingBuilder;
128 public void setGrouping(final GroupingBuilder grouping) {
129 this.groupingBuilder = grouping;
130 if (groupingBuilder != null) {
131 this.groupingPath = groupingBuilder.getPath();
136 public String getGroupingPathAsString() {
137 return groupingPathString;
141 public Set<AugmentationSchemaBuilder> getAugmentations() {
142 return augmentationBuilders;
146 public void addAugment(final AugmentationSchemaBuilder augmentBuilder) {
147 augmentationBuilders.add(augmentBuilder);
151 public boolean isAddedByUses() {
156 public void setAddedByUses(final boolean addedByUses) {
157 this.addedByUses = addedByUses;
161 public boolean isAugmenting() {
166 public void setAugmenting(final boolean augmenting) {
167 this.augmenting = augmenting;
171 public boolean isResolved() {
176 public void setResolved(final boolean resolved) {
177 this.resolved = resolved;
181 public List<SchemaNodeBuilder> getRefineNodes() {
182 return refineBuilders;
186 public void addRefineNode(final DataSchemaNodeBuilder refineNode) {
187 refineBuilders.add(refineNode);
191 public List<RefineHolder> getRefines() {
196 public void addRefine(final RefineHolder refine) {
201 public int hashCode() {
202 final int prime = 31;
204 result = prime * result + ((groupingPathString == null) ? 0 : groupingPathString.hashCode());
205 result = prime * result + ((parentBuilder == null) ? 0 : parentBuilder.hashCode());
210 public boolean equals(final Object obj) {
217 if (getClass() != obj.getClass()) {
220 UsesNodeBuilderImpl other = (UsesNodeBuilderImpl) obj;
221 if (groupingPathString == null) {
222 if (other.groupingPathString != null) {
225 } else if (!groupingPathString.equals(other.groupingPathString)) {
228 if (parentBuilder == null) {
229 if (other.parentBuilder != null) {
232 } else if (!parentBuilder.equals(other.parentBuilder)) {
239 public String toString() {
240 return "uses '" + groupingPathString + "'";
243 private static final class UsesNodeImpl implements UsesNode {
244 private final SchemaPath groupingPath;
245 private ImmutableSet<AugmentationSchema> augmentations;
246 private boolean addedByUses;
247 private ImmutableMap<SchemaPath, SchemaNode> refines;
248 private ImmutableList<UnknownSchemaNode> unknownNodes;
250 private UsesNodeImpl(final SchemaPath groupingPath) {
251 this.groupingPath = groupingPath;
255 public SchemaPath getGroupingPath() {
260 public Set<AugmentationSchema> getAugmentations() {
261 return augmentations;
265 public boolean isAugmenting() {
270 public boolean isAddedByUses() {
274 private void setAddedByUses(final boolean addedByUses) {
275 this.addedByUses = addedByUses;
279 public Map<SchemaPath, SchemaNode> getRefines() {
283 @SuppressWarnings("unused")
284 public List<UnknownSchemaNode> getUnknownSchemaNodes() {
289 public int hashCode() {
290 final int prime = 31;
292 result = prime * result + ((groupingPath == null) ? 0 : groupingPath.hashCode());
293 result = prime * result + ((augmentations == null) ? 0 : augmentations.hashCode());
298 public boolean equals(final Object obj) {
305 if (getClass() != obj.getClass()) {
308 final UsesNodeImpl other = (UsesNodeImpl) obj;
309 if (groupingPath == null) {
310 if (other.groupingPath != null) {
313 } else if (!groupingPath.equals(other.groupingPath)) {
316 if (augmentations == null) {
317 if (other.augmentations != null) {
320 } else if (!augmentations.equals(other.augmentations)) {
327 public String toString() {
328 StringBuilder sb = new StringBuilder(UsesNodeImpl.class.getSimpleName());
329 sb.append("[groupingPath=");
330 sb.append(groupingPath);
332 return sb.toString();