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>. | per <patternset>. | ||||
| * Two new supported compilers for javac: kjc for kopi and gcj for the | * 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 | * <fixrlf> can now with CR only line-ends and can use an arbitraty | ||||
| between 2 and 80. | 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> | <li>kjc (the <a href="http://www.dms.at/kopi/" target="_top">kopi</a> | ||||
| compiler)</li> | compiler)</li> | ||||
| <li>gcj (the gcj compiler from gcc)</li> | <li>gcj (the gcj compiler from gcc)</li> | ||||
| <li>extJavac (run either modern or classic in a JVM of its own)</li> | |||||
| </ul> | </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 | If you wish to use a different compiler interface than one of the four | ||||
| supplied, write a class that implements the CompilerAdapter interface | supplied, write a class that implements the CompilerAdapter interface | ||||
| (package org.apache.tools.ant.taskdefs.compilers). Supply the full | (package org.apache.tools.ant.taskdefs.compilers). Supply the full | ||||
| classname in the "build.compiler" property. | classname in the "build.compiler" property. | ||||
| </p> | </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 | <p>This task will drop all entries that point to non-existant | ||||
| files/directories from the CLASSPATH it passes to the compiler.</p> | files/directories from the CLASSPATH it passes to the compiler.</p> | ||||
| <h3>Parameters</h3> | <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> | libraries from the executing VM; defaults to <code>no</code>.</td> | ||||
| <td align="center" valign="top">No</td> | <td align="center" valign="top">No</td> | ||||
| </tr> | </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> | <tr> | ||||
| <td valign="top">failonerror</td> <td valign="top"> | <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>. | 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 Path extdirs; | ||||
| private boolean includeAntRuntime = true; | private boolean includeAntRuntime = true; | ||||
| private boolean includeJavaRuntime = false; | private boolean includeJavaRuntime = false; | ||||
| private boolean fork = false; | |||||
| protected boolean failOnError = true; | protected boolean failOnError = true; | ||||
| protected File[] compileList = new File[0]; | protected File[] compileList = new File[0]; | ||||
| @@ -400,6 +401,15 @@ public class Javac extends MatchingTask { | |||||
| return includeJavaRuntime; | return includeJavaRuntime; | ||||
| } | } | ||||
| /** | |||||
| * Sets whether to fork the javac compiler. | |||||
| */ | |||||
| public void setFork(boolean fork) | |||||
| { | |||||
| this.fork = fork; | |||||
| } | |||||
| /** | /** | ||||
| * Executes the task. | * Executes the task. | ||||
| */ | */ | ||||
| @@ -437,7 +447,15 @@ public class Javac extends MatchingTask { | |||||
| // compile the source files | // compile the source files | ||||
| String compiler = project.getProperty("build.compiler"); | 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 && | if (Project.getJavaVersion() != Project.JAVA_1_1 && | ||||
| Project.getJavaVersion() != Project.JAVA_1_2) { | Project.getJavaVersion() != Project.JAVA_1_2) { | ||||
| compiler = "modern"; | compiler = "modern"; | ||||
| @@ -100,6 +100,9 @@ public class CompilerAdapterFactory { | |||||
| if ( compilerType.equalsIgnoreCase("jikes") ) { | if ( compilerType.equalsIgnoreCase("jikes") ) { | ||||
| return new Jikes(); | return new Jikes(); | ||||
| } | } | ||||
| if ( compilerType.equalsIgnoreCase("extJavac") ) { | |||||
| return new JavacExternal(); | |||||
| } | |||||
| if ( compilerType.equalsIgnoreCase("classic") || | if ( compilerType.equalsIgnoreCase("classic") || | ||||
| compilerType.equalsIgnoreCase("javac1.1") || | compilerType.equalsIgnoreCase("javac1.1") || | ||||
| compilerType.equalsIgnoreCase("javac1.2")) { | compilerType.equalsIgnoreCase("javac1.2")) { | ||||
| @@ -201,10 +201,9 @@ public abstract class DefaultCompilerAdapter implements CompilerAdapter { | |||||
| /** | /** | ||||
| * Does the command line argument processing common to classic and | * 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(); | Path classpath = getCompileClasspath(); | ||||
| if (deprecation == true) { | if (deprecation == true) { | ||||
| @@ -280,7 +279,16 @@ public abstract class DefaultCompilerAdapter implements CompilerAdapter { | |||||
| if (verbose) { | if (verbose) { | ||||
| cmd.createArgument().setValue("-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); | logAndAddFilesToCompile(cmd); | ||||
| return 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; | |||||
| } | |||||
| } | |||||