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;fp=runtime%2Forg.argeo.slc.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fcore%2Fexecution%2FProcessThreadGroup.java;h=23d165a4c25066283cc87e4090c703afdceefbb6;hb=9b2422e7198df6f34282a805058dd5f497417318;hp=6f0143f0fcca651847610471a71ab0945e0d1b74;hpb=94f8c90b4eb50398388b6ee2ebb4e19c8abdee01;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 6f0143f0f..23d165a4c 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 @@ -18,6 +18,8 @@ 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; @@ -30,6 +32,11 @@ public class ProcessThreadGroup extends ThreadGroup { private final ExecutionModulesManager executionModulesManager; private final ProcessThread processThread; + private final static Integer STEPS_BUFFER_CAPACITY = 10000; + + private BlockingQueue steps = new ArrayBlockingQueue( + STEPS_BUFFER_CAPACITY); + public ProcessThreadGroup(ExecutionModulesManager executionModulesManager, ProcessThread processThread) { super("SLC Process #" + processThread.getProcess().getUuid() @@ -50,7 +57,8 @@ public class ProcessThreadGroup extends ThreadGroup { List steps = new ArrayList(); steps.add(step); - dispatchAddSteps(steps); + // dispatchAddSteps(steps); + this.steps.add(step); } public void dispatchAddSteps(List steps) { @@ -58,4 +66,8 @@ public class ProcessThreadGroup extends ThreadGroup { executionModulesManager.dispatchAddSteps(slcProcess, steps); } + public BlockingQueue getSteps() { + return steps; + } + }