X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fsal%2Fyang-prototype%2Fcode-generator%2Fyang-model-parser-impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fyang%2Fparser%2Fbuilder%2Fimpl%2FUnionTypeBuilder.java;h=33a51d6cd322d1201e0caf0452c0d1f79a97655b;hb=934490635d3a1c4ebd27703d33f382ae7d676a4f;hp=fd9a3aabc84cc5d10b7d1d41cca9a4b5787de809;hpb=39ff6ed2000232d607877311770c74cef36cf96f;p=controller.git diff --git a/opendaylight/sal/yang-prototype/code-generator/yang-model-parser-impl/src/main/java/org/opendaylight/controller/yang/parser/builder/impl/UnionTypeBuilder.java b/opendaylight/sal/yang-prototype/code-generator/yang-model-parser-impl/src/main/java/org/opendaylight/controller/yang/parser/builder/impl/UnionTypeBuilder.java index fd9a3aabc8..33a51d6cd3 100644 --- a/opendaylight/sal/yang-prototype/code-generator/yang-model-parser-impl/src/main/java/org/opendaylight/controller/yang/parser/builder/impl/UnionTypeBuilder.java +++ b/opendaylight/sal/yang-prototype/code-generator/yang-model-parser-impl/src/main/java/org/opendaylight/controller/yang/parser/builder/impl/UnionTypeBuilder.java @@ -7,23 +7,21 @@ */ package org.opendaylight.controller.yang.parser.builder.impl; -import java.net.URI; import java.util.ArrayList; import java.util.Collections; -import java.util.Date; import java.util.List; -import org.opendaylight.controller.yang.common.QName; import org.opendaylight.controller.yang.model.api.SchemaPath; 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.api.type.LengthConstraint; import org.opendaylight.controller.yang.model.api.type.PatternConstraint; import org.opendaylight.controller.yang.model.api.type.RangeConstraint; import org.opendaylight.controller.yang.model.util.UnionType; import org.opendaylight.controller.yang.parser.builder.api.AbstractTypeAwareBuilder; -import org.opendaylight.controller.yang.parser.builder.api.Builder; import org.opendaylight.controller.yang.parser.builder.api.TypeDefinitionBuilder; +import org.opendaylight.controller.yang.parser.util.YangParseException; /** * Builder for YANG union type. User can add type to this union as @@ -31,33 +29,22 @@ import org.opendaylight.controller.yang.parser.builder.api.TypeDefinitionBuilder * When build is called, types in builder form will be built and add to resolved * types. */ -public class UnionTypeBuilder extends AbstractTypeAwareBuilder implements - TypeDefinitionBuilder, Builder { - private final int line; +public final class UnionTypeBuilder extends AbstractTypeAwareBuilder implements TypeDefinitionBuilder { + private final static String NAME = "union"; + private final List> types; private final List typedefs; - private final UnionType instance; + private UnionType instance; + private boolean isBuilt; - private final List actualPath; - private final URI namespace; - private final Date revision; + private SchemaPath path; - public UnionTypeBuilder(final List actualPath, final URI namespace, - final Date revision, final int line) { - this.line = line; + public UnionTypeBuilder(final int line) { + super(line, null); types = new ArrayList>(); typedefs = new ArrayList(); - instance = new UnionType(actualPath, namespace, revision, types); - - this.actualPath = actualPath; - this.namespace = namespace; - this.revision = revision; } - @Override - public int getLine() { - return line; - } public List> getTypes() { return types; @@ -83,56 +70,65 @@ public class UnionTypeBuilder extends AbstractTypeAwareBuilder implements } @Override - public void setType(final TypeDefinitionBuilder tdb) { + public void setTypedef(final TypeDefinitionBuilder tdb) { typedefs.add(tdb); } @Override public UnionType build() { - for (TypeDefinitionBuilder tdb : typedefs) { - types.add(tdb.build()); + if (!isBuilt) { + instance = new UnionType(path, types); + for (TypeDefinitionBuilder tdb : typedefs) { + types.add(tdb.build()); + } + isBuilt = true; } return instance; } @Override public void setPath(final SchemaPath schemaPath) { - throw new IllegalStateException("Can not set path to " - + UnionTypeBuilder.class.getSimpleName()); + this.path = schemaPath; } @Override public void setDescription(final String description) { - throw new IllegalStateException("Can not set description to " - + UnionTypeBuilder.class.getSimpleName()); + throw new YangParseException(line, "Can not set description to " + NAME); } @Override public void setReference(final String reference) { - throw new IllegalStateException("Can not set reference to " - + UnionTypeBuilder.class.getSimpleName()); + throw new YangParseException(line, "Can not set reference to " + NAME); } @Override public void setStatus(final Status status) { - throw new IllegalStateException("Can not set status to " - + UnionTypeBuilder.class.getSimpleName()); + throw new YangParseException(line, "Can not set status to " + NAME); } @Override - public void addUnknownSchemaNode(final UnknownSchemaNodeBuilder unknownNode) { - throw new IllegalStateException("Can not add unknown node to " - + UnionTypeBuilder.class.getSimpleName()); + public boolean isAddedByUses() { + return false; } @Override - public QName getQName() { - return null; + public void setAddedByUses(final boolean addedByUses) { + throw new YangParseException(line, "Union type can not be added by uses."); + } + + @Override + public List getUnknownNodes() { + return Collections.emptyList(); + } + + @Override + public void addUnknownSchemaNode(final UnknownSchemaNodeBuilder unknownNode) { + // not yet supported } @Override public SchemaPath getPath() { - return null; + return path; } @Override @@ -157,8 +153,7 @@ public class UnionTypeBuilder extends AbstractTypeAwareBuilder implements @Override public void setRanges(List ranges) { - throw new IllegalStateException("Can not set ranges to " - + UnionTypeBuilder.class.getSimpleName()); + throw new YangParseException(line, "Can not set ranges to " + NAME); } @Override @@ -168,8 +163,7 @@ public class UnionTypeBuilder extends AbstractTypeAwareBuilder implements @Override public void setLengths(List lengths) { - throw new IllegalStateException("Can not set lengths to " - + UnionTypeBuilder.class.getSimpleName()); + throw new YangParseException(line, "Can not set lengths to " + NAME); } @Override @@ -179,8 +173,7 @@ public class UnionTypeBuilder extends AbstractTypeAwareBuilder implements @Override public void setPatterns(List patterns) { - throw new IllegalStateException("Can not set patterns to " - + UnionTypeBuilder.class.getSimpleName()); + throw new YangParseException(line, "Can not set patterns to " + NAME); } @Override @@ -190,12 +183,11 @@ public class UnionTypeBuilder extends AbstractTypeAwareBuilder implements @Override public void setFractionDigits(Integer fractionDigits) { - throw new IllegalStateException("Can not set fraction digits to " - + UnionTypeBuilder.class.getSimpleName()); + throw new YangParseException(line, "Can not set fraction digits to " + NAME); } @Override - public List getUnknownNodes() { + public List getUnknownNodeBuilders() { return Collections.emptyList(); } @@ -206,8 +198,7 @@ public class UnionTypeBuilder extends AbstractTypeAwareBuilder implements @Override public void setDefaultValue(Object defaultValue) { - throw new IllegalStateException("Can not set default value to " - + UnionTypeBuilder.class.getSimpleName()); + throw new YangParseException(line, "Can not set default value to " + NAME); } @Override @@ -217,26 +208,12 @@ public class UnionTypeBuilder extends AbstractTypeAwareBuilder implements @Override public void setUnits(String units) { - throw new IllegalStateException("Can not set units to " - + UnionTypeBuilder.class.getSimpleName()); - } - - public List getActualPath() { - return actualPath; - } - - public URI getNamespace() { - return namespace; - } - - public Date getRevision() { - return revision; + throw new YangParseException(line, "Can not set units to " + NAME); } @Override public String toString() { - final StringBuilder result = new StringBuilder( - UnionTypeBuilder.class.getSimpleName() + "["); + final StringBuilder result = new StringBuilder(UnionTypeBuilder.class.getSimpleName() + "["); result.append(", types=" + types); result.append(", typedefs=" + typedefs); result.append("]");