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=03b72f6052adad7ae80b38ac58c23eb7acd842b0;hb=5fcacdb600e4c9e765cb93b46132932662832c1b;hp=1574b97d6761a1a62318d2a050bf11b1a693aacc;hpb=30f4c6af6c20077e5e36b61faf5edb22c1aae6c6;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 1574b97d6..03b72f605 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 @@ -16,31 +16,61 @@ package org.argeo.slc.core.execution; +import java.util.ArrayList; +import java.util.List; +import java.util.concurrent.ArrayBlockingQueue; +import java.util.concurrent.BlockingQueue; + 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.SlcExecutionStep; /** The thread group attached to a given {@link SlcExecution}. */ +@SuppressWarnings("deprecation") public class ProcessThreadGroup extends ThreadGroup { private final ExecutionModulesManager executionModulesManager; private final ProcessThread processThread; +// private final Authentication authentication; + private final static Integer STEPS_BUFFER_CAPACITY = 5000; + + private BlockingQueue steps = new ArrayBlockingQueue( + STEPS_BUFFER_CAPACITY); public ProcessThreadGroup(ExecutionModulesManager executionModulesManager, ProcessThread processThread) { - super("SLC Process #" + processThread.getSlcProcess().getUuid() + super("SLC Process #" + processThread.getProcess().getUuid() + " thread group"); this.executionModulesManager = executionModulesManager; this.processThread = processThread; +// this.authentication = SecurityContextHolder.getContext() +// .getAuthentication(); + } + +// public Authentication getAuthentication() { +// return authentication; +// } + + public void dispatchAddStep(ExecutionStep step) { + // legacy + ExecutionProcess slcProcess = processThread.getProcess(); + if (slcProcess instanceof SlcExecution) + ((SlcExecution) slcProcess).getSteps().add((SlcExecutionStep) step); + + List steps = new ArrayList(); + steps.add(step); + // dispatchAddSteps(steps); + this.steps.add(step); } - public SlcExecution getSlcProcess() { - return processThread.getSlcProcess(); + public void dispatchAddSteps(List steps) { + ExecutionProcess slcProcess = processThread.getProcess(); + executionModulesManager.dispatchAddSteps(slcProcess, steps); } - public void dispatchAddStep(SlcExecutionStep step) { - SlcExecution slcProcess = processThread.getSlcProcess(); - slcProcess.getSteps().add(step); - executionModulesManager.dispatchAddStep(slcProcess, step); + public BlockingQueue getSteps() { + return steps; } }