import org.opendaylight.controller.yang.model.api.Status;
import org.opendaylight.controller.yang.model.api.TypeDefinition;
import org.opendaylight.controller.yang.model.api.UnknownSchemaNode;
+import org.opendaylight.controller.yang.model.parser.builder.api.AbstractTypeAwareBuilder;
import org.opendaylight.controller.yang.model.parser.builder.api.DataSchemaNodeBuilder;
import org.opendaylight.controller.yang.model.parser.builder.api.SchemaNodeBuilder;
-import org.opendaylight.controller.yang.model.parser.builder.api.TypeAwareBuilder;
-
-public class LeafSchemaNodeBuilder implements DataSchemaNodeBuilder,
- SchemaNodeBuilder, TypeAwareBuilder {
+public class LeafSchemaNodeBuilder extends AbstractTypeAwareBuilder implements DataSchemaNodeBuilder,
+ SchemaNodeBuilder {
private final QName qname;
private final LeafSchemaNodeImpl instance;
- private final ConstraintsBuilder constraintsBuilder = new ConstraintsBuilder();
+ private final ConstraintsBuilder constraints = new ConstraintsBuilder();
private final List<UnknownSchemaNodeBuilder> addedUnknownNodes = new ArrayList<UnknownSchemaNodeBuilder>();
- private TypeDefinition<?> type;
LeafSchemaNodeBuilder(QName qname) {
this.qname = qname;
@Override
public LeafSchemaNode build() {
+ if(type == null) {
+ instance.setType(typedef.build());
+ } else {
+ instance.setType(type);
+ }
+
// UNKNOWN NODES
final List<UnknownSchemaNode> unknownNodes = new ArrayList<UnknownSchemaNode>();
for(UnknownSchemaNodeBuilder b : addedUnknownNodes) {
}
instance.setUnknownSchemaNodes(unknownNodes);
- instance.setConstraints(constraintsBuilder.build());
+ instance.setConstraints(constraints.build());
return instance;
}
@Override
public ConstraintsBuilder getConstraintsBuilder() {
- return constraintsBuilder;
- }
-
- @Override
- public TypeDefinition<?> getType() {
- return type;
- }
-
- @Override
- public void setType(TypeDefinition<?> type) {
- this.type = type;
- instance.setType(type);
+ return constraints;
}
@Override
- public void addUnknownSchemaNode(UnknownSchemaNodeBuilder unknownSchemaNodeBuilder) {
- addedUnknownNodes.add(unknownSchemaNodeBuilder);
+ public void addUnknownSchemaNode(UnknownSchemaNodeBuilder unknownNode) {
+ addedUnknownNodes.add(unknownNode);
}
private class LeafSchemaNodeImpl implements LeafSchemaNode {
private Status status = Status.CURRENT;
private boolean augmenting;
private boolean configuration;
- private ConstraintDefinition constraints;
+ private ConstraintDefinition constraintsDef;
private TypeDefinition<?> type;
- private List<UnknownSchemaNode> unknownSchemaNodes = Collections.emptyList();
+ private List<UnknownSchemaNode> unknownNodes = Collections.emptyList();
private LeafSchemaNodeImpl(QName qname) {
this.qname = qname;
@Override
public ConstraintDefinition getConstraints() {
- return constraints;
+ return constraintsDef;
}
- private void setConstraints(ConstraintDefinition constraints) {
- this.constraints = constraints;
+ private void setConstraints(ConstraintDefinition constraintsDef) {
+ this.constraintsDef = constraintsDef;
}
@Override
@Override
public List<UnknownSchemaNode> getUnknownSchemaNodes() {
- return unknownSchemaNodes;
+ return unknownNodes;
}
- private void setUnknownSchemaNodes(List<UnknownSchemaNode> unknownSchemaNodes) {
- if(unknownSchemaNodes != null) {
- this.unknownSchemaNodes = unknownSchemaNodes;
+ private void setUnknownSchemaNodes(List<UnknownSchemaNode> unknownNodes) {
+ if(unknownNodes != null) {
+ this.unknownNodes = unknownNodes;
}
}
sb.append(", status=" + status);
sb.append(", augmenting=" + augmenting);
sb.append(", configuration=" + configuration);
- sb.append(", constraints=" + constraints);
+ sb.append(", constraints=" + constraintsDef);
sb.append(", type=" + type);
- sb.append(", constraints=" + constraints);
+ sb.append(", constraints=" + constraintsDef);
sb.append("]");
return sb.toString();
}