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=041adefd281be9beea94c234961b80b4935d2c5a;hb=88aeb1cd912d37fcadf671b622fece9a01297e90;hp=00500eaf23d3f51d786d3bbfc92f72df1102a33e;hpb=61f49cd2ff55f24af91c232d3a82ab3f2b565255;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 00500eaf23..041adefd28 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,6 +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.CopyHistory; +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; @@ -64,31 +67,27 @@ public final class AnyxmlStatementSupport } @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); - } + protected AnyxmlEffectiveStatement createEffective(final Current stmt, + final ImmutableList> substatements) { + final int flags = computeFlags(stmt.history(), stmt.effectiveConfig(), substatements); + final SchemaPath path = stmt.getSchemaPath(); - @Override - protected AnyxmlEffectiveStatement createEmptyEffective( - final StmtContext ctx, final AnyxmlStatement declared) { - return new EmptyAnyxmlEffectiveStatement(declared, ctx.getSchemaPath().get(), - computeFlags(ctx, ImmutableList.of()), findOriginal(ctx)); + return substatements.isEmpty() + ? new EmptyAnyxmlEffectiveStatement(stmt.declared(), path, flags, findOriginal(stmt)) + : new RegularAnyxmlEffectiveStatement(stmt.declared(), path, flags, findOriginal(stmt),substatements); } - private static int computeFlags(final StmtContext ctx, - final ImmutableList> substatements) { + private static int computeFlags(final CopyHistory history, final boolean isConfig, + final ImmutableList> substatements) { return new FlagsBuilder() - .setHistory(ctx.getCopyHistory()) + .setHistory(history) .setStatus(findFirstArgument(substatements, StatusEffectiveStatement.class, Status.CURRENT)) - .setConfiguration(ctx.isConfiguration()) + .setConfiguration(isConfig) .setMandatory(findFirstArgument(substatements, MandatoryEffectiveStatement.class, Boolean.FALSE)) .toFlags(); } - 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(); } }