*/
package org.opendaylight.yangtools.yang.parser.builder.impl;
-import java.net.URI;
import java.util.ArrayList;
-import java.util.Date;
import java.util.List;
import java.util.Set;
import org.opendaylight.yangtools.yang.common.QName;
-import org.opendaylight.yangtools.yang.model.api.*;
-import org.opendaylight.yangtools.yang.parser.builder.api.AbstractDataNodeContainerBuilder;
+import org.opendaylight.yangtools.yang.model.api.AugmentationSchema;
+import org.opendaylight.yangtools.yang.model.api.ConstraintDefinition;
+import org.opendaylight.yangtools.yang.model.api.ContainerSchemaNode;
+import org.opendaylight.yangtools.yang.model.api.DerivableSchemaNode;
+import org.opendaylight.yangtools.yang.model.api.SchemaPath;
+import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode;
import org.opendaylight.yangtools.yang.parser.builder.api.AugmentationSchemaBuilder;
import org.opendaylight.yangtools.yang.parser.builder.api.AugmentationTargetBuilder;
+import org.opendaylight.yangtools.yang.parser.builder.api.ConstraintsBuilder;
import org.opendaylight.yangtools.yang.parser.builder.api.DataSchemaNodeBuilder;
-import org.opendaylight.yangtools.yang.parser.builder.api.GroupingBuilder;
-import org.opendaylight.yangtools.yang.parser.builder.api.TypeDefinitionBuilder;
-import org.opendaylight.yangtools.yang.parser.builder.api.UsesNodeBuilder;
-import org.opendaylight.yangtools.yang.parser.util.ParserUtils;
-import org.opendaylight.yangtools.yang.parser.util.YangParseException;
+import org.opendaylight.yangtools.yang.parser.builder.api.SchemaNodeBuilder;
+import org.opendaylight.yangtools.yang.parser.builder.api.UnknownSchemaNodeBuilder;
+import org.opendaylight.yangtools.yang.parser.builder.util.AbstractDocumentedDataNodeContainer;
+import org.opendaylight.yangtools.yang.parser.builder.util.AbstractDocumentedDataNodeContainerBuilder;
+import com.google.common.base.Optional;
import com.google.common.base.Preconditions;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableSet;
-public final class ContainerSchemaNodeBuilder extends AbstractDataNodeContainerBuilder implements
+public final class ContainerSchemaNodeBuilder extends AbstractDocumentedDataNodeContainerBuilder implements
AugmentationTargetBuilder, DataSchemaNodeBuilder {
private ContainerSchemaNodeImpl instance;
private boolean presence;
// SchemaNode args
private SchemaPath path;
- private String description;
- private String reference;
- private Status status = Status.CURRENT;
// DataSchemaNode args
private boolean augmenting;
private boolean addedByUses;
private boolean configuration;
+ private ContainerSchemaNode originalNode;
+ private ContainerSchemaNodeBuilder originalBuilder;
private final ConstraintsBuilder constraints;
// AugmentationTarget args
private final List<AugmentationSchema> augmentations = new ArrayList<>();
public ContainerSchemaNodeBuilder(final String moduleName, final int line, final QName qname, final SchemaPath path) {
super(moduleName, line, qname);
- this.path = path;
- this.constraints = new ConstraintsBuilder(moduleName, line);
+ this.path = Preconditions.checkNotNull(path, "Schema Path must not be null");
+ this.constraints = new ConstraintsBuilderImpl(moduleName, line);
}
// constructor for uses
public ContainerSchemaNodeBuilder(final String moduleName, final int line, final QName qname,
final SchemaPath path, final ContainerSchemaNode base) {
- super(moduleName, line, qname);
- this.path = path;
- constraints = new ConstraintsBuilder(moduleName, line, base.getConstraints());
+ super(moduleName, line, qname, path, base);
+ this.path = Preconditions.checkNotNull(path, "Schema Path must not be null");
+
+ constraints = new ConstraintsBuilderImpl(moduleName, line, base.getConstraints());
- description = base.getDescription();
- reference = base.getReference();
- status = base.getStatus();
augmenting = base.isAugmenting();
addedByUses = base.isAddedByUses();
+ originalNode = base;
configuration = base.isConfiguration();
presence = base.isPresenceContainer();
- URI ns = qname.getNamespace();
- Date rev = qname.getRevision();
- String pref = qname.getPrefix();
- addedChildNodes.addAll(ParserUtils.wrapChildNodes(moduleName, line, base.getChildNodes(), path, ns, rev, pref));
- addedGroupings.addAll(ParserUtils.wrapGroupings(moduleName, line, base.getGroupings(), path, ns, rev, pref));
- addedTypedefs.addAll(ParserUtils.wrapTypedefs(moduleName, line, base, path, ns, rev, pref));
- addedUnknownNodes.addAll(ParserUtils.wrapUnknownNodes(moduleName, line, base.getUnknownSchemaNodes(), path, ns,
- rev, pref));
-
augmentations.addAll(base.getAvailableAugmentations());
- usesNodes.addAll(base.getUses());
+
+ }
+
+ @Override
+ protected String getStatementName() {
+ return "container";
}
@Override
return instance;
}
- instance = new ContainerSchemaNodeImpl(qname, path);
+ buildChildren();
+ instance = new ContainerSchemaNodeImpl(this);
- instance.description = description;
- instance.reference = reference;
- instance.status = status;
instance.augmenting = augmenting;
instance.addedByUses = addedByUses;
instance.configuration = configuration;
- instance.constraints = constraints.build();
+ instance.constraints = constraints.toInstance();
instance.presence = presence;
- // CHILD NODES
- for (DataSchemaNodeBuilder node : addedChildNodes) {
- childNodes.add(node.build());
- }
- instance.childNodes = ImmutableSet.copyOf(childNodes);
-
- // GROUPINGS
- for (GroupingBuilder builder : addedGroupings) {
- groupings.add(builder.build());
- }
- instance.groupings = ImmutableSet.copyOf(groupings);
-
- // TYPEDEFS
- for (TypeDefinitionBuilder entry : addedTypedefs) {
- typedefs.add(entry.build());
- }
- instance.typeDefinitions = ImmutableSet.copyOf(typedefs);
-
- // USES
- for (UsesNodeBuilder builder : addedUsesNodes) {
- usesNodes.add(builder.build());
+ // ORIGINAL NODE
+ if (originalNode == null && originalBuilder != null) {
+ originalNode = originalBuilder.build();
}
- instance.uses = ImmutableSet.copyOf(usesNodes);
+ instance.original = originalNode;
// AUGMENTATIONS
for (AugmentationSchemaBuilder builder : augmentationBuilders) {
return instance;
}
- @Override
- public Set<TypeDefinitionBuilder> getTypeDefinitionBuilders() {
- return addedTypedefs;
- }
-
- @Override
- public void addTypedef(final TypeDefinitionBuilder type) {
- String typeName = type.getQName().getLocalName();
- for (TypeDefinitionBuilder addedTypedef : addedTypedefs) {
- if (addedTypedef.getQName().getLocalName().equals(typeName)) {
- throw new YangParseException(moduleName, type.getLine(), "Can not add typedef '" + typeName
- + "': typedef with same name already declared at line " + addedTypedef.getLine());
- }
- }
- addedTypedefs.add(type);
- }
-
public List<AugmentationSchemaBuilder> getAugmentationBuilders() {
return augmentationBuilders;
}
@Override
- public void addAugmentation(AugmentationSchemaBuilder augment) {
+ public void addAugmentation(final AugmentationSchemaBuilder augment) {
augmentationBuilders.add(augment);
}
}
@Override
- public void setPath(SchemaPath path) {
+ public void setPath(final SchemaPath path) {
this.path = path;
}
- @Override
- public String getDescription() {
- return description;
- }
-
- @Override
- public void setDescription(final String description) {
- this.description = description;
- }
-
- @Override
- public String getReference() {
- return reference;
- }
-
- @Override
- public void setReference(final String reference) {
- this.reference = reference;
- }
-
- @Override
- public Status getStatus() {
- return status;
- }
-
- @Override
- public void setStatus(Status status) {
- this.status = Preconditions.checkNotNull(status, "status cannot be null");
- }
-
@Override
public boolean isAugmenting() {
return augmenting;
}
@Override
- public void setAugmenting(boolean augmenting) {
+ public void setAugmenting(final boolean augmenting) {
this.augmenting = augmenting;
}
this.addedByUses = addedByUses;
}
+ @Override
+ public ContainerSchemaNodeBuilder getOriginal() {
+ return originalBuilder;
+ }
+
+ @Override
+ public void setOriginal(final SchemaNodeBuilder builder) {
+ Preconditions.checkArgument(builder instanceof ContainerSchemaNodeBuilder, "Original of container cannot be "
+ + builder);
+ this.originalBuilder = (ContainerSchemaNodeBuilder) builder;
+ }
+
@Override
public boolean isConfiguration() {
return configuration;
}
@Override
- public void setConfiguration(boolean configuration) {
+ public void setConfiguration(final boolean configuration) {
this.configuration = configuration;
}
return presence;
}
- public void setPresence(boolean presence) {
+ public void setPresence(final boolean presence) {
this.presence = presence;
}
}
@Override
- public boolean equals(Object obj) {
+ public boolean equals(final Object obj) {
if (this == obj) {
return true;
}
} else if (!path.equals(other.path)) {
return false;
}
- if (parentBuilder == null) {
- if (other.parentBuilder != null) {
+ if (getParent() == null) {
+ if (other.getParent() != null) {
return false;
}
- } else if (!parentBuilder.equals(other.parentBuilder)) {
+ } else if (!getParent().equals(other.getParent())) {
return false;
}
return true;
return "container " + qname.getLocalName();
}
- private static final class ContainerSchemaNodeImpl implements ContainerSchemaNode {
+ private static final class ContainerSchemaNodeImpl extends AbstractDocumentedDataNodeContainer implements
+ ContainerSchemaNode, DerivableSchemaNode {
private final QName qname;
private final SchemaPath path;
- private String description;
- private String reference;
- private Status status;
+
private boolean augmenting;
private boolean addedByUses;
private boolean configuration;
+ private ContainerSchemaNode original;
private ConstraintDefinition constraints;
private ImmutableSet<AugmentationSchema> augmentations;
- private ImmutableSet<DataSchemaNode> childNodes;
- private ImmutableSet<GroupingDefinition> groupings;
- private ImmutableSet<TypeDefinition<?>> typeDefinitions;
- private ImmutableSet<UsesNode> uses;
private ImmutableList<UnknownSchemaNode> unknownNodes;
private boolean presence;
- private ContainerSchemaNodeImpl(QName qname, SchemaPath path) {
- this.qname = qname;
- this.path = path;
+ public ContainerSchemaNodeImpl(final ContainerSchemaNodeBuilder builder) {
+ super(builder);
+ this.qname = builder.getQName();
+ this.path = builder.getPath();
}
@Override
return path;
}
- @Override
- public String getDescription() {
- return description;
- }
-
- @Override
- public String getReference() {
- return reference;
- }
-
- @Override
- public Status getStatus() {
- return status;
- }
-
@Override
public boolean isAugmenting() {
return augmenting;
return addedByUses;
}
+ @Override
+ public Optional<ContainerSchemaNode> getOriginal() {
+ return Optional.fromNullable(original);
+ }
+
@Override
public boolean isConfiguration() {
return configuration;
return augmentations;
}
- @Override
- public Set<DataSchemaNode> getChildNodes() {
- return childNodes;
- }
-
- @Override
- public Set<GroupingDefinition> getGroupings() {
- return groupings;
- }
-
- @Override
- public DataSchemaNode getDataChildByName(QName name) {
- return getChildNode(childNodes, name);
- }
-
- @Override
- public DataSchemaNode getDataChildByName(String name) {
- return getChildNode(childNodes, name);
- }
-
- @Override
- public Set<UsesNode> getUses() {
- return uses;
- }
-
@Override
public boolean isPresenceContainer() {
return presence;
}
- @Override
- public Set<TypeDefinition<?>> getTypeDefinitions() {
- return typeDefinitions;
- }
-
@Override
public List<UnknownSchemaNode> getUnknownSchemaNodes() {
return unknownNodes;
}
@Override
- public boolean equals(Object obj) {
+ public boolean equals(final Object obj) {
if (this == obj) {
return true;
}
public String toString() {
return "container " + qname.getLocalName();
}
+
}
}