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%2Fextension%2FUnrecognizedStatementSupport.java;h=57e48075129da1677edfef5c23afa87ec4df1011;hb=refs%2Fchanges%2F88%2F94088%2F7;hp=7ee1ff8262bbf8f8e41b4e7659eb4060d3337146;hpb=deb9fb60870038ede88da04205b2c8b2a5b7dcd1;p=yangtools.git diff --git a/yang/yang-parser-rfc7950/src/main/java/org/opendaylight/yangtools/yang/parser/rfc7950/stmt/extension/UnrecognizedStatementSupport.java b/yang/yang-parser-rfc7950/src/main/java/org/opendaylight/yangtools/yang/parser/rfc7950/stmt/extension/UnrecognizedStatementSupport.java index 7ee1ff8262..57e4807512 100644 --- a/yang/yang-parser-rfc7950/src/main/java/org/opendaylight/yangtools/yang/parser/rfc7950/stmt/extension/UnrecognizedStatementSupport.java +++ b/yang/yang-parser-rfc7950/src/main/java/org/opendaylight/yangtools/yang/parser/rfc7950/stmt/extension/UnrecognizedStatementSupport.java @@ -7,29 +7,36 @@ */ package org.opendaylight.yangtools.yang.parser.rfc7950.stmt.extension; +import static java.util.Objects.requireNonNull; + import com.google.common.collect.ImmutableList; import java.util.Optional; import org.opendaylight.yangtools.yang.common.QName; -import org.opendaylight.yangtools.yang.common.QNameModule; -import org.opendaylight.yangtools.yang.common.UnqualifiedQName; -import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode; import org.opendaylight.yangtools.yang.model.api.meta.ArgumentDefinition; +import org.opendaylight.yangtools.yang.model.api.meta.DeclarationReference; 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.meta.StatementDefinition; -import org.opendaylight.yangtools.yang.model.api.stmt.UnrecognizedEffectiveStatement; import org.opendaylight.yangtools.yang.model.api.stmt.UnrecognizedStatement; +import org.opendaylight.yangtools.yang.model.parser.api.YangParserConfiguration; import org.opendaylight.yangtools.yang.parser.spi.meta.AbstractStatementSupport; import org.opendaylight.yangtools.yang.parser.spi.meta.EffectiveStmtCtx.Current; -import org.opendaylight.yangtools.yang.parser.spi.meta.StatementSupport; +import org.opendaylight.yangtools.yang.parser.spi.meta.InferenceException; +import org.opendaylight.yangtools.yang.parser.spi.meta.OverrideChildStatementSupport; 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.StmtContext.Mutable; import org.opendaylight.yangtools.yang.parser.spi.meta.SubstatementValidator; final class UnrecognizedStatementSupport - extends AbstractStatementSupport { - UnrecognizedStatementSupport(final StatementDefinition publicDefinition) { - super(publicDefinition, StatementPolicy.legacyDeclaredCopy()); + extends AbstractStatementSupport + implements OverrideChildStatementSupport { + private final YangParserConfiguration config; + + UnrecognizedStatementSupport(final StatementDefinition publicDefinition, final YangParserConfiguration config) { + // We have no idea about the statement's semantics, hence there should be noone interested in its semantics. + // Nevertheless it may be of interest for various hacks to understand there was an extension involved. + super(publicDefinition, StatementPolicy.exactReplica(), config); + this.config = requireNonNull(config); } @Override @@ -38,69 +45,54 @@ final class UnrecognizedStatementSupport } @Override - public Optional> getUnknownStatementDefinitionOf( - final StatementDefinition yangStmtDef) { + public UnrecognizedStatementSupport statementDefinitionOverrideOf(final StatementDefinition childDef) { + /* + * This code wraps statements encountered inside an extension so they do not get confused with regular + * statements. + */ final QName baseQName = getStatementName(); - final QName statementName = QName.create(baseQName, yangStmtDef.getStatementName().getLocalName()); + final QName statementName = QName.create(baseQName, childDef.getStatementName().getLocalName()); final ModelDefinedStatementDefinition def; - final Optional optArgDef = yangStmtDef.getArgumentDefinition(); + final Optional optArgDef = childDef.getArgumentDefinition(); if (optArgDef.isPresent()) { final ArgumentDefinition argDef = optArgDef.get(); def = new ModelDefinedStatementDefinition(statementName, argDef.getArgumentName(), argDef.isYinElement()); } else { def = new ModelDefinedStatementDefinition(statementName); } - return Optional.of(new UnrecognizedStatementSupport(def)); + return new UnrecognizedStatementSupport(def, config); } @Override protected SubstatementValidator getSubstatementValidator() { + // We know nothing about this statement return null; } @Override - protected UnrecognizedStatement createDeclared(final StmtContext ctx, + protected UnrecognizedStatement createDeclared(final StmtContext ctx, final ImmutableList> substatements) { return new UnrecognizedStatementImpl(ctx.rawArgument(), ctx.publicDefinition(), substatements); } @Override - protected UnrecognizedStatement createEmptyDeclared(final StmtContext ctx) { - return createDeclared(ctx, ImmutableList.of()); + protected UnrecognizedStatement attachDeclarationReference(final UnrecognizedStatement stmt, + final DeclarationReference reference) { + return new RefUnrecognizedStatement(stmt, reference); } + // createEffective() should never be called, ensure that for each declared statement + @Override - protected UnrecognizedEffectiveStatement createEffective(final Current stmt, - final ImmutableList> substatements) { - // FIXME: Remove following section after fixing 4380 - final UnknownSchemaNode original = (UnknownSchemaNode) stmt.original(); - return new UnrecognizedEffectiveStatementImpl(stmt, substatements, - original == null ? qnameFromArgument(stmt) : original.getQName()); + public void onStatementAdded(final Mutable stmt) { + stmt.setIsSupportedToBuildEffective(false); } - private static QName qnameFromArgument(final Current stmt) { - final String value = stmt.argument(); - if (value == null || value.isEmpty()) { - return stmt.publicDefinition().getStatementName(); - } - - final int colon = value.indexOf(':'); - if (colon == -1) { - final UnqualifiedQName qname = UnqualifiedQName.tryCreate(value); - return qname == null ? null : qname.bindTo(stmt.moduleName().getModule()).intern(); - } - - final QNameModule qnameModule = StmtContextUtils.getModuleQNameByPrefix(stmt.caerbannog(), - value.substring(0, colon)); - if (qnameModule == null) { - return null; - } - - final int next = value.indexOf(':', colon + 1); - final String localName = next == -1 ? value.substring(colon + 1) : value.substring(colon + 1, next); - // Careful: selected string may still not be an identifier - final UnqualifiedQName qname = UnqualifiedQName.tryCreate(localName); - return qname == null ? null : qname.bindTo(qnameModule).intern(); + @Override + protected UnrecognizedEffectiveStatement createEffective(final Current stmt, + final ImmutableList> substatements) { + throw new InferenceException(stmt, "Attempted to instantiate unrecognized effective statement %s", + stmt.publicDefinition()); } } \ No newline at end of file