+ // FIXME: hack to let the SlcExecution be registered on server
+ try {
+ Thread.sleep(500);
+ } catch (InterruptedException e1) {
+ // silent
+ }
+
+ slcExecution.setStatus(SlcExecution.STATUS_RUNNING);
+ dispatchUpdateStatus(slcExecution, SlcExecution.STATUS_SCHEDULED,
+ SlcExecution.STATUS_RUNNING);
+
+ flowsToProcess.addAll(slcExecution.getRealizedFlows());
+
+ while (flowsToProcess.size() > 0) {
+ RealizedFlow flow = flowsToProcess.remove(0);
+ ExecutionModule module = getExecutionModule(flow
+ .getModuleName(), flow.getModuleVersion());
+ if (module != null) {
+ ExecutionThread thread = new ExecutionThread(this, flow
+ .getFlowDescriptor(), module);
+ thread.start();
+ } else {
+ throw new SlcException("ExecutionModule "
+ + flow.getModuleName() + ", version "
+ + flow.getModuleVersion() + " not found.");
+ }
+
+ synchronized (this) {
+ try {
+ wait();
+ } catch (InterruptedException e) {
+ // silent
+ }
+ }
+ }
+
+ slcExecution.setStatus(SlcExecution.STATUS_RUNNING);
+ dispatchUpdateStatus(slcExecution, SlcExecution.STATUS_RUNNING,
+ SlcExecution.STATUS_FINISHED);
+ /*
+ * for (RealizedFlow flow : slcExecution.getRealizedFlows()) {
+ * ExecutionModule module = getExecutionModule(flow.getModuleName(),
+ * flow.getModuleVersion()); if (module != null) { ExecutionThread
+ * thread = new ExecutionThread(flow .getFlowDescriptor(), module);
+ * thread.start(); } else { throw new
+ * SlcException("ExecutionModule " + flow.getModuleName() +
+ * ", version " + flow.getModuleVersion() + " not found."); } }
+ */
+ }
+
+ public synchronized void flowCompleted() {
+ notifyAll();
+ }