import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext.TypeOfCopy;
import org.opendaylight.yangtools.yang.parser.stmt.rfc6020.Utils;
-public class UnknownEffectiveStatementImpl extends EffectiveStatementBase<QName, UnknownStatement<QName>> implements
+public class UnknownEffectiveStatementImpl extends EffectiveStatementBase<String, UnknownStatement<String>> implements
UnknownSchemaNode {
private boolean augmenting;
private boolean addedByUses;
private UnknownSchemaNode original;
- private final QName qName;
+ private QName maybeQNameArgument;
private final SchemaPath path;
private ExtensionDefinition extension;
private String description;
private QName nodeType;
private final String nodeParameter;
- public UnknownEffectiveStatementImpl(final StmtContext<QName, UnknownStatement<QName>, ?> ctx) {
+ public UnknownEffectiveStatementImpl(final StmtContext<String, UnknownStatement<String>, ?> ctx) {
super(ctx);
final StmtContext<?, ExtensionStatement, EffectiveStatement<QName, ExtensionStatement>> extensionInit = ctx
extension = (ExtensionEffectiveStatementImpl) extensionInit.buildEffective();
nodeType = extension.getQName();
}
+
+ List<TypeOfCopy> copyTypesFromOriginal = ctx.getCopyHistory();
- qName = ctx.getStatementArgument();
- path = Utils.getSchemaPath(ctx);
+ if (copyTypesFromOriginal.contains(TypeOfCopy.ADDED_BY_AUGMENTATION)) {
+ augmenting = true;
+ }
+ if (copyTypesFromOriginal.contains(TypeOfCopy.ADDED_BY_USES)) {
+ addedByUses = true;
+ }
+ if (copyTypesFromOriginal.contains(TypeOfCopy.ADDED_BY_USES_AUGMENTATION)) {
+ addedByUses = augmenting = true;
+ }
+ if (ctx.getOriginalCtx() != null) {
+ original = (UnknownSchemaNode) ctx.getOriginalCtx().buildEffective();
+ }
+
+ // FIXME: Remove following section after fixing 4380
+ if(original != null) {
+ maybeQNameArgument = original.getQName();
+ } else {
+ try {
+ maybeQNameArgument = Utils.qNameFromArgument(ctx, argument());
+ } catch (IllegalArgumentException e) {
+ maybeQNameArgument = nodeType;
+ }
+ }
+ path = Utils.getSchemaPath(ctx.getParentContext()).createChild(maybeQNameArgument);
nodeParameter = (ctx.rawStatementArgument() == null) ? "" : ctx.rawStatementArgument();
// TODO init other fields (see Bug1412Test)
unknownNodes.add((UnknownEffectiveStatementImpl) effectiveStatement);
}
}
-
- initCopyType(ctx);
}
- private void initCopyType(final StmtContext<QName, UnknownStatement<QName>, ?> ctx) {
-
- List<TypeOfCopy> copyTypesFromOriginal = ctx.getCopyHistory();
-
- if (copyTypesFromOriginal.contains(TypeOfCopy.ADDED_BY_AUGMENTATION)) {
- augmenting = true;
- }
- if (copyTypesFromOriginal.contains(TypeOfCopy.ADDED_BY_USES)) {
- addedByUses = true;
- }
- if (copyTypesFromOriginal.contains(TypeOfCopy.ADDED_BY_USES_AUGMENTATION)) {
- addedByUses = augmenting = true;
- }
-
- if (ctx.getOriginalCtx() != null) {
- original = (UnknownSchemaNode) ctx.getOriginalCtx().buildEffective();
- }
- }
@Override
public QName getNodeType() {
@Override
public QName getQName() {
- return qName;
+ return maybeQNameArgument;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
- result = prime * result + Objects.hashCode(qName);
+ result = prime * result + Objects.hashCode(maybeQNameArgument);
result = prime * result + Objects.hashCode(path);
result = prime * result + Objects.hashCode(nodeType);
result = prime * result + Objects.hashCode(nodeParameter);
return false;
}
UnknownEffectiveStatementImpl other = (UnknownEffectiveStatementImpl) obj;
- if (!Objects.equals(qName, other.qName)) {
+ if (!Objects.equals(maybeQNameArgument, other.maybeQNameArgument)) {
return false;
}
if (!Objects.equals(path, other.path)) {