]> git.argeo.org Git - gpl/argeo-slc.git/blobdiff - runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/tasks/JvmProcess.java
Improve RunInOSGi command
[gpl/argeo-slc.git] / runtime / org.argeo.slc.core / src / main / java / org / argeo / slc / core / execution / tasks / JvmProcess.java
index 037b7ff4f67bc7a343ae6bd54d0e4ed260aa7583..01f11012fba228d8b49200020e5fea9c8a632db4 100644 (file)
@@ -29,12 +29,14 @@ import org.argeo.slc.SlcException;
 import org.springframework.beans.factory.InitializingBean;
 import org.springframework.core.io.Resource;
 
+/** A Java Virtual Machine process. */
 public class JvmProcess extends SystemCall implements InitializingBean {
        private Properties systemProperties = new Properties();
        private List<Resource> classpath = new ArrayList<Resource>();
        private List<Resource> pBootClasspath = new ArrayList<Resource>();
        private Resource jvm = null;
        private String mainClass;
+       private String mainJar;
        private List<String> jvmArgs = new ArrayList<String>();
        private List<String> args = new ArrayList<String>();
 
@@ -67,14 +69,16 @@ public class JvmProcess extends SystemCall implements InitializingBean {
                        command.add(jvmArg);
                }
 
-               command.add("-cp");
-               StringBuffer buf = new StringBuffer("");
-               for (Resource res : classpath) {
-                       if (buf.length() != 0)
-                               buf.append(File.pathSeparatorChar);
-                       buf.append(asFile(res));
+               if (classpath.size() > 0) {
+                       command.add("-cp");
+                       StringBuffer buf = new StringBuffer("");
+                       for (Resource res : classpath) {
+                               if (buf.length() != 0)
+                                       buf.append(File.pathSeparatorChar);
+                               buf.append(asFile(res));
+                       }
+                       command.add(buf.toString());
                }
-               command.add(buf.toString());
 
                if (systemPropertiesFileProperty == null) {
                        // pass system properties as argument
@@ -112,7 +116,14 @@ public class JvmProcess extends SystemCall implements InitializingBean {
                }
 
                // Program
-               command.add(mainClass);
+               if (mainClass != null) {
+                       command.add(mainClass);
+               } else if (mainJar != null) {
+                       command.add("-jar");
+                       command.add(mainJar);
+               } else {
+                       throw new SlcException("No main class or jar defined");
+               }
 
                for (String arg : args) {
                        command.add(arg);
@@ -147,6 +158,21 @@ public class JvmProcess extends SystemCall implements InitializingBean {
                return tempFile;
        }
 
+       /** Append the argument (for chaining) */
+       @Override
+       public SystemCall arg(String arg) {
+               args.add(arg);
+               return this;
+       }
+
+       /** Append the argument (for chaining) */
+       @Override
+       public SystemCall arg(String arg, String value) {
+               args.add(arg);
+               args.add(value);
+               return this;
+       }
+
        public Properties getSystemProperties() {
                return systemProperties;
        }
@@ -187,6 +213,14 @@ public class JvmProcess extends SystemCall implements InitializingBean {
                this.mainClass = mainClass;
        }
 
+       public String getMainJar() {
+               return mainJar;
+       }
+
+       public void setMainJar(String mainJar) {
+               this.mainJar = mainJar;
+       }
+
        public List<String> getJvmArgs() {
                return jvmArgs;
        }