package org.opendaylight.yangtools.yang.model.api;
import java.util.Optional;
+import org.eclipse.jdt.annotation.NonNull;
import org.opendaylight.yangtools.concepts.SemVer;
import org.opendaylight.yangtools.yang.common.Revision;
/**
- * Interface describing YANG 'import' statement.
- *
- * <p>
- * The import statement makes definitions from one module available inside another module or submodule.
+ * Interface describing YANG 'import' statement. The import statement makes definitions from one module available inside
+ * another module or submodule.
*/
-// FIXME: 5.0.0 this class is a leak of the declared world into the effective one. In effective world, all nodes form
-// a tree, which consists of multiple (mostly) QName-navigated namespaces. As such module imports contribute
-// only a prefix/QNameModule mapping to the effective world and hence should be mapped that way:
-// - Module exposes String->QNameModule mapping
+// FIXME: 6.0.0: this class is a leak of the declared world into the effective one. In effective world, all nodes form
+// a tree, which consists of multiple (mostly) QName-navigated namespaces. As such module imports
+// contribute only a prefix/QNameModule mapping to the effective world and hence should be mapped that
+// way:
+// - Module exposes String->QNameModule mapping
public interface ModuleImport extends DocumentedNode {
/**
* Returns the name of the module to import.
*
* @return Name of the module to import
*/
- String getModuleName();
+ @NonNull String getModuleName();
/**
* Returns the module revision to import. May be null.
*
* @return Prefix used to point to imported module
*/
- String getPrefix();
+ @NonNull String getPrefix();
}