Bug 7051 - moving of SubstatementValidator into spi.meta package
[yangtools.git] / yang / yang-parser-impl / src / main / java / org / opendaylight / yangtools / yang / parser / stmt / rfc6020 / UnknownStatementImpl.java
index 7b9dccf82805a65fdafd9dff02b09c00df331cd9..48645d8a7ea0a517b69b351e0f813b770458300c 100644 (file)
@@ -7,14 +7,17 @@
  */
 package org.opendaylight.yangtools.yang.parser.stmt.rfc6020;
 
+import java.util.Optional;
 import javax.annotation.Nullable;
+import org.opendaylight.yangtools.yang.common.QName;
 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.UnknownStatement;
 import org.opendaylight.yangtools.yang.parser.spi.meta.AbstractDeclaredStatement;
 import org.opendaylight.yangtools.yang.parser.spi.meta.AbstractStatementSupport;
 import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext;
-import org.opendaylight.yangtools.yang.parser.spi.source.SourceException;
+import org.opendaylight.yangtools.yang.parser.spi.meta.SubstatementValidator;
+import org.opendaylight.yangtools.yang.parser.stmt.reactor.StatementDefinitionContext;
 import org.opendaylight.yangtools.yang.parser.stmt.rfc6020.effective.UnknownEffectiveStatementImpl;
 
 public class UnknownStatementImpl extends AbstractDeclaredStatement<String> implements UnknownStatement<String> {
@@ -23,8 +26,7 @@ public class UnknownStatementImpl extends AbstractDeclaredStatement<String> impl
         super(context);
     }
 
-    public static class Definition
-            extends
+    public static class Definition extends
             AbstractStatementSupport<String, UnknownStatement<String>, EffectiveStatement<String, UnknownStatement<String>>> {
 
         public Definition(final StatementDefinition publicDefinition) {
@@ -32,7 +34,7 @@ public class UnknownStatementImpl extends AbstractDeclaredStatement<String> impl
         }
 
         @Override
-        public String parseArgumentValue(final StmtContext<?, ?, ?> ctx, final String value) throws SourceException {
+        public String parseArgumentValue(final StmtContext<?, ?, ?> ctx, final String value) {
             return value;
         }
 
@@ -46,11 +48,28 @@ public class UnknownStatementImpl extends AbstractDeclaredStatement<String> impl
                 final StmtContext<String, UnknownStatement<String>, EffectiveStatement<String, UnknownStatement<String>>> ctx) {
             return new UnknownEffectiveStatementImpl(ctx);
         }
+
+        @Override
+        protected SubstatementValidator getSubstatementValidator() {
+            return null;
+        }
+
+        @Override
+        public Optional<StatementDefinitionContext<?, ?, ?>> getUnknownStatementDefinitionOf(
+                final StatementDefinitionContext<?, ?, ?> yangStmtDef) {
+            final QName baseQName = getStatementName();
+            return Optional.of(new StatementDefinitionContext<>(
+                    new ModelDefinedStatementSupport(new ModelDefinedStatementDefinition(
+                            QName.create(baseQName, yangStmtDef.getStatementName().getLocalName()),
+                            yangStmtDef.hasArgument()
+                                    ? QName.create(baseQName, yangStmtDef.getArgumentName().getLocalName()) : null,
+                            yangStmtDef.isArgumentYinElement()))));
+        }
     }
 
     @Nullable
     @Override
     public String getArgument() {
-        return rawArgument();
+        return argument();
     }
 }