summaryrefslogtreecommitdiffstats
path: root/sca-java-2.x/branches/2.0-Beta2/maven/maven-tuscany-plugin/src/main/java/org/apache/tuscany/maven/plugin/TuscanyRunMojo.java
diff options
context:
space:
mode:
Diffstat (limited to 'sca-java-2.x/branches/2.0-Beta2/maven/maven-tuscany-plugin/src/main/java/org/apache/tuscany/maven/plugin/TuscanyRunMojo.java')
-rw-r--r--sca-java-2.x/branches/2.0-Beta2/maven/maven-tuscany-plugin/src/main/java/org/apache/tuscany/maven/plugin/TuscanyRunMojo.java198
1 files changed, 198 insertions, 0 deletions
diff --git a/sca-java-2.x/branches/2.0-Beta2/maven/maven-tuscany-plugin/src/main/java/org/apache/tuscany/maven/plugin/TuscanyRunMojo.java b/sca-java-2.x/branches/2.0-Beta2/maven/maven-tuscany-plugin/src/main/java/org/apache/tuscany/maven/plugin/TuscanyRunMojo.java
new file mode 100644
index 0000000000..ab2eefdf26
--- /dev/null
+++ b/sca-java-2.x/branches/2.0-Beta2/maven/maven-tuscany-plugin/src/main/java/org/apache/tuscany/maven/plugin/TuscanyRunMojo.java
@@ -0,0 +1,198 @@
+/*
+ * 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.io.File;
+import java.net.MalformedURLException;
+import java.util.ArrayList;
+import java.util.List;
+
+import org.apache.maven.artifact.Artifact;
+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.maven.project.MavenProject;
+import org.apache.tuscany.sca.node.Node;
+import org.apache.tuscany.sca.shell.Shell;
+
+/**
+ * Maven Mojo to run the Tuscany Shell and install the project as an SCA contribution.
+ *
+ * Invoked with "mvn tuscany:run"
+ *
+ * @goal run
+ * @requiresDependencyResolution runtime
+ * @execute phase="test-compile"
+ * @description Runs Tuscany directly from a SCA conribution maven project
+ */
+public class TuscanyRunMojo extends AbstractMojo {
+
+ /**
+ * The maven project.
+ *
+ * @parameter expression="${project}"
+ * @required
+ * @readonly
+ */
+ private MavenProject project;
+
+ /**
+ * The project artifactId.
+ *
+ * @parameter expression="${project.artifactId}"
+ * @required
+ */
+ protected String artifactId;
+
+ /**
+ * The project packaging.
+ *
+ * @parameter expression=".${project.packaging}"
+ * @required
+ */
+ protected String packaging;
+
+ /**
+ * The project build output directory
+ *
+ * @parameter expression="${project.build.outputDirectory}"
+ * @required
+ */
+ protected File buildDirectory;
+
+ /**
+ * The project build output directory
+ *
+ * @parameter expression="${project.build.finalName}"
+ * @required
+ */
+ protected File finalName;
+
+ /**
+ * @parameter expression="${config}" default-value="default"
+ */
+ private String config;
+
+ /**
+ * @parameter expression="${contributions}"
+ */
+ private String[] contributions;
+
+ public void execute() throws MojoExecutionException, MojoFailureException {
+ getLog().info("Starting Tuscany Shell...");
+
+ List<String> contributionList = new ArrayList<String>();
+
+ addProjectContribution(contributionList);
+
+ addAdditionalContributions(contributionList);
+
+ contributionList.add(0, "-help");
+ contributionList.add(0, config);
+
+ try {
+ Shell.main(contributionList.toArray(new String[contributionList.size()]));
+ } catch (Exception e) {
+ throw new MojoExecutionException("Exception in Shell", e);
+ }
+
+// waitForShutdown(new Ob, getLog());
+ getLog().info("Tuscany Shell stopped.");
+ }
+
+ private void addAdditionalContributions(List<String> contributionList) throws MojoExecutionException {
+ if (contributions != null) {
+ for (String s : contributions) {
+ if (new File(s).exists()) {
+ contributionList.add(s);
+ } else {
+ boolean found = false;
+ for (Object o : project.getDependencyArtifacts()) {
+ Artifact a = (Artifact) o;
+ if (a.getId().startsWith(s)) {
+ try {
+ contributionList.add(a.getFile().toURI().toURL().toString());
+ } catch (MalformedURLException e) {
+ throw new MojoExecutionException("", e);
+ }
+ found = true;
+ break;
+ }
+ }
+ if (!found) {
+ throw new IllegalArgumentException("Contribution not found as file or dependency: " + s);
+ }
+ }
+ }
+ }
+ }
+
+ protected void addProjectContribution(List<String> cs) throws MojoExecutionException {
+ try {
+
+ File contributionFile = new File(buildDirectory.getParent(), finalName.getName());
+ if (!contributionFile.exists()) {
+ contributionFile = new File(buildDirectory.getParent(), finalName.getName() + packaging);
+ }
+ String contribution = contributionFile.toURI().toURL().toString();
+ getLog().info("Project contribution: " + contribution);
+ cs.add(contribution);
+
+ } catch (MalformedURLException e) {
+ throw new MojoExecutionException("", e);
+ }
+ }
+
+ protected void waitForShutdown(Node node, Log log) {
+ Runtime.getRuntime().addShutdownHook(new ShutdownThread(node, 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 Node node;
+ private Log log;
+
+ public ShutdownThread(Node node, Log log) {
+ super();
+ this.node = node;
+ this.log = log;
+ }
+
+ @Override
+ public void run() {
+ try {
+
+ log.info("Stopping Tuscany Runtime...");
+ node.stop();
+
+ } catch (Exception e) {
+ log.error(e);
+ }
+ }
+ }
+}