diff options
Diffstat (limited to 'taskdefs/src')
-rw-r--r-- | taskdefs/src/org/aspectj/tools/ant/taskdefs/AjcTask.java | 92 |
1 files changed, 84 insertions, 8 deletions
diff --git a/taskdefs/src/org/aspectj/tools/ant/taskdefs/AjcTask.java b/taskdefs/src/org/aspectj/tools/ant/taskdefs/AjcTask.java index 7f117d87e..ffa97d124 100644 --- a/taskdefs/src/org/aspectj/tools/ant/taskdefs/AjcTask.java +++ b/taskdefs/src/org/aspectj/tools/ant/taskdefs/AjcTask.java @@ -327,7 +327,10 @@ public class AjcTask extends MatchingTask { /** non-null if copying all source root files but the filtered ones */ private String sourceRootCopyFilter; - + + /** non-null if copying all inpath dir files but the filtered ones */ + private String inpathDirCopyFilter; + /** directory sink for classes */ private File destDir; @@ -394,6 +397,7 @@ public class AjcTask extends MatchingTask { messageHolder = null; outjar = null; sourceRootCopyFilter = null; + inpathDirCopyFilter = null; sourceRoots = null; srcdir = null; tmpOutjar = null; @@ -680,6 +684,28 @@ public class AjcTask extends MatchingTask { public void setSourceRootCopyFilter(String filter){ this.sourceRootCopyFilter = filter; } + /** + * Option to copy all files from + * all inpath directories + * except the files specified here. + * If this is specified and inpath directories are specified, + * then this will copy all files except + * those specified in the filter pattern. + * Requires inpath. + * If the input does not contain "**\/*.class", then + * this prepends it, to avoid overwriting woven classes + * with unwoven input. + * @param filter a String acceptable as an excludes + * filter for an Ant Zip fileset. + */ + public void setInpathDirCopyFilter(String filter){ + if (null != filter) { + if (-1 == filter.indexOf("**/*.class")) { + filter = "**/*.class," + filter; + } + } + this.inpathDirCopyFilter = filter; + } public void setX(String input) { // ajc-only eajc-also docDone StringTokenizer tokens = new StringTokenizer(input, ",", false); @@ -1004,7 +1030,8 @@ public class AjcTask extends MatchingTask { // when copying resources, use temp jar for class output // then copy temp jar contents and resources to output jar if ((null != outjar) && !outjarFixedup) { - if (copyInjars || copyInpath || (null != sourceRootCopyFilter)) { + if (copyInjars || copyInpath || (null != sourceRootCopyFilter) + || (null != inpathDirCopyFilter)) { String path = outjar.getAbsolutePath(); int len = FileUtil.zipSuffixLength(path); if (len < 1) { @@ -1103,10 +1130,16 @@ 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"); - sb.append(REQ); + if (((null != inpathDirCopyFilter) || (null != sourceRootCopyFilter)) + && (null == outjar) && (DEFAULT_DESTDIR == destDir)) { + final String REQ = " requires dest dir or output jar.\n"; + if (null == inpathDirCopyFilter) { + sb.append("sourceRootCopyFilter"); + } else if (null == sourceRootCopyFilter) { + sb.append("inpathDirCopyFilter"); + } else { + sb.append("sourceRootCopyFilter and inpathDirCopyFilter"); + }
sb.append(REQ); } if (0 < sb.length()) { throw new BuildException(sb.toString()); @@ -1475,7 +1508,8 @@ public class AjcTask extends MatchingTask { * (if XCopyInjars is enabled). */ private void completeDestdir() { - if (!copyInjars && (null == sourceRootCopyFilter)) { + if (!copyInjars && (null == sourceRootCopyFilter) + && (null == inpathDirCopyFilter)) { return; } else if ((destDir == DEFAULT_DESTDIR) || !destDir.canWrite()) { @@ -1521,6 +1555,31 @@ public class AjcTask extends MatchingTask { copy.execute(); } } + if ((null != inpathDirCopyFilter) && (null != inpath)) { + String[] paths = inpath.list(); + if (!LangUtil.isEmpty(paths)) { + Copy copy = new Copy(); + copy.setProject(project); + copy.setTodir(destDir); + boolean gotDir = false; + for (int i = 0; i < paths.length; i++) { + File inpathDir = new File(paths[i]); + if (inpathDir.isDirectory() && inpathDir.canRead()) { + if (!gotDir) { + gotDir = true; + } + FileSet fileSet = new FileSet(); + fileSet.setDir(inpathDir); + fileSet.setIncludes("**/*"); + fileSet.setExcludes(inpathDirCopyFilter); + copy.addFileset(fileSet); + } + } + if (gotDir) { + copy.execute(); + } + } + } } /** @@ -1531,7 +1590,8 @@ public class AjcTask extends MatchingTask { */ private void completeOutjar() { if (((null == tmpOutjar) || !tmpOutjar.canRead()) - || (!copyInjars && (null == sourceRootCopyFilter))) { + || (!copyInjars && (null == sourceRootCopyFilter) + && (null == inpathDirCopyFilter))) { return; } Zip zip = new Zip(); @@ -1572,6 +1632,22 @@ public class AjcTask extends MatchingTask { } } } + if ((null != inpathDirCopyFilter) && (null != inpath)) { + String[] paths = inpath.list(); + if (!LangUtil.isEmpty(paths)) { + for (int i = 0; i < paths.length; i++) { + File inpathDir = new File(paths[i]); + if (inpathDir.isDirectory() && inpathDir.canRead()) { + FileSet fileset = new FileSet(); + fileset.setProject(project); + fileset.setDir(inpathDir); + fileset.setIncludes("**/*"); + fileset.setExcludes(inpathDirCopyFilter); + zip.addFileset(fileset); + } + } + } + } zip.execute(); } |