X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=runtime%2Forg.argeo.slc.support.equinox%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fequinox%2FExecutionCommandProvider.java;h=94ccf2649d54349d9c801edc827b29efccaed8ad;hb=bd07be7603d234ac496652aaa07ded77d4a2a292;hp=c9fe33122cdd2fe2c6ae53cbcc2c473c60f3e50f;hpb=645840383404d5962ca2af85c2020c3d66219518;p=gpl%2Fargeo-slc.git diff --git a/runtime/org.argeo.slc.support.equinox/src/main/java/org/argeo/slc/equinox/ExecutionCommandProvider.java b/runtime/org.argeo.slc.support.equinox/src/main/java/org/argeo/slc/equinox/ExecutionCommandProvider.java index c9fe33122..94ccf2649 100644 --- a/runtime/org.argeo.slc.support.equinox/src/main/java/org/argeo/slc/equinox/ExecutionCommandProvider.java +++ b/runtime/org.argeo.slc.support.equinox/src/main/java/org/argeo/slc/equinox/ExecutionCommandProvider.java @@ -1,5 +1,5 @@ /* - * Copyright (C) 2007-2012 Mathieu Baudier + * 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. @@ -15,87 +15,46 @@ */ package org.argeo.slc.equinox; -import org.apache.commons.logging.Log; -import org.apache.commons.logging.LogFactory; +import java.util.ArrayList; +import java.util.List; + import org.argeo.slc.SlcException; -import org.argeo.slc.execution.RealizedFlow; -import org.argeo.slc.osgi.OsgiExecutionModulesManager; +import org.argeo.slc.execution.SlcAgentCli; import org.eclipse.osgi.framework.console.CommandInterpreter; import org.eclipse.osgi.framework.console.CommandProvider; -@SuppressWarnings("restriction") public class ExecutionCommandProvider implements CommandProvider { - private final static Log log = LogFactory - .getLog(ExecutionCommandProvider.class); - - private final static String SLC_WITH_REFRESH = "slc"; - private final static String SLC_NO_REFRESH = "slcnr"; - - private OsgiExecutionModulesManager modulesManager; + private SlcAgentCli agentCli; - private RealizedFlow lastLaunch = null; + private String lastProcessUuid; public Object _slc(CommandInterpreter ci) { - return exec(SLC_WITH_REFRESH, ci); - } - - public Object _slcnr(CommandInterpreter ci) { - return exec(SLC_NO_REFRESH, ci); - } - - protected Object exec(String slcCommand, CommandInterpreter ci) { - // TODO: check version - String firstArg = ci.nextArgument(); - if (firstArg == null) { - if (lastLaunch != null) { - String cmd = slcCommand + " " + lastLaunch.getModuleName() - + " " + lastLaunch.getFlowDescriptor().getName(); - if (log.isDebugEnabled()) - log.debug("Execute again last command: " + cmd); - return ci.execute(cmd); - } else { - ci.execute("help"); - throw new SlcException("Command not properly formatted"); - } + List args = new ArrayList(); + 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"); } - String executionName = ci.nextArgument(); - - launch(slcCommand, firstArg, executionName); - return "COMMAND COMPLETED"; - } - - protected void launch(String slcCommand, String firstArg, - String executionName) { - lastLaunch = modulesManager.findRealizedFlow(firstArg, executionName); - if (lastLaunch == null) - throw new SlcException("Cannot find launch for " + firstArg + " " - + executionName); - // Execute - if (SLC_WITH_REFRESH.equals(slcCommand)) { - modulesManager.upgrade(lastLaunch.getModuleNameVersion()); - modulesManager.execute(lastLaunch); - } else if (SLC_NO_REFRESH.equals(slcCommand)) - modulesManager.execute(lastLaunch); - else - throw new SlcException("Unrecognized SLC command " + slcCommand); + 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 (|) " - + " - refresh the bundle, execute an execution flow (without arg, execute last)\n"); - buf - .append("\tslcnr (|) " - + " - execute an execution flow (without arg, execute last)\n"); + buf.append("\tslc [[ --arg value | --booleanArg ]]" + + " - executes an execution flow\n"); return buf.toString(); } - public void setModulesManager(OsgiExecutionModulesManager osgiModulesManager) { - this.modulesManager = osgiModulesManager; + public void setAgentCli(SlcAgentCli agentCli) { + this.agentCli = agentCli; } }