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%2Fanyxml%2FAnyxmlStatementSupport.java;h=e78b7e74b8ba07a64eebf16d21004dca7dc96122;hb=1e9cce8bcaaffeecede6dd676c69265650ecdcab;hp=39ceab02da38abe9022ed696e51b2120857dddeb;hpb=ca57ae28c6974bf6c5faa866667e52c8f458e325;p=yangtools.git diff --git a/yang/yang-parser-rfc7950/src/main/java/org/opendaylight/yangtools/yang/parser/rfc7950/stmt/anyxml/AnyxmlStatementSupport.java b/yang/yang-parser-rfc7950/src/main/java/org/opendaylight/yangtools/yang/parser/rfc7950/stmt/anyxml/AnyxmlStatementSupport.java index 39ceab02da..e78b7e74b8 100644 --- a/yang/yang-parser-rfc7950/src/main/java/org/opendaylight/yangtools/yang/parser/rfc7950/stmt/anyxml/AnyxmlStatementSupport.java +++ b/yang/yang-parser-rfc7950/src/main/java/org/opendaylight/yangtools/yang/parser/rfc7950/stmt/anyxml/AnyxmlStatementSupport.java @@ -11,6 +11,7 @@ import com.google.common.collect.ImmutableList; import org.eclipse.jdt.annotation.Nullable; import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.model.api.AnyxmlSchemaNode; +import org.opendaylight.yangtools.yang.model.api.SchemaPath; import org.opendaylight.yangtools.yang.model.api.Status; import org.opendaylight.yangtools.yang.model.api.YangStmtMapping; import org.opendaylight.yangtools.yang.model.api.meta.DeclaredStatement; @@ -21,8 +22,8 @@ import org.opendaylight.yangtools.yang.model.api.stmt.MandatoryEffectiveStatemen import org.opendaylight.yangtools.yang.model.api.stmt.StatusEffectiveStatement; import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.BaseSchemaTreeStatementSupport; import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.EffectiveStatementMixins.EffectiveStatementWithFlags.FlagsBuilder; +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.StmtContextUtils; import org.opendaylight.yangtools.yang.parser.spi.meta.SubstatementValidator; public final class AnyxmlStatementSupport @@ -48,11 +49,6 @@ public final class AnyxmlStatementSupport return INSTANCE; } - @Override - public QName parseArgumentValue(final StmtContext ctx, final String value) { - return StmtContextUtils.parseIdentifier(ctx, value); - } - @Override protected SubstatementValidator getSubstatementValidator() { return SUBSTATEMENT_VALIDATOR; @@ -61,40 +57,31 @@ public final class AnyxmlStatementSupport @Override protected AnyxmlStatement createDeclared(final StmtContext ctx, final ImmutableList> substatements) { - return new RegularAnyxmlStatement(ctx.coerceStatementArgument(), substatements); + return new RegularAnyxmlStatement(ctx.getArgument(), substatements); } @Override protected AnyxmlStatement createEmptyDeclared(final StmtContext ctx) { - return new EmptyAnyxmlStatement(ctx.coerceStatementArgument()); + return new EmptyAnyxmlStatement(ctx.getArgument()); } @Override - protected AnyxmlEffectiveStatement createEffective( - final StmtContext ctx, - final AnyxmlStatement declared, final ImmutableList> substatements) { - return new RegularAnyxmlEffectiveStatement(declared, ctx.getSchemaPath().get(), - computeFlags(ctx, substatements), findOriginal(ctx),substatements); - } - - @Override - protected AnyxmlEffectiveStatement createEmptyEffective( - final StmtContext ctx, final AnyxmlStatement declared) { - return new EmptyAnyxmlEffectiveStatement(declared, ctx.getSchemaPath().get(), - computeFlags(ctx, ImmutableList.of()), findOriginal(ctx)); - } - - private static int computeFlags(final StmtContext ctx, + protected AnyxmlEffectiveStatement createEffective(final Current stmt, final ImmutableList> substatements) { - return new FlagsBuilder() - .setHistory(ctx.getCopyHistory()) - .setStatus(findFirstArgument(substatements, StatusEffectiveStatement.class, Status.CURRENT)) - .setConfiguration(ctx.isConfiguration()) - .setMandatory(findFirstArgument(substatements, MandatoryEffectiveStatement.class, Boolean.FALSE)) - .toFlags(); + final int flags = new FlagsBuilder() + .setHistory(stmt.history()) + .setStatus(findFirstArgument(substatements, StatusEffectiveStatement.class, Status.CURRENT)) + .setConfiguration(stmt.effectiveConfig().asNullable()) + .setMandatory(findFirstArgument(substatements, MandatoryEffectiveStatement.class, Boolean.FALSE)) + .toFlags(); + final SchemaPath path = stmt.wrapSchemaPath(); + + return substatements.isEmpty() + ? new EmptyAnyxmlEffectiveStatement(stmt.declared(), path, flags, findOriginal(stmt)) + : new RegularAnyxmlEffectiveStatement(stmt.declared(), path, flags, findOriginal(stmt),substatements); } - private static @Nullable AnyxmlSchemaNode findOriginal(final StmtContext ctx) { - return (AnyxmlSchemaNode) ctx.getOriginalCtx().map(StmtContext::buildEffective).orElse(null); + private static @Nullable AnyxmlSchemaNode findOriginal(final Current stmt) { + return (AnyxmlSchemaNode) stmt.original(); } }