diff options
Diffstat (limited to '')
2 files changed, 79 insertions, 108 deletions
diff --git a/sca-java-2.x/trunk/maven/maven-tuscany-plugin/src/main/java/org/apache/tuscany/maven/plugin/TuscanyLaunchMojo.java b/sca-java-2.x/trunk/maven/maven-tuscany-plugin/src/main/java/org/apache/tuscany/maven/plugin/TuscanyLaunchMojo.java deleted file mode 100644 index 55b0a51b7f..0000000000 --- a/sca-java-2.x/trunk/maven/maven-tuscany-plugin/src/main/java/org/apache/tuscany/maven/plugin/TuscanyLaunchMojo.java +++ /dev/null @@ -1,108 +0,0 @@ -/*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you 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.apache.tuscany.maven.plugin;
-
-import java.util.ArrayList;
-import java.util.List;
-import java.util.StringTokenizer;
-
-import org.apache.maven.plugin.AbstractMojo;
-import org.apache.maven.plugin.MojoExecutionException;
-import org.apache.maven.plugin.MojoFailureException;
-import org.apache.maven.plugin.logging.Log;
-import org.apache.tuscany.sca.domain.node.DomainNode;
-
-/**
- * Maven Mojo to launch a Tuscany runtime
- * Invoked with mvn org.apache.tuscany.maven.plugin:maven-tuscany-plugin:launch [-Ddomain=tribes:myDomain] -Dcontributions=path\to\scacontribution
- *
- * @goal launch
- * @requiresProject false
- * @requiresDependencyResolution runtime
- */
-public class TuscanyLaunchMojo extends AbstractMojo {
-
- /**
- * @parameter expression="${domain}" default-value="vm:default"
- */
- private String domain;
-
- /**
- * @parameter expression="${contributions}"
- */
- private String contributions;
-
- public void execute() throws MojoExecutionException, MojoFailureException {
-
- if (contributions == null) {
- getLog().info("Missing contributions parameter");
- getLog().info(" use -Dcontributions=<pathToSCAContribution,pathToAnotherContribution...>");
- return;
- }
-
- getLog().info("Launching Tuscany Runtime...");
-
- List<String> cs = new ArrayList<String>();
- StringTokenizer st = new StringTokenizer(contributions, ",");
- while (st.hasMoreTokens()) {
- cs.add(st.nextToken());
- }
-
- DomainNode domainNode = new DomainNode(domain, cs.toArray(new String[cs.size()]));
-
- waitForShutdown(domainNode, getLog());
-
- }
-
- protected void waitForShutdown(DomainNode domainNode, Log log) {
- Runtime.getRuntime().addShutdownHook(new ShutdownThread(domainNode, log));
- synchronized (this) {
- try {
- log.info("Ctrl-C to end...");
- this.wait();
- } catch (InterruptedException e) {
- log.error(e);
- }
- }
- }
-
- protected static class ShutdownThread extends Thread {
-
- private DomainNode domainNode;
- private Log log;
-
- public ShutdownThread(DomainNode domainNode, Log log) {
- super();
- this.domainNode = domainNode;
- this.log = log;
- }
-
- @Override
- public void run() {
- try {
-
- log.info("Stopping Tuscany Runtime...");
- domainNode.stop();
-
- } catch (Exception e) {
- log.error(e);
- }
- }
- }
-}
diff --git a/sca-java-2.x/trunk/maven/maven-tuscany-plugin/src/main/java/org/apache/tuscany/maven/plugin/TuscanyShellMojo.java b/sca-java-2.x/trunk/maven/maven-tuscany-plugin/src/main/java/org/apache/tuscany/maven/plugin/TuscanyShellMojo.java new file mode 100644 index 0000000000..1a9545e551 --- /dev/null +++ b/sca-java-2.x/trunk/maven/maven-tuscany-plugin/src/main/java/org/apache/tuscany/maven/plugin/TuscanyShellMojo.java @@ -0,0 +1,79 @@ +/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you 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.apache.tuscany.maven.plugin;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.util.StringTokenizer;
+
+import org.apache.maven.plugin.AbstractMojo;
+import org.apache.maven.plugin.MojoExecutionException;
+import org.apache.maven.plugin.MojoFailureException;
+import org.apache.tuscany.sca.shell.Shell;
+
+/**
+ * Maven Mojo to run the Tuscany Shell
+ *
+ * Invoked with mvn org.apache.tuscany.maven.plugin:maven-tuscany-plugins:shell [-Ddomain=uri:myDomain] -Dcontributions=path\to\scacontribution,...
+ *
+ * @goal shell
+ * @requiresProject false
+ * @requiresDependencyResolution runtime
+ */
+public class TuscanyShellMojo extends AbstractMojo {
+
+ /**
+ * @parameter expression="${domain}" default-value="default"
+ */
+ private String domain;
+
+ /**
+ * @parameter expression="${contributions}"
+ */
+ private String contributions;
+
+ public void execute() throws MojoExecutionException, MojoFailureException {
+ getLog().info("Starting Tuscany Shell...");
+
+ String[] args;
+ if (contributions != null) {
+ List<String> cs = new ArrayList<String>();
+ StringTokenizer st = new StringTokenizer(contributions, ",");
+ while (st.hasMoreTokens()) {
+ cs.add(st.nextToken());
+ }
+ cs.add(0, domain);
+ args = cs.toArray(new String[cs.size()]);
+ } else {
+ if ("default".equals(domain)) {
+ args = new String[]{};
+ } else {
+ args = new String[]{domain};
+ }
+ }
+
+ try {
+ Shell.main(args);
+ } catch (Exception e) {
+ throw new MojoExecutionException("Exception in Shell", e);
+ }
+
+ getLog().info("Tuscany Shell stopped.");
+ }
+}
|