PR: 383 Submitted by: Brian Deitte <bdeitte@macromedia.com> git-svn-id: https://svn.apache.org/repos/asf/ant/core/trunk@269453 13f79535-47bb-0310-9956-ffa450edef68master
@@ -136,7 +136,8 @@ Other changes: | |||
per <patternset>. | |||
* Two new supported compilers for javac: kjc for kopi and gcj for the | |||
gcc frontend. | |||
gcc frontend. In addition extJavac or the new fork attribute can be | |||
used to run the JDK's javac in a JVM separate from Ant. | |||
* <fixrlf> can now with CR only line-ends and can use an arbitraty | |||
between 2 and 80. | |||
@@ -41,13 +41,17 @@ inclusion/exclusion of files works, and how to write patterns.</p> | |||
<li>kjc (the <a href="http://www.dms.at/kopi/" target="_top">kopi</a> | |||
compiler)</li> | |||
<li>gcj (the gcj compiler from gcc)</li> | |||
<li>extJavac (run either modern or classic in a JVM of its own)</li> | |||
</ul> | |||
<p>For JDK 1.1/1.2, classic is the default. For JDK 1.3, modern is the default. | |||
<p>For JDK 1.1/1.2, classic is the default. For JDK 1.3/1.4, modern is the default. | |||
If you wish to use a different compiler interface than one of the four | |||
supplied, write a class that implements the CompilerAdapter interface | |||
(package org.apache.tools.ant.taskdefs.compilers). Supply the full | |||
classname in the "build.compiler" property. | |||
</p> | |||
<p>The fork attribute overrides the build.compiler setting and expects | |||
a JDK1.1 or higher to be set in java.home. | |||
</p> | |||
<p>This task will drop all entries that point to non-existant | |||
files/directories from the CLASSPATH it passes to the compiler.</p> | |||
<h3>Parameters</h3> | |||
@@ -176,6 +180,12 @@ files/directories from the CLASSPATH it passes to the compiler.</p> | |||
libraries from the executing VM; defaults to <code>no</code>.</td> | |||
<td align="center" valign="top">No</td> | |||
</tr> | |||
<tr> | |||
<td valign="top">fork</td> | |||
<td valign="top">whether to execute Javac using the JDK compiler externally; | |||
defaults to <code>no</code>.</td> | |||
<td align="center" valign="top">No</td> | |||
</tr> | |||
<tr> | |||
<td valign="top">failonerror</td> <td valign="top"> | |||
indicates whether the build will continue even if there are compilation errors; defaults to <code>true</code>. | |||
@@ -114,6 +114,7 @@ public class Javac extends MatchingTask { | |||
private Path extdirs; | |||
private boolean includeAntRuntime = true; | |||
private boolean includeJavaRuntime = false; | |||
private boolean fork = false; | |||
protected boolean failOnError = true; | |||
protected File[] compileList = new File[0]; | |||
@@ -400,6 +401,15 @@ public class Javac extends MatchingTask { | |||
return includeJavaRuntime; | |||
} | |||
/** | |||
* Sets whether to fork the javac compiler. | |||
*/ | |||
public void setFork(boolean fork) | |||
{ | |||
this.fork = fork; | |||
} | |||
/** | |||
* Executes the task. | |||
*/ | |||
@@ -437,7 +447,15 @@ public class Javac extends MatchingTask { | |||
// compile the source files | |||
String compiler = project.getProperty("build.compiler"); | |||
if (compiler == null) { | |||
if (fork) { | |||
if (compiler != null) { | |||
log("Since fork is true, ignoring build.compiler setting.", Project.MSG_WARN); | |||
} | |||
compiler = "extJavac"; | |||
} | |||
if (compiler == null) { | |||
if (Project.getJavaVersion() != Project.JAVA_1_1 && | |||
Project.getJavaVersion() != Project.JAVA_1_2) { | |||
compiler = "modern"; | |||
@@ -100,6 +100,9 @@ public class CompilerAdapterFactory { | |||
if ( compilerType.equalsIgnoreCase("jikes") ) { | |||
return new Jikes(); | |||
} | |||
if ( compilerType.equalsIgnoreCase("extJavac") ) { | |||
return new JavacExternal(); | |||
} | |||
if ( compilerType.equalsIgnoreCase("classic") || | |||
compilerType.equalsIgnoreCase("javac1.1") || | |||
compilerType.equalsIgnoreCase("javac1.2")) { | |||
@@ -201,10 +201,9 @@ public abstract class DefaultCompilerAdapter implements CompilerAdapter { | |||
/** | |||
* Does the command line argument processing common to classic and | |||
* modern. | |||
* modern. Doesn't add the files to compile. | |||
*/ | |||
protected Commandline setupJavacCommand() { | |||
Commandline cmd = new Commandline(); | |||
protected Commandline setupJavacCommandlineSwitches(Commandline cmd) { | |||
Path classpath = getCompileClasspath(); | |||
if (deprecation == true) { | |||
@@ -280,7 +279,16 @@ public abstract class DefaultCompilerAdapter implements CompilerAdapter { | |||
if (verbose) { | |||
cmd.createArgument().setValue("-verbose"); | |||
} | |||
return cmd; | |||
} | |||
/** | |||
* Does the command line argument processing common to classic and | |||
* modern and adds the files to compile as well. | |||
*/ | |||
protected Commandline setupJavacCommand() { | |||
Commandline cmd = new Commandline(); | |||
setupJavacCommandlineSwitches(cmd); | |||
logAndAddFilesToCompile(cmd); | |||
return cmd; | |||
} | |||
@@ -0,0 +1,82 @@ | |||
/* | |||
* The Apache Software License, Version 1.1 | |||
* | |||
* Copyright (c) 2001 The Apache Software Foundation. All rights | |||
* reserved. | |||
* | |||
* Redistribution and use in source and binary forms, with or without | |||
* modification, are permitted provided that the following conditions | |||
* are met: | |||
* | |||
* 1. Redistributions of source code must retain the above copyright | |||
* notice, this list of conditions and the following disclaimer. | |||
* | |||
* 2. Redistributions in binary form must reproduce the above copyright | |||
* notice, this list of conditions and the following disclaimer in | |||
* the documentation and/or other materials provided with the | |||
* distribution. | |||
* | |||
* 3. The end-user documentation included with the redistribution, if | |||
* any, must include the following acknowlegement: | |||
* "This product includes software developed by the | |||
* Apache Software Foundation (http://www.apache.org/)." | |||
* Alternately, this acknowlegement may appear in the software itself, | |||
* if and wherever such third-party acknowlegements normally appear. | |||
* | |||
* 4. The names "The Jakarta Project", "Ant", and "Apache Software | |||
* Foundation" must not be used to endorse or promote products derived | |||
* from this software without prior written permission. For written | |||
* permission, please contact apache@apache.org. | |||
* | |||
* 5. Products derived from this software may not be called "Apache" | |||
* nor may "Apache" appear in their names without prior written | |||
* permission of the Apache Group. | |||
* | |||
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED | |||
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | |||
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |||
* DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR | |||
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | |||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | |||
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF | |||
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | |||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | |||
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT | |||
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | |||
* SUCH DAMAGE. | |||
* ==================================================================== | |||
* | |||
* This software consists of voluntary contributions made by many | |||
* individuals on behalf of the Apache Software Foundation. For more | |||
* information on the Apache Software Foundation, please see | |||
* <http://www.apache.org/>. | |||
*/ | |||
package org.apache.tools.ant.taskdefs.compilers; | |||
import org.apache.tools.ant.BuildException; | |||
import org.apache.tools.ant.Project; | |||
import org.apache.tools.ant.types.*; | |||
/** | |||
* Performs a compile using javac externally. | |||
* | |||
* @author Brian Deitte | |||
*/ | |||
public class JavacExternal extends DefaultCompilerAdapter { | |||
/** | |||
* Performs a compile using the Javac externally. | |||
*/ | |||
public boolean execute() throws BuildException { | |||
attributes.log("Using external javac compiler", Project.MSG_VERBOSE); | |||
Commandline cmd = new Commandline(); | |||
setupJavacCommandlineSwitches(cmd); | |||
int firstFileName = cmd.size(); | |||
logAndAddFilesToCompile(cmd); | |||
return executeExternalCompile(cmd.getCommandline(), firstFileName) == 0; | |||
} | |||
} | |||