X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=runtime%2Forg.argeo.slc.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fcore%2Fexecution%2FProcessThreadGroup.java;h=6f0143f0fcca651847610471a71ab0945e0d1b74;hb=32f9566efa0d0ce29b31ee0779faf2b42f46321a;hp=f7e2bea1c810c500e625bf5aa672014f39e7e69b;hpb=1fdb1b4e7b1d2b0cabb6483238301b857a6392fa;p=gpl%2Fargeo-slc.git diff --git a/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/ProcessThreadGroup.java b/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/ProcessThreadGroup.java index f7e2bea1c..6f0143f0f 100644 --- a/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/ProcessThreadGroup.java +++ b/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/ProcessThreadGroup.java @@ -17,35 +17,45 @@ package org.argeo.slc.core.execution; import java.util.ArrayList; -import java.util.Iterator; import java.util.List; +import org.argeo.slc.execution.ExecutionModulesManager; +import org.argeo.slc.execution.ExecutionProcess; +import org.argeo.slc.execution.ExecutionStep; import org.argeo.slc.process.SlcExecution; -import org.argeo.slc.process.SlcExecutionNotifier; import org.argeo.slc.process.SlcExecutionStep; +/** The thread group attached to a given {@link SlcExecution}. */ public class ProcessThreadGroup extends ThreadGroup { + private final ExecutionModulesManager executionModulesManager; private final ProcessThread processThread; - public ProcessThreadGroup(ProcessThread processThread) { - super("SLC Process #" + processThread.getSlcProcess().getUuid() + public ProcessThreadGroup(ExecutionModulesManager executionModulesManager, + ProcessThread processThread) { + super("SLC Process #" + processThread.getProcess().getUuid() + " thread group"); + this.executionModulesManager = executionModulesManager; this.processThread = processThread; } - public SlcExecution getSlcProcess() { - return processThread.getSlcProcess(); - } + // public SlcExecution getSlcProcess() { + // return processThread.getSlcProcess(); + // } + + public void dispatchAddStep(ExecutionStep step) { + // legacy + ExecutionProcess slcProcess = processThread.getProcess(); + if (slcProcess instanceof SlcExecution) + ((SlcExecution) slcProcess).getSteps().add((SlcExecutionStep) step); - public void dispatchAddStep(SlcExecutionStep step) { - processThread.getSlcProcess().getSteps().add(step); - List steps = new ArrayList(); + List steps = new ArrayList(); steps.add(step); - for (Iterator it = processThread - .getExecutionModulesManager().getSlcExecutionNotifiers() - .iterator(); it.hasNext();) { - it.next().addSteps(processThread.getSlcProcess(), steps); - } + dispatchAddSteps(steps); + } + + public void dispatchAddSteps(List steps) { + ExecutionProcess slcProcess = processThread.getProcess(); + executionModulesManager.dispatchAddSteps(slcProcess, steps); } }