X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=yang%2Fyang-parser-rfc7950%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fyangtools%2Fyang%2Fparser%2Frfc7950%2Fstmt%2Ftype%2FUnionSpecificationSupport.java;h=f90526c62e39b386975281552b287ad09efb90da;hb=d605800fa3da3ea340497c683bd83ea37c12da6c;hp=6504bbd131e6da7cb8abe583ca8035f4637c8839;hpb=5db72610e7358baa1f5c9dd85abc9e93f3c8b020;p=yangtools.git diff --git a/yang/yang-parser-rfc7950/src/main/java/org/opendaylight/yangtools/yang/parser/rfc7950/stmt/type/UnionSpecificationSupport.java b/yang/yang-parser-rfc7950/src/main/java/org/opendaylight/yangtools/yang/parser/rfc7950/stmt/type/UnionSpecificationSupport.java index 6504bbd131..f90526c62e 100644 --- a/yang/yang-parser-rfc7950/src/main/java/org/opendaylight/yangtools/yang/parser/rfc7950/stmt/type/UnionSpecificationSupport.java +++ b/yang/yang-parser-rfc7950/src/main/java/org/opendaylight/yangtools/yang/parser/rfc7950/stmt/type/UnionSpecificationSupport.java @@ -9,34 +9,27 @@ package org.opendaylight.yangtools.yang.parser.rfc7950.stmt.type; import com.google.common.collect.ImmutableList; import org.eclipse.jdt.annotation.NonNull; +import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.model.api.YangStmtMapping; import org.opendaylight.yangtools.yang.model.api.meta.DeclaredStatement; import org.opendaylight.yangtools.yang.model.api.meta.EffectiveStatement; import org.opendaylight.yangtools.yang.model.api.stmt.TypeEffectiveStatement; import org.opendaylight.yangtools.yang.model.api.stmt.TypeStatement.UnionSpecification; -import org.opendaylight.yangtools.yang.model.util.type.BaseTypes; -import org.opendaylight.yangtools.yang.model.util.type.UnionTypeBuilder; -import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.BaseStatementSupport; +import org.opendaylight.yangtools.yang.model.parser.api.YangParserConfiguration; +import org.opendaylight.yangtools.yang.model.ri.type.BaseTypes; +import org.opendaylight.yangtools.yang.model.ri.type.UnionTypeBuilder; import org.opendaylight.yangtools.yang.parser.spi.meta.CommonStmtCtx; import org.opendaylight.yangtools.yang.parser.spi.meta.EffectiveStmtCtx.Current; import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext; import org.opendaylight.yangtools.yang.parser.spi.meta.SubstatementValidator; import org.opendaylight.yangtools.yang.parser.spi.source.SourceException; -final class UnionSpecificationSupport - extends BaseStatementSupport> { - private static final SubstatementValidator SUBSTATEMENT_VALIDATOR = SubstatementValidator.builder(YangStmtMapping - .TYPE) - .addMultiple(YangStmtMapping.TYPE) - .build(); +final class UnionSpecificationSupport extends AbstractTypeSupport { + private static final SubstatementValidator SUBSTATEMENT_VALIDATOR = + SubstatementValidator.builder(YangStmtMapping.TYPE).addMultiple(YangStmtMapping.TYPE).build(); - UnionSpecificationSupport() { - super(YangStmtMapping.TYPE); - } - - @Override - public String parseArgumentValue(final StmtContext ctx, final String value) { - return value; + UnionSpecificationSupport(final YangParserConfiguration config) { + super(config); } @Override @@ -45,25 +38,23 @@ final class UnionSpecificationSupport } @Override - protected UnionSpecification createDeclared(final StmtContext ctx, + protected UnionSpecification createDeclared(final StmtContext ctx, final ImmutableList> substatements) { - return new UnionSpecificationImpl(ctx.coerceRawStatementArgument(), substatements); - } - - @Override - protected UnionSpecification createEmptyDeclared(final StmtContext ctx) { - throw noType(ctx); + if (substatements.isEmpty()) { + throw noType(ctx); + } + return new UnionSpecificationImpl(ctx.getRawArgument(), ctx.getArgument(), substatements); } @Override - protected EffectiveStatement createEffective( - final Current stmt, + protected EffectiveStatement createEffective( + final Current stmt, final ImmutableList> substatements) { if (substatements.isEmpty()) { throw noType(stmt); } - final UnionTypeBuilder builder = BaseTypes.unionTypeBuilder(stmt.getSchemaPath()); + final UnionTypeBuilder builder = BaseTypes.unionTypeBuilder(stmt.argumentAsTypeQName()); for (final EffectiveStatement subStmt : substatements) { if (subStmt instanceof TypeEffectiveStatement) { @@ -81,6 +72,6 @@ final class UnionSpecificationSupport * When the type is "union", the "type" statement (Section 7.4) MUST be * present. */ - return new SourceException("At least one type statement has to be present", stmt.sourceReference()); + return new SourceException("At least one type statement has to be present", stmt); } }