X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;ds=sidebyside;f=runtime%2Forg.argeo.slc.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fcore%2Fexecution%2FProcessThread.java;h=1d333845d1e9bb1f7caa4996207b1b5c44533fb4;hb=9b2422e7198df6f34282a805058dd5f497417318;hp=c11e875b8083df0d627c51dba32587360bdfed22;hpb=94f8c90b4eb50398388b6ee2ebb4e19c8abdee01;p=gpl%2Fargeo-slc.git diff --git a/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/ProcessThread.java b/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/ProcessThread.java index c11e875b8..1d333845d 100644 --- a/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/ProcessThread.java +++ b/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/ProcessThread.java @@ -21,12 +21,15 @@ import java.util.Collections; import java.util.HashSet; import java.util.List; import java.util.Set; +import java.util.concurrent.ArrayBlockingQueue; +import java.util.concurrent.BlockingQueue; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.argeo.slc.SlcException; import org.argeo.slc.execution.ExecutionModulesManager; import org.argeo.slc.execution.ExecutionProcess; +import org.argeo.slc.execution.ExecutionStep; import org.argeo.slc.process.RealizedFlow; import org.argeo.slc.process.SlcExecution; @@ -44,6 +47,10 @@ public class ProcessThread extends Thread { private Boolean hadAnError = false; private Boolean killed = false; + private final static Integer STEPS_BUFFER_CAPACITY = 10000; + private BlockingQueue steps = new ArrayBlockingQueue( + STEPS_BUFFER_CAPACITY); + public ProcessThread(ThreadGroup processesThreadGroup, ExecutionModulesManager executionModulesManager, ExecutionProcess process) { @@ -58,6 +65,9 @@ public class ProcessThread extends Thread { log.info("\n##\n## SLC Process #" + process.getUuid() + " STARTED\n##\n"); + // Start logging + new LoggingThread().start(); + String oldStatus = process.getStatus(); process.setStatus(ExecutionProcess.RUNNING); executionModulesManager.dispatchUpdateStatus(process, oldStatus, @@ -170,4 +180,29 @@ public class ProcessThread extends Thread { public ExecutionModulesManager getExecutionModulesManager() { return executionModulesManager; } + + private class LoggingThread extends Thread { + public void run() { + boolean run = true; + while (run) { + List newSteps = new ArrayList(); + processThreadGroup.getSteps().drainTo(newSteps); + if (newSteps.size() > 0) { + //System.out.println(steps.size() + " steps"); + process.addSteps(newSteps); + } + + try { + Thread.sleep(1000); + } catch (InterruptedException e) { + break; + } + + if (!ProcessThread.this.isAlive() + && processThreadGroup.getSteps().size() == 0) + run = false; + } + } + + } }