aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorwisberg <wisberg>2003-10-01 05:24:04 +0000
committerwisberg <wisberg>2003-10-01 05:24:04 +0000
commit83b5e4a3a53ef41d14c2e565bdcc742a363ab2f5 (patch)
tree97cf41c6dd6d37ab11b2383d1868d37624c241b3
parente0c8a4875c23cc2443bd309658d8dab3e1f7d070 (diff)
downloadaspectj-83b5e4a3a53ef41d14c2e565bdcc742a363ab2f5.tar.gz
aspectj-83b5e4a3a53ef41d14c2e565bdcc742a363ab2f5.zip
- fix for bugs disclosed by fixes for bug 40807
- added xweavedir attribute for weaving from and to a directory of classes
-rw-r--r--taskdefs/src/org/aspectj/tools/ant/taskdefs/Ajc11CompilerAdapter.java129
-rw-r--r--taskdefs/src/org/aspectj/tools/ant/taskdefs/AjcTask.java87
2 files changed, 130 insertions, 86 deletions
diff --git a/taskdefs/src/org/aspectj/tools/ant/taskdefs/Ajc11CompilerAdapter.java b/taskdefs/src/org/aspectj/tools/ant/taskdefs/Ajc11CompilerAdapter.java
index 77f0afced..bd594c369 100644
--- a/taskdefs/src/org/aspectj/tools/ant/taskdefs/Ajc11CompilerAdapter.java
+++ b/taskdefs/src/org/aspectj/tools/ant/taskdefs/Ajc11CompilerAdapter.java
@@ -10,7 +10,6 @@
* Wes Isberg initial implementation
* ******************************************************************/
-
package org.aspectj.tools.ant.taskdefs;
import org.apache.tools.ant.BuildException;
@@ -34,15 +33,12 @@ import java.io.IOException;
* requires all the files every time. To work around this,
* set the global property CLEAN ("build.compiler.clean") to delete
* all .class files in the destination directory before compiling.
- * This clean process only permits one compile process at a time
- * for each destination directory because it tracks recursion by
- * writing a tag file to the destination directory.
*
* <p><u>Warnings</u>:
* <ol>
* <li>cleaning will not work if no destination directory
- * is specified in the javac task
- * (because we don't know where to put the tag file).</li>
+ * is specified in the javac task.
+ * (RFE: find and kill .class files in source dirs?)</li>
* <li>cleaning will makes stepwise build processes fail
* if they depend on the results of the prior compilation being
* in the same directory, since this deletes <strong>all</strong>
@@ -56,108 +52,81 @@ import java.io.IOException;
* @since AspectJ 1.1, Ant 1.5.1
*/
public class Ajc11CompilerAdapter implements CompilerAdapter {
+
/**
* Define this system/project property to signal that the
* destination directory should be cleaned
* and javac reinvoked
* to get the complete list of files every time.
- */
+ */
public static final String CLEAN = "build.compiler.clean";
-
+
+ /** track whether we re-called <code>javac.execute()</code> */
+ private static final ThreadLocal inSelfCall = new ThreadLocal() {
+ public Object initialValue() {
+ return Boolean.FALSE;
+ }
+ };
+
Javac javac;
-
+
public void setJavac(Javac javac) {
this.javac = javac;
+ javac.setTaskName(javac.getTaskName() + " - ajc");
}
-
+
public boolean execute() throws BuildException {
- checkJavac();
- if (recurse()) {
- javac.execute(); // re-invokes us after recalculating file list
- } else {
+ if (null == javac) {
+ throw new IllegalStateException("null javac");
+ }
+ if (!((Boolean) inSelfCall.get()).booleanValue()
+ && afterCleaningDirs()) {
+ // if we are not re-calling ourself and we cleaned dirs,
+ // then re-call javac to get the list of all source files.
+ inSelfCall.set(Boolean.TRUE);
+ javac.execute();
+ // javac re-invokes us after recalculating file list
+ } else {
try {
AjcTask ajc = new AjcTask();
String err = ajc.setupAjc(javac);
if (null != err) {
throw new BuildException(err, javac.getLocation());
}
- ajc.execute(); // handles BuildException for failonerror, etc.
+ ajc.execute();
+ // handles BuildException for failonerror, etc.
} finally {
- doneRecursing();
+ inSelfCall.set(Boolean.FALSE);
}
}
return true;
}
- /** @throws IllegalStateException if javac is not defined */
- protected void checkJavac() {
- if (null == javac) {
- throw new IllegalStateException("null javac");
- }
- }
-
/**
- * Get javac dest dir.
- * @param client the String label for the client seeking the directory
- * (only used in throwing BuildException)
- * @return File dest dir
- * @throws BuildException if not specified and required
+ * If destDir exists and property CLEAN is set,
+ * this cleans out the dest dir of any .class files,
+ * and returns true to signal a recursive call.
+ * @return true if destDir was cleaned.
*/
- protected File getDestDir(String client) {
- checkJavac();
- File destDir = javac.getDestdir();
- if (null == destDir) {
- throw new BuildException("require destDir for " + client);
- }
- return destDir;
- }
-
- protected File getTagFile() {
- return new File(getDestDir("getting tag file directory"),
- "Ajc11CompilerAdapter.tag");
- }
-
- /**
- * If property CLEAN is set, then this
- * cleans out the dest dir of any .class files,
- * installs a tag file, and returns true to signal a recursive call.
- * That means this returns false if CLEAN is not set
- * or if the tag file already exists (i.e., already recursing).
- * The result is that javac is re-invoked after the dest dir
- * is cleaned, so it picks up all the correct source files.
- * (This is a costly hack to work around Javac's forcing the
- * pruning of the file list.)
- * @return true if javac should be re-invoked.
- */
- protected boolean recurse() {
- checkJavac();
- String cleanDirs = javac.getProject().getProperty(CLEAN);
- if (null == cleanDirs) {
- return false;
- }
- File destDir = getDestDir("recursing to clean");
- File tagFile = getTagFile();
- if (tagFile.exists()) {
+ private boolean afterCleaningDirs() {
+ String clean = javac.getProject().getProperty(CLEAN);
+ if (null == clean) {
return false;
}
- try {
- javac.log(CLEAN + " cleaning .class files from " + destDir,
- Project.MSG_VERBOSE);
- FileUtil.deleteContents(destDir, FileUtil.DIRS_AND_WRITABLE_CLASSES, true);
- FileWriter fw = new FileWriter(tagFile);
- fw.write("Ajc11CompilerAdapter.recursing");
- fw.close();
- return true;
- } catch (IOException e) {
+ File destDir = javac.getDestdir();
+ if (null == destDir) {
+ javac.log(
+ CLEAN + " specified, but no dest dir to clean",
+ Project.MSG_WARN);
return false;
}
- }
-
- protected void doneRecursing() {
- File tagFile = getTagFile();
- if (tagFile.exists()) {
- tagFile.delete();
- }
+ javac.log(
+ CLEAN + " cleaning .class files from " + destDir,
+ Project.MSG_VERBOSE);
+ FileUtil.deleteContents(
+ destDir,
+ FileUtil.DIRS_AND_WRITABLE_CLASSES,
+ true);
+ return true;
}
}
-
diff --git a/taskdefs/src/org/aspectj/tools/ant/taskdefs/AjcTask.java b/taskdefs/src/org/aspectj/tools/ant/taskdefs/AjcTask.java
index 7237a8a85..c8eb47cbe 100644
--- a/taskdefs/src/org/aspectj/tools/ant/taskdefs/AjcTask.java
+++ b/taskdefs/src/org/aspectj/tools/ant/taskdefs/AjcTask.java
@@ -130,6 +130,9 @@ public class AjcTask extends MatchingTask {
File javacDestDir = javac.getDestdir();
if (null != javacDestDir) {
ajc.setDestdir(javacDestDir);
+ // filter requires dest dir
+ // mimic Javac task's behavior in copying resources,
+ ajc.setSourceRootCopyFilter("**/CVS/*,**/*.java,**/*.aj");
}
ajc.setBootclasspath(javac.getBootclasspath());
ajc.setExtdirs(javac.getExtdirs());
@@ -137,8 +140,6 @@ public class AjcTask extends MatchingTask {
// ignore srcDir -- all files picked up in recalculated file list
// ajc.setSrcDir(javac.getSrcdir());
ajc.addFiles(javac.getFileList());
- // mimic Javac task's behavior in copying resources,
- ajc.setSourceRootCopyFilter("**/CVS/*,**/*.java,**/*.aj");
// arguments can override the filter, add to paths, override options
ajc.readArguments(javac.getCurrentCompilerArgs());
@@ -299,6 +300,7 @@ public class AjcTask extends MatchingTask {
private Path argfiles;
private List ignored;
private Path sourceRoots;
+ private File xweaveDir;
// ----- added by adapter - integrate better?
private List /* File */ adapterFiles;
private String[] adapterArguments;
@@ -381,6 +383,7 @@ public class AjcTask extends MatchingTask {
srcdir = null;
tmpOutjar = null;
verbose = false;
+ xweaveDir = null;
}
protected void ignore(String ignored) {
@@ -542,6 +545,13 @@ public class AjcTask extends MatchingTask {
this.failonerror = failonerror;
}
+ /**
+ * @return true if fork was set
+ */
+ public boolean isForked() {
+ return fork;
+ }
+
public void setFork(boolean fork) {
this.fork = fork;
}
@@ -749,7 +759,14 @@ public class AjcTask extends MatchingTask {
}
return sourceRoots.createPath();
}
-
+
+ public void setXWeaveDir(File file) {
+ if ((null != file) && file.isDirectory()
+ && file.canRead()) {
+ xweaveDir = file;
+ }
+ }
+
public void setInjarsref(Reference ref) {
createInjars().setRefid(ref);
}
@@ -894,6 +911,7 @@ public class AjcTask extends MatchingTask {
} else {
executing = true;
}
+ setupOptions();
verifyOptions();
try {
String[] args = makeCommand();
@@ -980,6 +998,63 @@ public class AjcTask extends MatchingTask {
}
/**
+ * Create any pseudo-options required to implement
+ * some of the macro options
+ * @throws BuildException if options conflict
+ */
+ protected void setupOptions() {
+ if (null != xweaveDir) {
+ if (DEFAULT_DESTDIR != destDir) {
+ throw new BuildException("weaveDir forces destdir");
+ }
+ if (null != outjar) {
+ throw new BuildException("weaveDir forces outjar");
+ }
+ if (null != injars) {
+ throw new BuildException("weaveDir incompatible with injars now");
+ }
+ File injar = zipDirectory(xweaveDir);
+ setInjars(new Path(getProject(), injar.getAbsolutePath()));
+ setDestdir(xweaveDir);
+ }
+ }
+
+ protected File zipDirectory(File dir) {
+ File tempDir = new File(".");
+ try {
+ tempDir = File.createTempFile("AjcTest", ".tmp");
+ tempDir.mkdirs();
+ tempDir.deleteOnExit(); // XXX remove zip explicitly..
+ } catch (IOException e) {
+ // ignore
+ }
+// File result = new File(tempDir,
+ String filename = "AjcTask-"
+ + System.currentTimeMillis()
+ + ".zip";
+ File result = new File(filename);
+ Zip zip = new Zip();
+ zip.setProject(getProject());
+ zip.setDestFile(result);
+ zip.setTaskName(getTaskName() + " - zip");
+ FileSet fileset = new FileSet();
+ fileset.setDir(dir);
+ zip.addFileset(fileset);
+ zip.execute();
+ Delete delete = new Delete();
+ delete.setProject(getProject());
+ delete.setTaskName(getTaskName() + " - delete");
+ delete.setDir(dir);
+ delete.execute();
+ Mkdir mkdir = new Mkdir();
+ mkdir.setProject(getProject());
+ mkdir.setTaskName(getTaskName() + " - mkdir");
+ mkdir.setDir(dir);
+ mkdir.execute();
+ return result;
+ }
+
+ /**
* @throw BuildException if options conflict
*/
protected void verifyOptions() {
@@ -987,7 +1062,6 @@ public class AjcTask extends MatchingTask {
if (fork && isInIncrementalMode() && !isInIncrementalFileMode()) {
sb.append("can fork incremental only using tag file.\n");
}
-
if ((null != sourceRootCopyFilter) && (null == outjar)
&& (DEFAULT_DESTDIR == destDir)) {
final String REQ = " requires dest dir or output jar.\n"; sb.append("sourceRootCopyFilter");
@@ -1051,8 +1125,9 @@ public class AjcTask extends MatchingTask {
int errs = holder.numMessages(IMessage.ERROR, false);
errs -= numPreviousErrors;
if (0 < errs) {
- // errors should already be printed by interceptor
- throw new BuildException(errs + " errors");
+ String m = errs + " errors";
+ MessageUtil.print(System.err, holder, "", MessageUtil.MESSAGE_ALL, MessageUtil.PICK_ERROR, true);
+ throw new BuildException(m);
}
}
// Throw BuildException if there are any fail or abort