X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=runtime%2Forg.argeo.slc.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fcore%2Fexecution%2FAbstractExecutionModulesManager.java;h=06c05248b2f3c82ec3c25fa89c17ac719937e6d8;hb=3781dcd363f0f6265fae0ac758fd40cf4254ebc9;hp=76d523bf8105f91ae2a149c579139ebe6a85c0d1;hpb=c092f2c4564f7238f2960bc005c5a2202732f44e;p=gpl%2Fargeo-slc.git diff --git a/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/AbstractExecutionModulesManager.java b/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/AbstractExecutionModulesManager.java index 76d523bf8..06c05248b 100644 --- a/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/AbstractExecutionModulesManager.java +++ b/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/AbstractExecutionModulesManager.java @@ -1,6 +1,23 @@ +/* + * Copyright (C) 2010 Mathieu Baudier + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + package org.argeo.slc.core.execution; import java.util.ArrayList; +import java.util.Iterator; import java.util.List; import java.util.Map; @@ -9,19 +26,20 @@ import org.apache.commons.logging.LogFactory; import org.argeo.slc.execution.ExecutionContext; import org.argeo.slc.execution.ExecutionFlow; import org.argeo.slc.execution.ExecutionFlowDescriptorConverter; -import org.argeo.slc.execution.ExecutionModulesListener; import org.argeo.slc.execution.ExecutionModulesManager; +import org.argeo.slc.execution.ExecutionProcess; import org.argeo.slc.process.RealizedFlow; -import org.argeo.slc.process.SlcExecution; import org.argeo.slc.process.SlcExecutionNotifier; +import org.argeo.slc.process.SlcExecutionStep; +/** Provides the base feature of an execution module manager. */ +@SuppressWarnings("deprecation") public abstract class AbstractExecutionModulesManager implements ExecutionModulesManager { private final static Log log = LogFactory .getLog(AbstractExecutionModulesManager.class); private List slcExecutionNotifiers = new ArrayList(); - private List executionModulesListeners = new ArrayList(); private ThreadGroup processesThreadGroup = new ThreadGroup("Processes"); @@ -34,10 +52,6 @@ public abstract class AbstractExecutionModulesManager implements protected abstract ExecutionFlowDescriptorConverter getExecutionFlowDescriptorConverter( String moduleName, String moduleVersion); - public void process(SlcExecution slcExecution) { - new ProcessThread(this, slcExecution).start(); - } - public void execute(RealizedFlow realizedFlow) { if (log.isTraceEnabled()) log.trace("Executing " + realizedFlow); @@ -65,6 +79,24 @@ public abstract class AbstractExecutionModulesManager implements // } + public void dispatchUpdateStatus(ExecutionProcess slcExecution, + String oldStatus, String newStatus) { + for (Iterator it = getSlcExecutionNotifiers() + .iterator(); it.hasNext();) { + it.next().updateStatus(slcExecution, oldStatus, newStatus); + } + } + + public void dispatchAddStep(ExecutionProcess slcExecution, + SlcExecutionStep step) { + List steps = new ArrayList(); + steps.add(step); + for (Iterator it = getSlcExecutionNotifiers() + .iterator(); it.hasNext();) { + it.next().addSteps(slcExecution, steps); + } + } + public void setSlcExecutionNotifiers( List slcExecutionNotifiers) { this.slcExecutionNotifiers = slcExecutionNotifiers; @@ -78,13 +110,4 @@ public abstract class AbstractExecutionModulesManager implements return processesThreadGroup; } - public List getExecutionModulesListeners() { - return executionModulesListeners; - } - - public void setExecutionModulesListeners( - List executionModulesListeners) { - this.executionModulesListeners = executionModulesListeners; - } - }