aboutsummaryrefslogtreecommitdiffstats
path: root/build
diff options
context:
space:
mode:
Diffstat (limited to 'build')
-rw-r--r--build/src/org/aspectj/internal/tools/ant/taskdefs/AntBuilder.java51
1 files changed, 38 insertions, 13 deletions
diff --git a/build/src/org/aspectj/internal/tools/ant/taskdefs/AntBuilder.java b/build/src/org/aspectj/internal/tools/ant/taskdefs/AntBuilder.java
index 0cfd097b7..233adce1e 100644
--- a/build/src/org/aspectj/internal/tools/ant/taskdefs/AntBuilder.java
+++ b/build/src/org/aspectj/internal/tools/ant/taskdefs/AntBuilder.java
@@ -12,6 +12,8 @@
package org.aspectj.internal.tools.ant.taskdefs;
import java.io.File;
+import java.io.FileWriter;
+import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
@@ -207,11 +209,32 @@ public class AntBuilder extends Builder {
// I suspect it requires the proper adapter setup.
Javac javac = new Javac();
setupTask(javac, "javac");
+ javac.setDestdir(classesDir);
+ if (!classesDir.mkdirs()) {
+ errors.add("unable to create classes directory");
+ return false;
+ }
// -- source paths
Path path = new Path(project);
+ boolean hasSourceDirectories = false;
for (Iterator iter = module.getSrcDirs().iterator(); iter.hasNext();) {
File file = (File) iter.next();
path.createPathElement().setLocation(file);
+ if (!hasSourceDirectories) {
+ hasSourceDirectories = true;
+ }
+ }
+ if (!hasSourceDirectories) { // none - dump minimal file and exit
+ File minFile = new File(classesDir, module.name);
+ try {
+ FileWriter fw = new FileWriter(minFile);
+ fw.write(module.name);
+ fw.close();
+ } catch (IOException e) {
+ // ignore
+ }
+ // XXX signal?
+ return true; // nothing to compile - ok
}
javac.setSrcdir(path);
path = null;
@@ -219,21 +242,28 @@ public class AntBuilder extends Builder {
// -- classpath
Path classpath = new Path(project);
boolean hasLibraries = false;
- // modules
- for (Iterator iter = module.getRequired().iterator(); iter.hasNext();) {
- Module required = (Module) iter.next();
- classpath.createPathElement().setLocation(required.getModuleJar());
+ // required libraries
+ for (Iterator iter = module.getLibJars().iterator(); iter.hasNext();) {
+ File file = (File) iter.next();
+ classpath.createPathElement().setLocation(file);
if (!hasLibraries) {
hasLibraries = true;
}
}
- // libraries
- for (Iterator iter = module.getLibJars().iterator(); iter.hasNext();) {
- File file = (File) iter.next();
- classpath.createPathElement().setLocation(file);
+ // required modules and their exported libraries
+ for (Iterator iter = module.getRequired().iterator(); iter.hasNext();) {
+ Module required = (Module) iter.next();
+ classpath.createPathElement().setLocation(required.getModuleJar());
if (!hasLibraries) {
hasLibraries = true;
}
+ // also put on classpath libraries exported from required module
+ // XXX exported modules not supported
+ for (Iterator iterator = required.getExportedLibJars().iterator();
+ iterator.hasNext();
+ ) {
+ classpath.createPathElement().setLocation((File) iterator.next());
+ }
}
// need to add system classes??
boolean inEclipse = true; // XXX detect, fork only in eclipse
@@ -244,11 +274,6 @@ public class AntBuilder extends Builder {
// -- set output directory
classpath.createPathElement().setLocation(classesDir);
javac.setClasspath(classpath);
- javac.setDestdir(classesDir);
- if (!classesDir.mkdirs()) {
- errors.add("unable to create classes directory");
- return false;
- }
// misc
javac.setDebug(true);
// compile