Merge branch 'master' of ../controller
[yangtools.git] / yang / yang-model-api / src / main / java / org / opendaylight / yangtools / yang / model / api / stmt / DeviationStatement.java
index 1c92c32a0c958952894a1a6dbddd3d8963438aee..adec391fb473a2e123c5e564816acd688f8e6b70 100644 (file)
@@ -7,12 +7,18 @@
  */
 package org.opendaylight.yangtools.yang.model.api.stmt;
 
-import javax.annotation.Nonnull;
-import org.opendaylight.yangtools.yang.model.api.meta.DeclaredStatement;
+import static com.google.common.base.Verify.verifyNotNull;
 
-public interface DeviationStatement extends DeclaredStatement<SchemaNodeIdentifier> {
+import java.util.Collection;
+import org.eclipse.jdt.annotation.NonNull;
 
+public interface DeviationStatement extends DocumentedDeclaredStatement<SchemaNodeIdentifier> {
+    default @NonNull SchemaNodeIdentifier getTargetNode() {
+        // FIXME: YANGTOOLS-908: verifyNotNull() should not be needed here
+        return verifyNotNull(argument());
+    }
 
-    @Nonnull SchemaNodeIdentifier getTargetNode();
-
+    default @NonNull Collection<? extends DeviateStatement> getDeviateStatements() {
+        return declaredSubstatements(DeviateStatement.class);
+    }
 }