Allow derived context to be reused
[yangtools.git] / yang / yang-parser-spi / src / main / java / org / opendaylight / yangtools / yang / parser / spi / meta / StatementFactory.java
index 793c0e3534fb00b4cf3b97be41942d57486c5646..279e9336965ab8d857723cbdae97557666efaacf 100644 (file)
@@ -37,10 +37,20 @@ public interface StatementFactory<A, D extends DeclaredStatement<A>, E extends E
      * @param stmt Effective capture of this statement's significant state
      * @return An effective statement instance
      */
-    @NonNull E createEffective(EffectiveStmtCtx.@NonNull Current<A, D> stmt,
+    @NonNull E createEffective(@NonNull Current<A, D> stmt,
         Stream<? extends StmtContext<?, ?, ?>> declaredSubstatements,
         Stream<? extends StmtContext<?, ?, ?>> effectiveSubstatements);
 
+    /**
+     * Create a {@link EffectiveStatement} copy of provided original for specified context.
+     *
+     * @param stmt Effective capture of this statement's significant state
+     * @param original Original effective statement
+     * @return An effective statement instance
+     * @throws NullPointerException if any argument is null
+     */
+    @NonNull E copyEffective(@NonNull Current<A, D> stmt, @NonNull E original);
+
     /**
      * Determine reactor copy behaviour of a statement instance. Implementations classes are required to determine
      * their operations with regard to their statements being replicated into different contexts -- potentially sharing
@@ -55,6 +65,7 @@ public interface StatementFactory<A, D extends DeclaredStatement<A>, E extends E
      * @param substatements Current effective substatements
      * @return True if the differences between {@code copy} and {@code current} do not affect this statement's effective
      *         semantics.
+     * @throws NullPointerException if any argument is null
      */
     boolean canReuseCurrent(@NonNull Current<A, D> copy, @NonNull Current<A, D> current,
         @NonNull Collection<? extends EffectiveStatement<?, ?>> substatements);