import org.opendaylight.yangtools.yang.model.api.SchemaPath;
import org.opendaylight.yangtools.yang.model.api.Status;
import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode;
+import org.opendaylight.yangtools.yang.model.api.YangNode;
import org.opendaylight.yangtools.yang.parser.builder.api.AbstractSchemaNodeBuilder;
import org.opendaylight.yangtools.yang.parser.builder.api.AugmentationSchemaBuilder;
import org.opendaylight.yangtools.yang.parser.builder.api.AugmentationTargetBuilder;
AugmentationTargetBuilder {
private boolean isBuilt;
private final ChoiceNodeImpl instance;
+ private YangNode parent;
// DataSchemaNode args
private boolean augmenting;
private boolean addedByUses;
private Boolean configuration;
private final ConstraintsBuilder constraints;
// AugmentationTarget args
- private final Set<AugmentationSchemaBuilder> addedAugmentations = new HashSet<>();
+ private final List<AugmentationSchema> augmentations = new ArrayList<>();
+ private final List<AugmentationSchemaBuilder> augmentationBuilders = new ArrayList<>();
// ChoiceNode args
- private Set<ChoiceCaseNode> cases;
- private final Set<ChoiceCaseBuilder> addedCases = new HashSet<>();
+ private Set<ChoiceCaseNode> cases = new TreeSet<>(Comparators.SCHEMA_NODE_COMP);
+ private final Set<ChoiceCaseBuilder> caseBuilders = new HashSet<>();
private String defaultCase;
public ChoiceBuilder(final String moduleName, final int line, final QName qname) {
}
@Override
- public ChoiceNode build() {
+ public ChoiceNode build(YangNode parent) {
if (!isBuilt) {
+ this.parent = parent;
+ instance.setParent(parent);
instance.setPath(schemaPath);
instance.setDescription(description);
instance.setReference(reference);
instance.setDefaultCase(defaultCase);
// CASES
- if (cases == null) {
- cases = new TreeSet<>(Comparators.SCHEMA_NODE_COMP);
- for (ChoiceCaseBuilder caseBuilder : addedCases) {
- cases.add(caseBuilder.build());
- }
+ for (ChoiceCaseBuilder caseBuilder : caseBuilders) {
+ cases.add(caseBuilder.build(instance));
}
instance.setCases(cases);
// AUGMENTATIONS
- final Set<AugmentationSchema> augmentations = new HashSet<>();
- for (AugmentationSchemaBuilder builder : addedAugmentations) {
- augmentations.add(builder.build());
+ for (AugmentationSchemaBuilder builder : augmentationBuilders) {
+ augmentations.add(builder.build(instance));
}
- instance.setAvailableAugmentations(augmentations);
+ instance.setAvailableAugmentations(new HashSet<>(augmentations));
// UNKNOWN NODES
- if (unknownNodes == null) {
- unknownNodes = new ArrayList<>();
- for (UnknownSchemaNodeBuilder b : addedUnknownNodes) {
- unknownNodes.add(b.build());
- }
- Collections.sort(unknownNodes, Comparators.SCHEMA_NODE_COMP);
+ for (UnknownSchemaNodeBuilder b : addedUnknownNodes) {
+ unknownNodes.add(b.build(instance));
}
+ Collections.sort(unknownNodes, Comparators.SCHEMA_NODE_COMP);
instance.setUnknownSchemaNodes(unknownNodes);
isBuilt = true;
@Override
public void rebuild() {
isBuilt = false;
- build();
+ build(parent);
}
@Override
}
public Set<ChoiceCaseBuilder> getCases() {
- return addedCases;
+ return caseBuilders;
}
/**
* @return case with given name if present, null otherwise
*/
public ChoiceCaseBuilder getCaseNodeByName(String caseName) {
- for (ChoiceCaseBuilder addedCase : addedCases) {
+ for (ChoiceCaseBuilder addedCase : caseBuilders) {
if (addedCase.getQName().getLocalName().equals(caseName)) {
return addedCase;
}
public void addCase(DataSchemaNodeBuilder caseNode) {
QName caseQName = caseNode.getQName();
String caseName = caseQName.getLocalName();
- for (ChoiceCaseBuilder addedCase : addedCases) {
+
+ for (ChoiceCaseBuilder addedCase : caseBuilders) {
if (addedCase.getQName().getLocalName().equals(caseName)) {
throw new YangParseException(caseNode.getModuleName(), caseNode.getLine(), "Can not add '" + caseNode
+ "' to node '" + qname.getLocalName() + "' in module '" + moduleName
}
if (caseNode instanceof ChoiceCaseBuilder) {
- addedCases.add((ChoiceCaseBuilder) caseNode);
+ caseBuilders.add((ChoiceCaseBuilder) caseNode);
} else {
ChoiceCaseBuilder caseBuilder = new ChoiceCaseBuilder(caseNode.getModuleName(), caseNode.getLine(),
caseQName);
SchemaPath newPath = ParserUtils.createSchemaPath(caseNode.getPath(), caseQName);
caseNode.setPath(newPath);
caseBuilder.addChildNode(caseNode);
- addedCases.add(caseBuilder);
+ caseBuilders.add(caseBuilder);
}
}
return constraints;
}
- public Set<AugmentationSchemaBuilder> getAugmentations() {
- return addedAugmentations;
- }
-
@Override
public void addAugmentation(AugmentationSchemaBuilder augment) {
- addedAugmentations.add(augment);
+ augmentationBuilders.add(augment);
+ }
+
+ public List<AugmentationSchemaBuilder> getAugmentationBuilders() {
+ return augmentationBuilders;
}
public List<UnknownSchemaNodeBuilder> getUnknownNodes() {
} else if (!schemaPath.equals(other.schemaPath)) {
return false;
}
- if (parent == null) {
- if (other.parent != null) {
+ if (parentBuilder == null) {
+ if (other.parentBuilder != null) {
return false;
}
- } else if (!parent.equals(other.parent)) {
+ } else if (!parentBuilder.equals(other.parentBuilder)) {
return false;
}
return true;
public final class ChoiceNodeImpl implements ChoiceNode {
private final QName qname;
private SchemaPath path;
+ private YangNode parent;
private String description;
private String reference;
private Status status = Status.CURRENT;
this.path = path;
}
+ @Override
+ public YangNode getParent() {
+ return parent;
+ }
+
+ private void setParent(YangNode parent) {
+ this.parent = parent;
+ }
+
@Override
public String getDescription() {
return description;