]> git.argeo.org Git - gpl/argeo-slc.git/blobdiff - runtime/org.argeo.slc.support.equinox/src/main/java/org/argeo/slc/equinox/ExecutionCommandProvider.java
Clean up directories
[gpl/argeo-slc.git] / runtime / org.argeo.slc.support.equinox / src / main / java / org / argeo / slc / equinox / ExecutionCommandProvider.java
index ca49e8fdc6b8db7370f79ed26d0343b2d215c5c3..94ccf2649d54349d9c801edc827b29efccaed8ad 100644 (file)
@@ -1,47 +1,60 @@
+/*
+ * Copyright (C) 2007-2012 Argeo GmbH
+ *
+ * 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.equinox;
 
+import java.util.ArrayList;
 import java.util.List;
 
-import org.argeo.slc.execution.ExecutionModule;
-import org.argeo.slc.process.SlcExecution;
+import org.argeo.slc.SlcException;
+import org.argeo.slc.execution.SlcAgentCli;
 import org.eclipse.osgi.framework.console.CommandInterpreter;
 import org.eclipse.osgi.framework.console.CommandProvider;
 
 public class ExecutionCommandProvider implements CommandProvider {
-       private List<ExecutionModule> executionModules;
-
-       public Object _slc_execute(CommandInterpreter ci) {
-               String moduleName = ci.nextArgument();
-               String executionName = ci.nextArgument();
-               
-               SlcExecution slcExecution = new SlcExecution();
-               slcExecution.getAttributes().put("slc.flows", executionName);
-
-               ExecutionModule module = null;
-               for (ExecutionModule moduleT : executionModules) {
-                       if(moduleT.getName().equals(moduleName)){
-                               // TODO: check version
-                               module = moduleT;
-                               break;
-                       }
+       private SlcAgentCli agentCli;
+
+       private String lastProcessUuid;
+
+       public Object _slc(CommandInterpreter ci) {
+               List<String> args = new ArrayList<String>();
+               String arg = null;
+               while ((arg = ci.nextArgument()) != null)
+                       args.add(arg);
+               if (args.size() == 0) {
+                       // TODO relaunch last process
+                       ci.execute("help");
+                       throw new SlcException("Command not properly formatted");
                }
 
-               if(module!=null)
-                       module.execute(slcExecution);
-               
-               return null;
+               lastProcessUuid = agentCli
+                               .process(args.toArray(new String[args.size()]));
+               return lastProcessUuid;
        }
 
        public String getHelp() {
                StringBuffer buf = new StringBuffer();
                buf.append("---SLC Execution Commands---\n");
-               buf.append("\tslc_execute - Execute an execution flow\n");
+               buf.append("\tslc <module> <flow> [[ --arg value | --booleanArg ]]"
+                               + "  - executes an execution flow\n");
                return buf.toString();
 
        }
 
-       public void setExecutionModules(List<ExecutionModule> executionModules) {
-               this.executionModules = executionModules;
+       public void setAgentCli(SlcAgentCli agentCli) {
+               this.agentCli = agentCli;
        }
 
 }