diff options
author | rfeng <rfeng@13f79535-47bb-0310-9956-ffa450edef68> | 2011-09-20 22:13:53 +0000 |
---|---|---|
committer | rfeng <rfeng@13f79535-47bb-0310-9956-ffa450edef68> | 2011-09-20 22:13:53 +0000 |
commit | ebcc293bfbc009011ac4fe2462d729cb0fba9e51 (patch) | |
tree | 9ad8a28226fcfb8b968f256b136c4a10a0857e79 /sca-java-2.x/trunk/maven | |
parent | 792e596a1a75c5f246a4e314fba20947e18640e1 (diff) |
Add a Mojo to generate node diagram
git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@1173407 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'sca-java-2.x/trunk/maven')
-rw-r--r-- | sca-java-2.x/trunk/maven/tuscany-diagram-plugin/src/main/java/org/apache/tuscany/sca/diagram/maven/plugin/CompositeDiagramMojo.java (renamed from sca-java-2.x/trunk/maven/tuscany-diagram-plugin/src/main/java/org/apache/tuscany/sca/diagram/maven/plugin/TuscanyDiagramMojo.java) | 17 | ||||
-rw-r--r-- | sca-java-2.x/trunk/maven/tuscany-diagram-plugin/src/main/java/org/apache/tuscany/sca/diagram/maven/plugin/NodeDiagramMojo.java | 180 |
2 files changed, 181 insertions, 16 deletions
diff --git a/sca-java-2.x/trunk/maven/tuscany-diagram-plugin/src/main/java/org/apache/tuscany/sca/diagram/maven/plugin/TuscanyDiagramMojo.java b/sca-java-2.x/trunk/maven/tuscany-diagram-plugin/src/main/java/org/apache/tuscany/sca/diagram/maven/plugin/CompositeDiagramMojo.java index c0cc6adeb0..191908b575 100644 --- a/sca-java-2.x/trunk/maven/tuscany-diagram-plugin/src/main/java/org/apache/tuscany/sca/diagram/maven/plugin/TuscanyDiagramMojo.java +++ b/sca-java-2.x/trunk/maven/tuscany-diagram-plugin/src/main/java/org/apache/tuscany/sca/diagram/maven/plugin/CompositeDiagramMojo.java @@ -27,7 +27,6 @@ import java.util.List; import org.apache.maven.plugin.AbstractMojo; import org.apache.maven.plugin.MojoExecutionException; import org.apache.maven.plugin.MojoFailureException; -import org.apache.maven.project.MavenProject; /** * Maven Mojo to generate the diagrams for SCA composites @@ -38,21 +37,7 @@ import org.apache.maven.project.MavenProject; * @phase generate-sources * @description */ -public class TuscanyDiagramMojo extends AbstractMojo { - - /** - * The maven project. - * - * @parameter expression="${project}" - * @required - * @readonly - */ - private MavenProject project; - - /** - * @parameter expression="${contributions}" - */ - private File[] contributions; +public class CompositeDiagramMojo extends AbstractMojo { /** * @parameter expression="${composites}" diff --git a/sca-java-2.x/trunk/maven/tuscany-diagram-plugin/src/main/java/org/apache/tuscany/sca/diagram/maven/plugin/NodeDiagramMojo.java b/sca-java-2.x/trunk/maven/tuscany-diagram-plugin/src/main/java/org/apache/tuscany/sca/diagram/maven/plugin/NodeDiagramMojo.java new file mode 100644 index 0000000000..78ae2de132 --- /dev/null +++ b/sca-java-2.x/trunk/maven/tuscany-diagram-plugin/src/main/java/org/apache/tuscany/sca/diagram/maven/plugin/NodeDiagramMojo.java @@ -0,0 +1,180 @@ +/* + * 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.sca.diagram.maven.plugin; + +import java.io.File; +import java.io.FileFilter; +import java.io.FileInputStream; +import java.io.FileWriter; +import java.io.IOException; +import java.net.URL; +import java.net.URLClassLoader; +import java.util.ArrayList; +import java.util.List; + +import org.apache.maven.plugin.AbstractMojo; +import org.apache.maven.plugin.MojoExecutionException; +import org.apache.maven.plugin.MojoFailureException; +import org.apache.maven.project.MavenProject; +import org.apache.tuscany.sca.node.NodeFactory; +import org.apache.tuscany.sca.node.configuration.NodeConfiguration; + +/** + * Maven Mojo to generate the diagrams for Tuscany Node + * + * + * @goal generateNodeDiagram + * @requiresDependencyResolution runtime + * @phase process-classes + * @description + */ +public class NodeDiagramMojo extends AbstractMojo { + + /** + * The maven project. + * + * @parameter expression="${project}" + * @required + * @readonly + */ + private MavenProject project; + + /** + * @parameter expression="${project.build.directory}/composite-diagrams" + */ + private File outputDirectory; + + /** + * @parameter The node.xml + */ + private File nodeConfiguration; + + /** + * @parameter expression="${project.build.outputDirectory}" + */ + private File contribution; + + /** + * @parameter expression="${project.runtimeClasspathElements}" + */ + private List<String> runtimeClasspathElements; + + /** + * @parameter The root folder of a web application + */ + private File webApplication; + + /** + * @parameter The base URL for the clickable blocks + */ + private String baseURL; + + /** + * @parameter + */ + private boolean generateSVG = true; + + /** + * @parameter + */ + private boolean generateJPG = false; + + /** + * @parameter + */ + private boolean generateHTML = false; + + public void execute() throws MojoExecutionException, MojoFailureException { + // getLog().info(String.valueOf(runtimeClasspathElements)); + try { + NodeFactory factory = NodeFactory.getInstance(); + NodeConfiguration configuration = null; + if (nodeConfiguration != null) { + getLog().info("Loading node configuration: " + nodeConfiguration); + configuration = + factory + .loadConfiguration(new FileInputStream(nodeConfiguration), nodeConfiguration.toURI().toURL()); + } else if (contribution != null) { + getLog().info("Loading contribution: " + contribution); + configuration = factory.createNodeConfiguration().addContribution(contribution.toURI().toURL()); + } + + URL[] paths = buildClasspath(); + ClassLoader classLoader = new URLClassLoader(paths, Thread.currentThread().getContextClassLoader()); + outputDirectory.mkdirs(); + String svg = org.apache.tuscany.sca.diagram.main.Main.generateDiagram(configuration, classLoader, baseURL); + File svgFile = new File(outputDirectory, "node.svg"); + FileWriter fw = new FileWriter(svgFile); + fw.write(svg); + fw.close(); + } catch (Exception e) { + throw new MojoExecutionException(e.getMessage(), e); + } + + } + + private URL[] buildClasspath() throws IOException { + List<URL> urls = new ArrayList<URL>(); + if (webApplication != null) { + File root = webApplication; + File classes = new File(root, "WEB-INF/classes"); + urls.add(classes.toURI().toURL()); + + File lib = new File(root, "WEB-INF/lib"); + for (File jar : listJarFiles(lib)) { + urls.add(jar.toURI().toURL()); + } + } + for (String path : runtimeClasspathElements) { + urls.add(new File(path).toURI().toURL()); + } + return urls.toArray(new URL[urls.size()]); + } + + private List<File> listJarFiles(File lib) { + List<File> compositeFiles = new ArrayList<File>(); + // getLog().info(compositeDirectory.getAbsolutePath()); + listJarFiles(lib, compositeFiles); + return compositeFiles; + } + + private void listJarFiles(File dir, List<File> files) { + + if (!dir.isDirectory()) { + return; + } + File[] list = dir.listFiles(new FileFilter() { + + @Override + public boolean accept(File pathname) { + return pathname.isFile() && pathname.getName().endsWith(".jar"); + } + }); + + for (File f : list) { + if (f.isFile()) { + files.add(f); + } + // else { + // listJarFiles(f, files); + // } + } + } + +} |