summaryrefslogtreecommitdiff
path: root/src/main/java/org
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/org')
-rw-r--r--src/main/java/org/apache/maven/plugin/nar/NarGnuConfigureMojo.java46
-rw-r--r--src/main/java/org/apache/maven/plugin/nar/NarGnuMakeMojo.java13
2 files changed, 47 insertions, 12 deletions
diff --git a/src/main/java/org/apache/maven/plugin/nar/NarGnuConfigureMojo.java b/src/main/java/org/apache/maven/plugin/nar/NarGnuConfigureMojo.java
index 2f32094..082a9f5 100644
--- a/src/main/java/org/apache/maven/plugin/nar/NarGnuConfigureMojo.java
+++ b/src/main/java/org/apache/maven/plugin/nar/NarGnuConfigureMojo.java
@@ -43,10 +43,18 @@ public class NarGnuConfigureMojo
* @parameter expression="${nar.gnu.autogen.skip}" default-value="false"
*/
private boolean gnuAutogenSkip;
-
- private static String autogen = "autogen.sh";
- private static String configure = "configure";
-
+
+ /**
+ * Skip running of configure and therefore also autogen.sh
+ *
+ * @parameter expression="${nar.gnu.configure.skip}" default-value="false"
+ */
+ private boolean gnuConfigureSkip;
+
+ private static final String AUTOGEN = "autogen.sh";
+
+ private static final String CONFIGURE = "configure";
+
public void execute()
throws MojoExecutionException, MojoFailureException
{
@@ -68,14 +76,32 @@ public class NarGnuConfigureMojo
throw new MojoExecutionException( "Failed to copy GNU sources", e );
}
- if ((!gnuAutogenSkip) && new File(targetDir, "autogen.sh").exists()) {
- getLog().info( "Running GNU "+autogen );
- NarUtil.runCommand( "sh ./"+autogen, null, targetDir, null, getLog() );
+ File autogen = new File( targetDir, AUTOGEN );
+ if ( !gnuConfigureSkip && !gnuAutogenSkip && autogen.exists() )
+ {
+ getLog().info( "Running GNU " + AUTOGEN );
+ NarUtil.makeExecutable( autogen, getLog() );
+ int result = NarUtil.runCommand( "./" + autogen.getName(), null, targetDir, null, getLog() );
+ if ( result != 0 )
+ {
+ System.err.println( targetDir );
+ throw new MojoExecutionException( "'"+AUTOGEN+"' errorcode: " + result );
+ }
}
- getLog().info( "Running GNU "+configure );
- NarUtil.runCommand( "sh ./"+configure, new String[] { "--disable-ccache", "--prefix="
- + getGnuAOLTargetDirectory().getAbsolutePath() }, targetDir, null, getLog() );
+ File configure = new File( targetDir, CONFIGURE );
+ if ( !gnuConfigureSkip && configure.exists() )
+ {
+ getLog().info( "Running GNU " + CONFIGURE );
+ NarUtil.makeExecutable( configure, getLog() );
+ int result =
+ NarUtil.runCommand( "./" + configure.getName(), new String[] { "--disable-ccache",
+ "--prefix=" + getGnuAOLTargetDirectory().getAbsolutePath() }, targetDir, null, getLog() );
+ if ( result != 0 )
+ {
+ throw new MojoExecutionException( "'"+CONFIGURE+"' errorcode: " + result );
+ }
+ }
}
}
}
diff --git a/src/main/java/org/apache/maven/plugin/nar/NarGnuMakeMojo.java b/src/main/java/org/apache/maven/plugin/nar/NarGnuMakeMojo.java
index e04e3a9..f7b2f48 100644
--- a/src/main/java/org/apache/maven/plugin/nar/NarGnuMakeMojo.java
+++ b/src/main/java/org/apache/maven/plugin/nar/NarGnuMakeMojo.java
@@ -45,8 +45,17 @@ public class NarGnuMakeMojo
if ( srcDir.exists() )
{
getLog().info( "Running GNU make" );
- NarUtil.runCommand( "make", null, srcDir, null, getLog() );
- NarUtil.runCommand( "make", new String[] { "install" }, srcDir, null, getLog() );
+ int result = NarUtil.runCommand( "make", null, srcDir, null, getLog() );
+ if ( result != 0 )
+ {
+ throw new MojoExecutionException( "'make' errorcode: " + result );
+ }
+
+ result = NarUtil.runCommand( "make", new String[] { "install" }, srcDir, null, getLog() );
+ if ( result != 0 )
+ {
+ throw new MojoExecutionException( "'make install' errorcode: " + result );
+ }
}
}
}