diff options
author | ehilsdal <ehilsdal> | 2004-05-21 06:19:07 +0000 |
---|---|---|
committer | ehilsdal <ehilsdal> | 2004-05-21 06:19:07 +0000 |
commit | cdfb3edaeecc171e912040fc9c68fe002bfa459d (patch) | |
tree | 8bfd6f7721ac9d7616725b34c03b8b42835c1094 | |
parent | 68bc96dd1086d5832e96395b09f49da2b8e5f995 (diff) | |
download | aspectj-cdfb3edaeecc171e912040fc9c68fe002bfa459d.tar.gz aspectj-cdfb3edaeecc171e912040fc9c68fe002bfa459d.zip |
Hopefully better bcel-builder build system,
instigated by Andy actually trying to use
this module the way it is supposed to be used
-rw-r--r-- | bcel-builder/build.xml | 80 | ||||
-rw-r--r-- | bcel-builder/readme.html | 52 |
2 files changed, 76 insertions, 56 deletions
diff --git a/bcel-builder/build.xml b/bcel-builder/build.xml index 0310d4c3f..98aebeeb8 100644 --- a/bcel-builder/build.xml +++ b/bcel-builder/build.xml @@ -1,60 +1,70 @@ -<project default="unpackAndJar" basedir="."> +<project default="extractAndJar" basedir="."> - <target name="unpackAndJar" depends="unpack,jar" /> + <!-- top-level --> + <target name="extractAndJar" depends="extract,jar" /> - <target name="jar"> + <target name="extract" depends="unzipSource,createPatchedSource" /> + + <target name="jar" depends="pack"> <copy file="../lib/regexp/jakarta-regexp-1.2.jar" tofile="bcel/lib/Regex.jar" /> <ant dir="bcel" target="jar" /> <copy file="bcel/bin/bcel.jar" toDir="." /> </target> - - <target name="update"> + + <target name="push"> <copy file="bcel.jar" todir="../lib/bcel" /> </target> - - <target name="pack"> - <move toDir="bcel/src/java"> - <fileset dir="src" /> - </move> - </target> - - <target name="unpack" depends="extract,patch,srcclean"> - <move toDir="src"> - <fileset dir="bcel/src/java" /> - </move> - </target> - - <target name="extract"> - <unzip src="bcel-5.1-src.zip" dest="." /> + + <target name="diff" depends="pack"> + <exec dir="." executable="diff.exe" output="patch.txt"> + <arg line="-N"/> + <arg line="-a"/> + <arg line="-u"/> + <arg line="-r"/> + <arg line="-b"/> + <arg line="bcel-5.1" /> + <arg line="bcel" /> + </exec> </target> - - <target name="srcclean"> - <delete dir="src/org" /> + + <target name="clean"> + <delete dir="bcel-5.1" /> + <delete dir="bcel" /> + <delete file="bcel.jar" /> + <delete dir="src" /> + <mkdir dir="src" /> <!-- empty src dir --> </target> + + <!-- internals --> - <target name="clean" depends="srcclean"> + <target name="unzipSource"> <delete dir="bcel-5.1" /> - <delete dir="bcel" /> + <unzip src="bcel-5.1-src.zip" dest="." /> </target> + + <target name="createPatchedSource" depends="patch,unpack" /> <target name="patch"> + <delete dir="bcel" /> <copy todir="bcel"> <fileset dir="bcel-5.1" /> </copy> <patch patchfile="patch.txt" strip="1" dir="bcel" /> </target> - <target name="diff"> - <exec dir="." executable="diff.exe" output="patch.txt"> - <arg line="-N"/> - <arg line="-a"/> - <arg line="-u"/> - <arg line="-r"/> - <arg line="-b"/> - <arg line="bcel-5.1" /> - <arg line="bcel" /> - </exec> + <target name="pack"> + <delete dir="bcel/src/java" /> + <copy toDir="bcel/src/java"> + <fileset dir="src" /> + </copy> + </target> + + <target name="unpack"> + <delete dir="src" /> + <copy toDir="src"> + <fileset dir="bcel/src/java" /> + </copy> </target> </project> diff --git a/bcel-builder/readme.html b/bcel-builder/readme.html index b5a4c52c8..a0d20b60a 100644 --- a/bcel-builder/readme.html +++ b/bcel-builder/readme.html @@ -19,6 +19,9 @@ this directory? Well, the whole point is to generate bcel/bcel.jar in the lib package. To do so, first stick <strong>bcel-5.1-src.zip</strong> in this directory, then run ant. +(at one point, this was available at +<a href="http://archive.apache.org/dist/jakarta/bcel/source/bcel-5.1-src.zip"> +http://archive.apache.org/dist/jakarta/bcel/source/bcel-5.1-src.zip</a>) After much unzipping, patching, and compiling, you should get an appropriate bcel.jar file. Now put it in the appropriate place. </p> @@ -28,28 +31,35 @@ to know some more ant targets. But before anything, get that <strong>bcel-5.1-src.zip</strong> and stick it in this directory. </p> +<p> There are five top-level ant targets apart from the usual "clean":</p> + <ul> - <li>ant unpack -- unpack the sources for the AspectJ-version of BCEL - into the <strong>src</strong> subdirectory. Though you probably - don't care, this invokes the following subtasks: </li> - - <ul> - <li>ant extract -- extract the contents of bcel-5.1-src.zip - into the bcel-5.1 directory.</li> - - <li>ant patch -- apply the patchfile patch.txt to the - <strong>bcel-5.1/src</strong> directory, creating - <strong>src</strong>.</li> - </ul> - - <li>ant pack -- pack the sources for AspectJ's version of bcel back - into a tiny little patchfile. This uses exec, and requires that you - have diff somewhere on your path. Actually, it's much worse: it - requires you have diff.exe somewhere on your path. I hate that I'm - turning into a windows whore. </li> - - <li>ant clean -- get rid of everything extraneous in preparation for - a checkin. </li> + <li>ant extractAndJar -- this is just the composition of the extract + and jar targets, and is the default. It extracts the source from bcel-5.1-src.zip, + patches it, compiles the patched version into a jar and drops the new jar, + bcel.jar, into the project root. This is the default task, mainly used + to sanity check the building and make sure we're generating something. + The bcel.jar this generates should be the same as that in ..\lib\bcel\bcel.jar. + </li> + + <li>ant extract -- this extracts the source from bcel-5.1-src.zip, + patches it, and copies the patched source into the project src directory, + there to be visible by eclipse for people to do development on it. + </li> + + <li>ant jar -- this copies the edited source from the project source + directory and jars it up into bcel.jar, there to be tested. + </li> + + <li>ant push -- this pushes the new bcel.jar into ..\lib\bcel\bcel.jar, + ready to be used by the greater compiler.</li> + + <li>ant diff -- this creates the patch.txt file, composed of the differences + between the project src directory and the original bcel-5.1 source. </li> </ul> +<p> All of the tasks are destructive, so don't do "ant extract", for example, +if you have anything in the project source directory you care about. +</p> + </body> </html> |