summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorwisberg <wisberg>2004-03-08 19:13:03 +0000
committerwisberg <wisberg>2004-03-08 19:13:03 +0000
commit92d0049be5785ab552e40ffc6a07fa5568fc18b4 (patch)
treed3d0cf6be5b28e0e81af07a098f7860a4900842d
parent70cc1bb27f1e13d8f7bcbb98a691ee37633791e6 (diff)
downloadaspectj-92d0049be5785ab552e40ffc6a07fa5568fc18b4.tar.gz
aspectj-92d0049be5785ab552e40ffc6a07fa5568fc18b4.zip
-xlintfile option support
-rw-r--r--testing/src/org/aspectj/testing/harness/bridge/CompilerRun.java25
1 files changed, 19 insertions, 6 deletions
diff --git a/testing/src/org/aspectj/testing/harness/bridge/CompilerRun.java b/testing/src/org/aspectj/testing/harness/bridge/CompilerRun.java
index 084c17c7a..9241d103e 100644
--- a/testing/src/org/aspectj/testing/harness/bridge/CompilerRun.java
+++ b/testing/src/org/aspectj/testing/harness/bridge/CompilerRun.java
@@ -229,13 +229,17 @@ public class CompilerRun implements IAjcRun {
FileUtil.getBaseDirFiles(testBaseSrcDir, spec.extdirs);
final File[] classFiles =
FileUtil.getBaseDirFiles(testBaseSrcDir, spec.classpath);
+ final File[] xlintFiles = (null == spec.xlintfile ? new File[0]
+ : FileUtil.getBaseDirFiles(testBaseSrcDir, new String[] {spec.xlintfile}));
+
// hmm - duplicates validation above, verifying getBaseDirFiles?
if (!spec.badInput) {
if (!validator.canRead(argFiles, "argFiles")
|| !validator.canRead(injarFiles, "injarFiles")
|| !validator.canRead(inpathFiles, "inpathFiles")
|| !validator.canRead(aspectFiles, "aspectFiles")
- || !validator.canRead(classFiles, "classFiles")) {
+ || !validator.canRead(classFiles, "classFiles")
+ || !validator.canRead(xlintFiles, "xlintFiles")) {
return false;
}
}
@@ -277,12 +281,12 @@ public class CompilerRun implements IAjcRun {
spec.sourceroots,
sandbox.stagingDir);
// delete incremental files in sourceroot after copying // XXX inefficient
+ // an incremental file has an extra "." in name
+ // most .java files don't, because they are named after
+ // the principle type they contain, and simple type names
+ // have no dots.
FileFilter pickIncFiles = new FileFilter() {
- // an incremental file has an extra "." in name
- // most .java files don't, because they are named after
- // the principle type they contain, and simple type names
- // have no dots.
- public boolean accept(File file) {
+ public boolean accept(File file) {
if (file.isDirectory()) {
// continue recursion
return true;
@@ -327,6 +331,11 @@ public class CompilerRun implements IAjcRun {
}
arguments.clear();
+ if (!LangUtil.isEmpty(xlintFiles)) {
+ arguments.add("-Xlintfile");
+ String sr = FileUtil.flatten(xlintFiles, null);
+ arguments.add(sr);
+ }
if (!LangUtil.isEmpty(extdirFiles)) {
arguments.add("-extdirs");
String sr = FileUtil.flatten(extdirFiles, null);
@@ -718,6 +727,7 @@ public class CompilerRun implements IAjcRun {
/** src path = {suiteParentDir}/{testBaseDirOffset}/{testSrcDirOffset}/{path} */
protected String testSrcDirOffset;
+ protected String xlintfile;
public Spec() {
super(XMLNAME);
@@ -816,6 +826,9 @@ public class CompilerRun implements IAjcRun {
sourceroots = XMLWriter.unflattenList(dirs);
}
}
+ public void setXlintfile(String path) {
+ xlintfile = path;
+ }
/**
* Set extension dirs, deleting any old ones