aboutsummaryrefslogtreecommitdiffstats
path: root/docs
diff options
context:
space:
mode:
authorwisberg <wisberg>2005-03-22 21:27:08 +0000
committerwisberg <wisberg>2005-03-22 21:27:08 +0000
commit8c80fde9d4d3c7c2d913da377f8fb2de6e4bf854 (patch)
tree7eaa237754a0111da54820f473589ea09dc3c7c7 /docs
parent8766cadf5e70cf564ebc6699e48e3b2b7f20ad0a (diff)
downloadaspectj-8c80fde9d4d3c7c2d913da377f8fb2de6e4bf854.tar.gz
aspectj-8c80fde9d4d3c7c2d913da377f8fb2de6e4bf854.zip
bug 53209 - inpathDirCopyFilter doc updates and tests
Diffstat (limited to 'docs')
-rw-r--r--docs/devGuideDB/antsupport.xml45
-rw-r--r--docs/test/antScriptTest/build.xml64
-rw-r--r--docs/test/antScriptTest/build/binary-input/ignore.txt1
-rw-r--r--docs/test/antScriptTest/ec/inpathDirSrc/InpathFile.java2
4 files changed, 75 insertions, 37 deletions
diff --git a/docs/devGuideDB/antsupport.xml b/docs/devGuideDB/antsupport.xml
index 71d923563..900107bbb 100644
--- a/docs/devGuideDB/antsupport.xml
+++ b/docs/devGuideDB/antsupport.xml
@@ -285,7 +285,8 @@
<row>
<entry><para>copyInjars
</para></entry>
- <entry><para>
+ <entry><para>
+ (Deprecated/ignored; ajc does this.)
If true, copy all non-.class files from input jar(s)
to the output jar or destination directory after the
compile (or incremental compile) completes.
@@ -302,8 +303,29 @@
The pattern should be compatible with an Ant fileset excludes filter;
when using this, most developers pass
<literal>**/CVS/*,**/*.java</literal> to exclude any CVS directories
- or source files.
- </para></entry>
+ or source files.
+ See <literal>inpathDirCopyFilter</literal>.
+ Requires <literal>destDir</literal> or <literal>outJar</literal>.
+ </para></entry>
+ </row>
+ <row>
+ <entry><para>inpathDirCopyFilter
+ </para></entry>
+ <entry>
+ <para> When set, copy all files from the inpath directories
+ to the output jar or destination directory except those
+ specified in the filter pattern. The pattern should be
+ compatible with an Ant fileset excludes filter; when
+ using this, most developers pass
+ <literal>**/CVS/*,**/*.java,**/*.class</literal> to
+ exclude any CVS directories, source files, or unwoven
+ .class files. (If <literal>**/*.class</literal> is not
+ specified, it will be prepended to the filter.) See
+ <literal>sourceRootCopyFilter</literal>. (Note that ajc
+ itself copies all resources from input jar/zip files on
+ the inpath.) Requires <literal>destDir</literal> or
+ <literal>outJar</literal>.</para>
+ </entry>
</row>
</tbody>
</tgroup>
@@ -760,12 +782,12 @@
</para>
</listitem>
<listitem>
- <para>Reads all the sources from two directories;
+ <para>Reads all the source files from two directories;
</para>
</listitem>
<listitem>
- <para>Reads extrinsic module bytecode as input jar for weaving;
- </para>
+ <para>Reads binary .class files from input jar and directory;
+ </para>
</listitem>
<listitem>
<para>Uses a binary aspect library for persistence;
@@ -776,8 +798,8 @@
</para>
</listitem>
<listitem>
- <para>Copies resources from the input jar and source directories into the application jar.
- </para>
+ <para>Copies resources from the source directories and binary input
+ jar and directories to the application jar. </para>
</listitem>
</orderedlist>
<para>
@@ -792,14 +814,17 @@
<![CDATA[
<target name="build-test" >
<iajc outjar="${home.dir}/output/application.jar"
- injars="${home.dir}/build/module.jar"
- copyInjars="true"
sourceRootCopyFilter="**/CVS/*,**/*.java"
+ inpathDirCopyFilter="**/CVS/*,**/*.java,**/*.class"
incremental="true" >
<sourceroots>
<pathelement location="${home.dir}/ec/project/src"/>
<pathelement location="${home.dir}/ec/project/testsrc"/>
</sourceroots>
+ <inpath>
+ <pathelement location="${home.dir}/build/module.jar"/>
+ <pathelement location="${home.dir}/build/binary-input"/>
+ </inpath>
<aspectpath>
<pathelement location="${home.dir}/ec/int/persist.jar"/>
</aspectpath>
diff --git a/docs/test/antScriptTest/build.xml b/docs/test/antScriptTest/build.xml
index 2a7b00d82..7f875625c 100644
--- a/docs/test/antScriptTest/build.xml
+++ b/docs/test/antScriptTest/build.xml
@@ -61,6 +61,8 @@
<target name="clean" depends="init">
<delete quiet="on">
+ <fileset dir="${home.dir}/build/binary-input"
+ excludes="ignore.txt"/>
<fileset dir="${home.dir}"
includes="ec/int/persist.jar,
build/module.jar,
@@ -96,37 +98,45 @@
fork="${fork.iajc}"
sourceroots="${home.dir}/ec/module/src"
classpath="${home.dir}/tools/aspectj/lib/aspectjrt.jar"/>
+ <mkdir dir="${home.dir}/build/binary-input"/>
+ <iajc destdir="${home.dir}/build/binary-input"
+ failonerror="true"
+ fork="${fork.iajc}"
+ sourceroots="${home.dir}/ec/inpathDirSrc"
+ classpath="${home.dir}/tools/aspectj/lib/aspectjrt.jar"/>
</target>
<target name="build-test" depends="init,taskdef,setup"
description="test Ant script from the devguide">
- <!-- copy this from the Ant section of the rendered devguide -->
+ <!-- copy below from the Ant section of the rendered devguide -->
<!-- in eclipse, must run forked and not incremental -->
- <iajc outjar="${home.dir}/output/application.jar"
- injars="${home.dir}/build/module.jar"
- copyInjars="true"
- fork="${fork.iajc}"
- sourceRootCopyFilter="**/CVS/*,**/*.java"
- incremental="false" >
- <sourceroots>
- <pathelement location="${home.dir}/ec/project/src"/>
- <pathelement location="${home.dir}/ec/project/testsrc"/>
- </sourceroots>
- <aspectpath>
- <pathelement location="${home.dir}/ec/int/persist.jar"/>
- </aspectpath>
- <classpath>
- <pathelement location="${home.dir}/tools/aspectj/lib/aspectjrt.jar"/>
- </classpath>
- </iajc>
-
- <java classname="org.smart.app.Main">
- <classpath>
- <pathelement location="${home.dir}/tools/aspectj/lib/aspectjrt.jar"/>
- <pathelement location="${home.dir}/ec/int/persist.jar"/>
- <pathelement location="${home.dir}/output/application.jar"/>
- </classpath>
- </java>
- </target>
+ <iajc outjar="${home.dir}/output/application.jar"
+ sourceRootCopyFilter="**/CVS/*,**/*.java"
+ inpathDirCopyFilter="**/CVS/*,**/*.java,**/*.class"
+ incremental="true" >
+ <sourceroots>
+ <pathelement location="${home.dir}/ec/project/src"/>
+ <pathelement location="${home.dir}/ec/project/testsrc"/>
+ </sourceroots>
+ <inpath>
+ <pathelement location="${home.dir}/build/module.jar"/>
+ <pathelement location="${home.dir}/build/binary-input"/>
+ </inpath>
+ <aspectpath>
+ <pathelement location="${home.dir}/ec/int/persist.jar"/>
+ </aspectpath>
+ <classpath>
+ <pathelement location="${home.dir}/tools/aspectj/lib/aspectjrt.jar"/>
+ </classpath>
+ </iajc>
+
+ <java classname="org.smart.app.Main">
+ <classpath>
+ <pathelement location="${home.dir}/tools/aspectj/lib/aspectjrt.jar"/>
+ <pathelement location="${home.dir}/ec/int/persist.jar"/>
+ <pathelement location="${home.dir}/output/application.jar"/>
+ </classpath>
+ </java>
+ </target>
</project>
diff --git a/docs/test/antScriptTest/build/binary-input/ignore.txt b/docs/test/antScriptTest/build/binary-input/ignore.txt
new file mode 100644
index 000000000..c7d48fbb5
--- /dev/null
+++ b/docs/test/antScriptTest/build/binary-input/ignore.txt
@@ -0,0 +1 @@
+ignore - just to avoid CVS trimming empty directories.
diff --git a/docs/test/antScriptTest/ec/inpathDirSrc/InpathFile.java b/docs/test/antScriptTest/ec/inpathDirSrc/InpathFile.java
new file mode 100644
index 000000000..729709fea
--- /dev/null
+++ b/docs/test/antScriptTest/ec/inpathDirSrc/InpathFile.java
@@ -0,0 +1,2 @@
+
+public class InpathFile {} \ No newline at end of file