Improve {Action,Notification}NodeContainerCompat safety
[yangtools.git] / yang / yang-model-api / src / main / java / org / opendaylight / yangtools / yang / model / api / stmt / IdentityStatement.java
index 07b61c5858a0b1a821cfd2bcad55fddc04ef7e87..7a2ff3c1c23d46b8f13d7caac04773133bad8733 100644 (file)
@@ -7,15 +7,32 @@
  */
 package org.opendaylight.yangtools.yang.model.api.stmt;
 
-import javax.annotation.Nonnull;
-import javax.annotation.Nullable;
-import org.opendaylight.yangtools.yang.common.QName;
-import org.opendaylight.yangtools.yang.model.api.meta.DeclaredStatement;
+import static com.google.common.base.Verify.verifyNotNull;
 
-public interface IdentityStatement extends DeclaredStatement<QName>, DocumentationGroup.WithStatus {
+import java.util.Collection;
+import org.eclipse.jdt.annotation.NonNull;
+import org.opendaylight.yangtools.yang.common.QName;
+import org.opendaylight.yangtools.yang.model.api.YangStmtMapping;
+import org.opendaylight.yangtools.yang.model.api.meta.StatementDefinition;
 
-    @Nonnull String getName();
+public interface IdentityStatement extends DocumentedDeclaredStatement.WithStatus<QName>,
+        IfFeatureAwareDeclaredStatement<QName> {
+    @Override
+    default StatementDefinition statementDefinition() {
+        return YangStmtMapping.IDENTITY;
+    }
 
-    @Nullable BaseStatement getBase();
+    default @NonNull QName getName() {
+        // FIXME: YANGTOOLS-908: verifyNotNull() should not be needed here
+        return verifyNotNull(argument());
+    }
 
+    /**
+     * Returns the base identities of this identity.
+     *
+     * @return base identities, empty if there are none.
+     */
+    default @NonNull Collection<? extends BaseStatement> getBases() {
+        return declaredSubstatements(BaseStatement.class);
+    }
 }