*/
package org.opendaylight.yangtools.yang.parser.rfc7950.stmt.extension;
-import java.util.Objects;
+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.SchemaPath;
import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode;
+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.parser.rfc7950.stmt.UnknownEffectiveStatementBase;
-import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext;
+import org.opendaylight.yangtools.yang.parser.spi.meta.EffectiveStmtCtx.Current;
import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContextUtils;
+import org.opendaylight.yangtools.yang.parser.spi.source.SourceException;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
final class UnrecognizedEffectiveStatementImpl extends UnknownEffectiveStatementBase<String, UnrecognizedStatement>
implements UnrecognizedEffectiveStatement {
+ private static final Logger LOG = LoggerFactory.getLogger(UnrecognizedEffectiveStatementImpl.class);
private final QName maybeQNameArgument;
private final @NonNull SchemaPath path;
- UnrecognizedEffectiveStatementImpl(final StmtContext<String, UnrecognizedStatement, ?> ctx) {
- super(ctx);
+ UnrecognizedEffectiveStatementImpl(final Current<String, UnrecognizedStatement> stmt,
+ final @NonNull ImmutableList<? extends EffectiveStatement<?, ?>> substatements) {
+ super(stmt, substatements);
// FIXME: Remove following section after fixing 4380
- final UnknownSchemaNode original = (UnknownSchemaNode) ctx.getOriginalCtx().map(StmtContext::buildEffective)
- .orElse(null);
+ final UnknownSchemaNode original = (UnknownSchemaNode) stmt.original();
if (original != null) {
this.maybeQNameArgument = original.getQName();
} else {
QName maybeQNameArgumentInit = null;
try {
- maybeQNameArgumentInit = StmtContextUtils.qnameFromArgument(ctx, argument());
- } catch (IllegalArgumentException e) {
+ maybeQNameArgumentInit = StmtContextUtils.qnameFromArgument(stmt.caerbannog(), argument());
+ } catch (SourceException e) {
+ LOG.debug("Not constructing QName from {}", argument(), e);
maybeQNameArgumentInit = getNodeType();
}
this.maybeQNameArgument = maybeQNameArgumentInit;
}
- path = ctx.getParentContext().getSchemaPath().get().createChild(maybeQNameArgument);
+
+ SchemaPath maybePath;
+ try {
+ maybePath = stmt.getParent().schemaPath()
+ .map(parentPath -> parentPath.createChild(maybeQNameArgument)).orElse(null);
+ } catch (IllegalArgumentException | SourceException e) {
+ LOG.debug("Cannot construct path for {}, attempting to recover", stmt, e);
+ maybePath = null;
+ }
+ path = maybePath;
}
@Override
}
@Override
+ @Deprecated
public SchemaPath getPath() {
return path;
}
@Override
- public int hashCode() {
- final int prime = 31;
- int result = 1;
- result = prime * result + Objects.hashCode(maybeQNameArgument);
- result = prime * result + Objects.hashCode(path);
- result = prime * result + Objects.hashCode(getNodeType());
- result = prime * result + Objects.hashCode(getNodeParameter());
- return result;
- }
-
- @Override
- public boolean equals(final Object obj) {
- if (this == obj) {
- return true;
- }
- if (!(obj instanceof UnrecognizedEffectiveStatementImpl)) {
- return false;
- }
- UnrecognizedEffectiveStatementImpl other = (UnrecognizedEffectiveStatementImpl) obj;
- return Objects.equals(maybeQNameArgument, other.maybeQNameArgument) && Objects.equals(path, other.path)
- && Objects.equals(getNodeType(), other.getNodeType())
- && Objects.equals(getNodeParameter(), other.getNodeParameter());
+ public StatementDefinition statementDefinition() {
+ return getDeclared().statementDefinition();
}
}