]> 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 1dc91bf5d59558af6dde216a5878744cd5ffbfb2..01f11012fba228d8b49200020e5fea9c8a632db4 100644 (file)
@@ -1,3 +1,18 @@
+/*
+ * 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.core.execution.tasks;
 
 import java.io.File;
@@ -14,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>();
 
@@ -30,7 +47,7 @@ public class JvmProcess extends SystemCall implements InitializingBean {
        public void afterPropertiesSet() throws Exception {
                List<Object> command = new ArrayList<Object>();
                if (jvm != null)
-                       command.add(asFile(jvm).getAbsolutePath());
+                       command.add(asFile(jvm).getPath());
                else
                        command.add("java");
 
@@ -52,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
@@ -97,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);
@@ -108,7 +134,7 @@ public class JvmProcess extends SystemCall implements InitializingBean {
 
        protected File asFile(Resource res) {
                try {
-                       return res.getFile().getCanonicalFile();
+                       return res.getFile();
                } catch (FileNotFoundException e) {
                        return copyToTempFile(res);
                } catch (IOException e) {
@@ -132,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;
        }
@@ -172,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;
        }