]>
git.argeo.org Git - gpl/argeo-slc.git/blob - maven/maven-argeo-qooxdoo-plugin/src/main/java/org/argeo/slc/maven/plugins/qooxdoo/GenerateMojo.java
1 package org
.argeo
.slc
.maven
.plugins
.qooxdoo
;
5 import org
.apache
.maven
.plugin
.AbstractMojo
;
6 import org
.apache
.maven
.plugin
.MojoExecutionException
;
7 import org
.apache
.maven
.plugin
.MojoFailureException
;
8 import org
.apache
.maven
.plugin
.logging
.Log
;
9 import org
.codehaus
.plexus
.util
.cli
.CommandLineException
;
10 import org
.codehaus
.plexus
.util
.cli
.CommandLineUtils
;
11 import org
.codehaus
.plexus
.util
.cli
.Commandline
;
12 import org
.codehaus
.plexus
.util
.cli
.StreamConsumer
;
15 * Calls Qooxdoo python tool chain
20 public class GenerateMojo
extends AbstractMojo
{
22 * The Qooxdoo build target.
24 * @parameter expression="${job}"
30 * The build directory.
32 * @parameter expression="${project.build.directory}"
35 private File buildDirectory
;
38 * The directory for the pom
40 * @parameter expression="${basedir}"
45 public void execute() throws MojoExecutionException
, MojoFailureException
{
47 // File jythonBase = new File(buildDirectory, "jython");
48 // jythonBase.mkdirs();
49 // System.setProperty("python.home", jythonBase.getCanonicalPath());
51 File generateScript
= new File(baseDir
, "generate.py");
52 // String[] jobArray = jobs.split(" ");
53 // String[] args = new String[jobArray.length + 1];
54 // args[0] = generateScript.getCanonicalPath();
55 // System.arraycopy(jobArray, 0, args, 1, jobArray.length);
56 String
[] args
= { "generate.py", job
};
57 getLog().info("Running Qooxdoo job: " + job
+ " ...");
60 Commandline cl
= new Commandline();
61 cl
.setExecutable("python");
62 cl
.setWorkingDirectory(baseDir
.getCanonicalPath());
63 cl
.createArgument().setValue(generateScript
.getCanonicalPath());
64 cl
.createArgument().setValue(job
);
66 StreamConsumer stdout
= new StdoutConsumer(getLog());
67 StreamConsumer stderr
= new StderrConsumer(getLog());
69 int result
= CommandLineUtils
.executeCommandLine(cl
, stdout
,
72 throw new MojoExecutionException("Qooxdoo job returned: \'"
75 } catch (CommandLineException e
) {
76 throw new MojoExecutionException("Unable to run Qooxdoo job", e
);
78 getLog().info("Finished Qooxdoo job: " + job
);
80 } catch (Exception e
) {
81 throw new MojoExecutionException(
82 "Unexpected exception when running Jython", e
);
88 * Consumer to receive lines sent to stdout. The lines are logged as info.
90 private class StdoutConsumer
implements StreamConsumer
{
91 /** Logger to receive the lines. */
98 * The logger to receive the lines
100 public StdoutConsumer(Log log
) {
108 * The line to consume
110 public void consumeLine(String string
) {
116 * Consumer to receive lines sent to stderr. The lines are logged as
119 private class StderrConsumer
implements StreamConsumer
{
120 /** Logger to receive the lines. */
127 * The logger to receive the lines
129 public StderrConsumer(Log log
) {
137 * The line to consume
139 public void consumeLine(String string
) {