Bug 2366 - Effective statments impl merge, retest & bugfix
[yangtools.git] / yang / yang-parser-impl / src / main / java / org / opendaylight / yangtools / yang / parser / spi / meta / StmtContext.java
index 5b85dc637720f4570ca90d7bf56cf2236c788906..d46e2716a73a4027fed0685c8425fc31187887d5 100644 (file)
@@ -45,49 +45,62 @@ public interface StmtContext<A, D extends DeclaredStatement<A>, E extends Effect
     @Nullable
     List<Object> getArgumentsFromRoot();
 
-    // <K,VT, V extends VT,N extends IdentifierNamespace<K, V>>
-    // <K, VT, V extends VT ,N extends IdentifierNamespace<K, V>> VT
-    // getFromNamespace(Class<N> type, K key)
+    List<StmtContext<?,?,?>> getStmtContextsFromRoot();
+
     @Nonnull
-    <K, V, N extends IdentifierNamespace<K, V>> V getFromNamespace(
-            Class<N> type, K key) throws NamespaceNotAvailableException;
+    <K, V, KT extends K, N extends IdentifierNamespace<K, V>> V getFromNamespace(
+            Class<N> type, KT key) throws NamespaceNotAvailableException;
 
-    <K, V, N extends IdentifierNamespace<K, V>> Map<?, ?> getAllFromNamespace(
+    <K, V, N extends IdentifierNamespace<K, V>> Map<K, V> getAllFromNamespace(
             Class<N> type);
 
+    <K, V, N extends IdentifierNamespace<K, V>> Map<K, V> getAllFromCurrentStmtCtxNamespace(Class<N> type);
+
     @Nonnull
     StmtContext<?, ?, ?> getRoot();
 
     @Nonnull
     Collection<StatementContextBase<?, ?, ?>> declaredSubstatements();
 
-    public Collection<StatementContextBase<?, ?, ?>> effectiveSubstatements();
+    Collection<StatementContextBase<?, ?, ?>> effectiveSubstatements();
 
     D buildDeclared();
 
     E buildEffective();
 
-    public StatementContextBase<?, ?, ?> createCopy(QNameModule newQNameModule,
+    boolean isSupportedToBuildEffective();
+
+    void setIsSupportedToBuildEffective(boolean isSupportedToBuild);
+
+    Collection<StatementContextBase<?, ?, ?>> getEffectOfStatement();
+
+    void addAsEffectOfStatement(StatementContextBase<?, ?, ?> ctx);
+
+    StatementContextBase<?, ?, ?> createCopy(
+            StatementContextBase<?, ?, ?> newParent, TypeOfCopy typeOfCopy)
+            throws SourceException;
+
+    StatementContextBase<?, ?, ?> createCopy(QNameModule newQNameModule,
             StatementContextBase<?, ?, ?> newParent, TypeOfCopy typeOfCopy)
             throws SourceException;
 
-    public static enum TypeOfCopy {
-        ORIGINAL, ADDED_BY_USES, ADDED_BY_AUGMENTATION
+    enum TypeOfCopy {
+        ORIGINAL, ADDED_BY_USES, ADDED_BY_AUGMENTATION, ADDED_BY_USES_AUGMENTATION
     }
 
-    public TypeOfCopy getTypeOfCopy();
+    TypeOfCopy getTypeOfCopy();
 
-    public void setTypeOfCopy(TypeOfCopy typeOfCopy);
+    void setTypeOfCopy(TypeOfCopy typeOfCopy);
 
-    public StatementContextBase<?, ?, ?> getOriginalCtx();
+    StatementContextBase<?, ?, ?> getOriginalCtx();
 
-    public void setOriginalCtx(StatementContextBase<?, ?, ?> originalCtx);
+    void setOriginalCtx(StatementContextBase<?, ?, ?> originalCtx);
 
-    public boolean isRootContext();
+    boolean isRootContext();
 
-    public void setCompletedPhase(ModelProcessingPhase completedPhase);
+    void setCompletedPhase(ModelProcessingPhase completedPhase);
 
-    public ModelProcessingPhase getCompletedPhase();
+    ModelProcessingPhase getCompletedPhase();
 
     interface Mutable<A, D extends DeclaredStatement<A>, E extends EffectiveStatement<A, D>>
             extends StmtContext<A, D, E> {
@@ -95,10 +108,8 @@ public interface StmtContext<A, D extends DeclaredStatement<A>, E extends Effect
         @Override
         StmtContext.Mutable<?, ?, ?> getParentContext();
 
-        // <K,V,VT extends V,N extends IdentifierNamespace<K, V>> void
-        // addToNs(Class<N> type, K key, VT value)
-        <K, V, VT extends V, N extends IdentifierNamespace<K, V>> void addToNs(
-                Class<N> type, K key, VT value)
+        <K, V, KT extends K, VT extends V, N extends IdentifierNamespace<K, V>> void addToNs(
+                Class<N> type, KT key, VT value)
                 throws NamespaceNotAvailableException;
 
         @Override