import org.opendaylight.yangtools.yang.parser.builder.api.GroupingBuilder;
import org.opendaylight.yangtools.yang.parser.builder.api.SchemaNodeBuilder;
import org.opendaylight.yangtools.yang.parser.builder.api.UsesNodeBuilder;
+import org.opendaylight.yangtools.yang.parser.util.Comparators;
import org.opendaylight.yangtools.yang.parser.util.RefineHolder;
import org.opendaylight.yangtools.yang.parser.util.YangParseException;
private boolean addedByUses;
private boolean augmenting;
private boolean resolved;
- private final Set<AugmentationSchema> augments = new HashSet<>();
private final Set<AugmentationSchemaBuilder> addedAugments = new HashSet<>();
private final List<SchemaNodeBuilder> refineBuilders = new ArrayList<>();
private final List<RefineHolder> refines = new ArrayList<>();
instance.setAddedByUses(addedByUses);
// AUGMENTATIONS
+ final Set<AugmentationSchema> augments = new HashSet<>();
for (AugmentationSchemaBuilder builder : addedAugments) {
augments.add(builder.build());
}
for (UnknownSchemaNodeBuilder b : addedUnknownNodes) {
unknownNodes.add(b.build());
}
- instance.setUnknownSchemaNodes(unknownNodes);
+ Collections.sort(unknownNodes, Comparators.SCHEMA_NODE_COMP);
+ instance.addUnknownSchemaNodes(unknownNodes);
isBuilt = true;
}
}
@Override
- public void setParent(Builder parent) {
+ public void setParent(final Builder parent) {
if (!(parent instanceof DataNodeContainerBuilder)) {
throw new YangParseException(moduleName, line,
"Parent of 'uses' has to be instance of DataNodeContainerBuilder, but was: '" + parent + "'.");
}
@Override
- public void setGroupingDefinition(GroupingDefinition groupingDefinition) {
+ public void setGroupingDefinition(final GroupingDefinition groupingDefinition) {
this.groupingDefinition = groupingDefinition;
if (groupingDefinition != null) {
this.groupingPath = groupingDefinition.getPath();
}
@Override
- public void setGrouping(GroupingBuilder grouping) {
+ public void setGrouping(final GroupingBuilder grouping) {
this.groupingBuilder = grouping;
if (groupingBuilder != null) {
this.groupingPath = groupingBuilder.getPath();
}
@Override
- public void setAugmenting(boolean augmenting) {
+ public void setAugmenting(final boolean augmenting) {
this.augmenting = augmenting;
}
}
@Override
- public void setResolved(boolean resolved) {
+ public void setResolved(final boolean resolved) {
this.resolved = resolved;
}
}
@Override
- public void addRefineNode(DataSchemaNodeBuilder refineNode) {
+ public void addRefineNode(final DataSchemaNodeBuilder refineNode) {
refineBuilders.add(refineNode);
}
}
@Override
- public void addRefine(RefineHolder refine) {
+ public void addRefine(final RefineHolder refine) {
refines.add(refine);
}
}
@Override
- public boolean equals(Object obj) {
+ public boolean equals(final Object obj) {
if (this == obj) {
return true;
}
return "uses '" + groupingPathString + "'";
}
- public final class UsesNodeImpl implements UsesNode {
+ private static final class UsesNodeImpl implements UsesNode {
private final SchemaPath groupingPath;
private Set<AugmentationSchema> augmentations = Collections.emptySet();
private boolean addedByUses;
private Map<SchemaPath, SchemaNode> refines = Collections.emptyMap();
- private List<UnknownSchemaNode> unknownNodes = Collections.emptyList();
+ private final List<UnknownSchemaNode> unknownNodes = new ArrayList<>();
private UsesNodeImpl(final SchemaPath groupingPath) {
this.groupingPath = groupingPath;
return refines;
}
- private void setRefines(Map<SchemaPath, SchemaNode> refines) {
+ private void setRefines(final Map<SchemaPath, SchemaNode> refines) {
if (refines != null) {
this.refines = refines;
}
}
- public List<UnknownSchemaNode> getUnknownSchemaNodes() {
- return unknownNodes;
- }
-
- private void setUnknownSchemaNodes(List<UnknownSchemaNode> unknownSchemaNodes) {
+ private void addUnknownSchemaNodes(final List<UnknownSchemaNode> unknownSchemaNodes) {
if (unknownSchemaNodes != null) {
- this.unknownNodes = unknownSchemaNodes;
+ this.unknownNodes.addAll(unknownSchemaNodes);
}
}
- public UsesNodeBuilder toBuilder() {
- return UsesNodeBuilderImpl.this;
- }
-
@Override
public int hashCode() {
final int prime = 31;
}
@Override
- public boolean equals(Object obj) {
+ public boolean equals(final Object obj) {
if (this == obj) {
return true;
}