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<String, UnionSpecification, EffectiveStatement<String, UnionSpecification>> {
- private static final SubstatementValidator SUBSTATEMENT_VALIDATOR = SubstatementValidator.builder(YangStmtMapping
- .TYPE)
- .addMultiple(YangStmtMapping.TYPE)
- .build();
+final class UnionSpecificationSupport extends AbstractTypeSupport<UnionSpecification> {
+ 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
}
@Override
- protected UnionSpecification createDeclared(final StmtContext<String, UnionSpecification, ?> ctx,
+ protected UnionSpecification createDeclared(final StmtContext<QName, UnionSpecification, ?> ctx,
final ImmutableList<? extends DeclaredStatement<?>> substatements) {
- return new UnionSpecificationImpl(ctx.coerceRawStatementArgument(), substatements);
+ if (substatements.isEmpty()) {
+ throw noType(ctx);
+ }
+ return new UnionSpecificationImpl(ctx.getRawArgument(), ctx.getArgument(), substatements);
}
@Override
- protected UnionSpecification createEmptyDeclared(final StmtContext<String, UnionSpecification, ?> ctx) {
- throw noType(ctx);
- }
+ protected EffectiveStatement<QName, UnionSpecification> createEffective(
+ final Current<QName, UnionSpecification> stmt,
+ final ImmutableList<? extends EffectiveStatement<?, ?>> substatements) {
+ if (substatements.isEmpty()) {
+ throw noType(stmt);
+ }
- @Override
- protected EffectiveStatement<String, UnionSpecification> createEffective(
- final StmtContext<String, UnionSpecification, EffectiveStatement<String, UnionSpecification>> ctx,
- final UnionSpecification declared, final ImmutableList<? extends EffectiveStatement<?, ?>> substatements) {
- final UnionTypeBuilder builder = BaseTypes.unionTypeBuilder(ctx.getSchemaPath().get());
+ final UnionTypeBuilder builder = BaseTypes.unionTypeBuilder(stmt.argumentAsTypeQName());
- for (final EffectiveStatement<?, ?> stmt : substatements) {
- if (stmt instanceof TypeEffectiveStatement) {
- builder.addType(((TypeEffectiveStatement<?>)stmt).getTypeDefinition());
+ for (final EffectiveStatement<?, ?> subStmt : substatements) {
+ if (subStmt instanceof TypeEffectiveStatement) {
+ builder.addType(((TypeEffectiveStatement<?>)subStmt).getTypeDefinition());
}
}
- return new TypeEffectiveStatementImpl<>(declared, substatements, builder);
- }
-
- @Override
- protected EffectiveStatement<String, UnionSpecification> createEmptyEffective(
- final StmtContext<String, UnionSpecification, EffectiveStatement<String, UnionSpecification>> ctx,
- final UnionSpecification declared) {
- throw noType(ctx);
+ return new TypeEffectiveStatementImpl<>(stmt.declared(), substatements, builder);
}
- private static SourceException noType(final StmtContext<?, ?, ?> ctx) {
+ private static SourceException noType(final @NonNull CommonStmtCtx stmt) {
/*
* https://tools.ietf.org/html/rfc7950#section-9.12
*
* 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", ctx.getStatementSourceReference());
+ return new SourceException("At least one type statement has to be present", stmt);
}
}