source: other-projects/gs3-webservices-java-client/trunk/build.xml@ 21848

Last change on this file since 21848 was 21848, checked in by ak19, 12 years ago

Jar files now compiled up with debug information included.

File size: 17.1 KB
1<?xml version="1.0"?>
2<!-- ======================================================================
3 April 2008 - GS3 web services democlient compile script
4 With lots of help from kjdon's Greenstone3 build and install script
5 See
7 for info on build.xml ant files,
8 and
10====================================================================== -->
11<project name="gs3democlient" default="usage" basedir=".">
12<description>This buildfile is used to build the demo-client for Greenstone3's web services.</description>
14 <!-- ============ predefining properties for reuse =================== -->
15 <property name="src.dir" value="${basedir}/src" />
16 <property name="democlient.rootdir" value="${src.dir}/GS3DemoClient" />
17 <property name="democlient.src" value="${democlient.rootdir}/org" />
18 <property name="fedorags3.rootdir" value="${src.dir}/GS3Fedora" />
19 <property name="fedorags3.src" value="${fedorags3.rootdir}/org" />
20 <property name="gsearchinstaller.rootdir" value="${src.dir}/GSearchInstaller" />
21 <property name="gsearchinstaller.src" value="${gsearchinstaller.rootdir}/org" />
23 <property name="build" value="${basedir}/build" />
24 <property name="dist" value="${basedir}/dist" />
26 <property name="QBRdata.rel.path" value="org/greenstone/gs3client/data" />
27 <property name="dlservices.rel.path" value="org/greenstone/gs3client/dlservices" />
28 <property name="gui.rel.path" value="org/greenstone/gs3client" />
29 <property name="gs3services.rel.path" value="org/greenstone/gs3services" />
31 <property name="" value="GS3democlient.jar" /> <!-- name of the executable-->
32 <property name="gs3.files.jar" value="gs3_for_client.jar" />
33 <property name="log4j.propFile" value="" />
35 <property name="" value="gs3_webservices_democlient" />
36 <property name="zip.excludes" value="dist/**,logs/**," />
37 <property name="" value="gs3-webservices-democlient" />
39 <!-- svn url locations for obtaining copies of the latest version of source code dependencies -->
40 <property name="gs3forclient.svn.path" value=""/>
41 <property name="" value=""/>
43 <!-- ============ project classpath: everything in the lib folder =================== -->
44 <path id="project.classpath">
45 <fileset dir="lib">
46 <include name="**/*.jar"/>
47 </fileset>
48 </path>
50<target name="usage" description="Prints out ant commands for the GS3 demo-client">
51 <echo>Type:</echo>
52 <echo>- ant build-demo-client</echo>
53 <echo> for (compiling) and creating the demo-client executable</echo>
54 <echo>- ant compile-demo-client</echo>
55 <echo> for compiling the democlient</echo>
56 <echo>- ant fedoraGS3jar</echo>
57 <echo> for generating the fedoraGS3.jar dependency file</echo>
58 <echo>- ant QBRdatajar</echo>
59 <echo> for generating the QBRdata.jar dependency file</echo>
60 <echo>- ant DLservicesjar</echo>
61 <echo> for generating the DLservices.jar standalone library</echo>
62 <echo>- ant make-dist</echo>
63 <echo> for generating the zip/gzip/bzip file of the project</echo>
64 <echo>- ant clean-democlient</echo>
65 <echo> for deleting the *.class files from the GS3democlient's source</echo>
66 <echo>- ant clean</echo>
67 <echo> for deleting the *.class files from the GS3democlient and GS3Fedora sources</echo>
68 <echo>- ant distclean</echo>
69 <echo> for deleting the *.class files from the sources, the QBRdata.jar, fedoraGS3.jar, executable jar file, and any zips of the project folder</echo>
70 <echo>- ant update</echo>
71 <echo> for getting the latest version of, and the files for creating the gs3_for_client.jar dependency from Greenstone's SVN repository</echo>
72 <echo>- ant GSearchInstallerjar</echo>
73 <echo> for generating the GSearchInstaller.jar application that helps in installing Fedora Generic Search (if you have Fedora installed).</echo>
77<!-- Main targets: to build the GS3 web services demo-client and to create the tar.gz file for downloading -->
78<target name="build-demo-client" description="Creates the jar distribution file" depends="compile-demo-client,ensure-check-java-version">
79 <mkdir dir="${basedir}/logs" /> <!-- Need a logs dir for outputting log4j stuff-->
80 <jar destfile="${}"
81 basedir="${democlient.rootdir}/"
82 manifest="Manifest.MF"
83 excludes="${QBRdata.rel.path}/*.class"
84 />
85 <copy file="${src.dir}/${log4j.propFile}" tofile="${basedir}/${log4j.propFile}"/>
86<!-- LATER: only for tarring include source files, so that we can exclude the java files in this build?-->
89<target name="make-dist" description="Generates the zip file of the lib and src folders and the executable ${} file" depends="get-zipformat,ensure-exec-jar,ensure-gsearchinstall-jar" if="zip.type">
90 <mkdir dir="${dist}" />
91 <antcall target="create-${zip.type}"/>
96"Sometimes when debugging application we may run into this exception - Java Exception unknown source.
97The possible reason could be when compiling the application, javac ant tasks omits debug option by defaut. So we will have to explicity set debug flag to true. See the javac ant task documentation for more info. You can mention some thing like below:
99<target name="compile">
100 <javac srcdir="${src.dir}" destdir="{dest.dir}." debug="on" debuglevel="lines,vars,source" />
104<!-- Compilation first ensures the existence of QBRdata.jar AND fedoraGS3.jar by checking whether these jars already exist and, if not, generating them. It is then that the actual compilation of the GS3democlient starts. By now the QBRdata classes of the GS3democlient src folder would have been compiled, but that does not matter as javac only compiles when class files are outdated or when they have not been generated yet.-->
105<target name="compile-demo-client" description="Compiles the GS3 demo-client" depends="ensure-QBRdata-jar,ensure-fedoraGS3-jar,ensure-gs3-for-client">
106 <javac srcdir="${democlient.rootdir}" debug="on" debuglevel="lines,vars,source">
107 <classpath refid="project.classpath"/>
108 <exclude name="${gs3services.rel.path}/**" /> <!--gs3services package needs official gsdl.jar to compile, so we skip it as it is not part of the client anyway-->
109 </javac>
112<!-- Cleaning targets -->
113<target name="clean-democlient" description="Removes all class files from the GS3demo-client (includes the data package that is used to create QBRdata.jar)">
114 <delete>
115 <fileset dir="${democlient.src}" includes="**/*.class"/>
116 </delete>
119<target name="clean" description="Removes all class files from the GS3DemoClient, GS3Fedora, GSearchInstaller source folders" depends="clean-democlient">
120 <delete>
121 <fileset dir="${fedorags3.src}" includes="**/*.class"/>
122 <fileset dir="${gsearchinstaller.src}" includes="**/*.class"/>
123 </delete>
126<target name="distclean" description="Removes the project-specific jars fedoraGS3.jar, QBRdata.jar, ${} files AND all class files from the GS3DemoClient, GS3Fedora and GSearchInstaller source folders" depends="clean">
127 <delete includeEmptyDirs="true" failonerror="false">
128 <fileset file="${basedir}/GSearchInstaller.jar"/>
129 <fileset file="${basedir}/lib/fedoraGS3.jar"/>
130 <fileset file="${basedir}/lib/QBRdata.jar"/>
131 <fileset file="${basedir}/lib/DLservices.jar"/>
132 <fileset file="${basedir}/${}"/>
133 <fileset file="${basedir}/"/>
134 <fileset dir="logs"/>
135 <fileset file="${log4j.propFile}"/>
136 <fileset file="${dist}/${}.tar"/>
137 <fileset file="${dist}/${}.tar.gz"/>
138 <fileset file="${dist}/${}.zip"/>
139 <fileset file="${dist}/${}.tar.bz2"/>
140 </delete>
143<!-- Targets for updating some source code dependencies from Greenstone SVN -->
144<!-- Explicit update of java file dependencies. First make a directory and copy the old files in there (if they are present)-->
145<target name="update" description="Gets the latest version of, and gs3-client-jar's files from Greenstone's SVN repository">
146 <delete>
147 <fileset dir="${basedir}" includes="CheckJavaVersion.*"/>
148 </delete>
149 <antcall target="update-check-java-version" />
150 <antcall target="update-gs3-for-client" />
153<target name="ensure-gs3-for-client" description="Ensures the ${gs3.files.jar} file of required Greenstone3 support files is there">
154 <condition property="gs3.for.client.exists">
155 <available file="${basedir}/lib/${gs3.files.jar}"/>
156 </condition>
157 <antcall target="update-gs3-for-client" />
160<target name="ensure-check-java-version" description="Ensures the file required to run the demo-client's launching scripts (sh or bat) is present">
161 <condition property="">
162 <and>
163 <available file="${basedir}/CheckJavaVersion.class"/>
164 <available file="${basedir}/"/>
165 </and>
166 </condition>
167 <antcall target="update-check-java-version" />
170<!-- Gets the file if the local copy is missing or out of date (since usetimestamp=true) -->
171<target name="update-check-java-version" description="Gets the latest version of from Greenstone's SVN repository" unless="">
172 <get src="${}"
173 dest="${basedir}/"
174 usetimestamp="true" />
175 <!-- compile it up: specifying the file to be compiled explicitly (sourcepath="")-->
176 <javac sourcepath="" srcdir="${basedir}" destdir="${basedir}" debug="on" debuglevel="lines,vars,source">
177 <include name="**/"/>
178 </javac>
181<target name="update-gs3-for-client" description="Gets the latest version of the files needed to create ${gs3.files.jar} from Greenstone's SVN repository" unless="gs3.for.client.exists">
182 <mkdir dir="${basedir}/tmp" />
183 <echo>Getting java files GSXML, XMLConverter, GSPath and MyNodeList from Greenstone's SVN repository (${gs3forclient.svn.path}). Compiling and jarring them up into ${gs3.files.jar}...</echo>
184 <!-- No point using timestamp here with the get Task, since the tmp file is newly created and will not already have these java files. Get will therefore always retrieve them -->
185 <get src="${gs3forclient.svn.path}/" dest="${basedir}/tmp/" />
186 <get src="${gs3forclient.svn.path}/" dest="${basedir}/tmp/" />
187 <get src="${gs3forclient.svn.path}/" dest="${basedir}/tmp/" />
188 <get src="${gs3forclient.svn.path}/" dest="${basedir}/tmp/" />
189 <!-- compile it up: specifying the file to be compiled explicitly -->
190 <javac srcdir="${basedir}/tmp" destdir="${basedir}/tmp" debug="on" debuglevel="lines,vars,source">
191 <classpath refid="project.classpath"/>
192 <include name="**/*.java"/>
193 </javac>
194 <!-- jar it up (without the java files), placing the jar in the lib folder -->
195 <jar destfile="lib/${gs3.files.jar}" basedir="tmp/" excludes="tmp/*.java" />
196 <delete dir="tmp" />
199<!-- Targets to generate the project-specific jar files QBRdata.jar and fedoraGS3.jar -->
200<target name="QBRdatajar" description="Compiles and creates the QBRdata.jar file needed by GS3demo-client">
201 <javac srcdir="${democlient.rootdir}/${QBRdata.rel.path}" debug="on" debuglevel="lines,vars,source">
202 <classpath refid="project.classpath"/>
203 </javac>
204 <jar destfile="lib/QBRdata.jar"
205 basedir="${democlient.rootdir}/"
206 excludes="${gui.rel.path}/*.*,${dlservices.rel.path}/**,${gs3services.rel.path}/**">
207 </jar>
210<target name="fedoraGS3jar" description="Compiles and creates the fedoraGS3.jar file needed by GS3demo-client">
211 <javac srcdir="${fedorags3.rootdir}" debug="on" debuglevel="lines,vars,source">
212 <classpath refid="project.classpath"/>
213 </javac>
214 <jar destfile="lib/fedoraGS3.jar"
215 basedir="${fedorags3.rootdir}/"/>
218<!-- Target to generate the standalone (reusable) jar files DLservices.jar -->
219<target name="DLservicesjar" description="Compiles and creates the DLservices.jar standalone, reusable library file">
220 <javac srcdir="${democlient.rootdir}/${dlservices.rel.path}" debug="on" debuglevel="lines,vars,source">
221 <classpath refid="project.classpath"/>
222 </javac>
223 <jar destfile="lib/DLservices.jar"
224 basedir="${democlient.rootdir}/"
225 excludes="${gui.rel.path}/*.*,${QBRdata.rel.path}/**,${gs3services.rel.path}/**">
226 </jar>
229<!-- Target that generates the GSearchInstaller jar file -->
230<target name="GSearchInstallerjar" description="Compiles and creates the jar file for the stand-alone GSearchInstaller application">
231 <javac srcdir="${gsearchinstaller.rootdir}" debug="on" debuglevel="lines,vars,source" />
232 <jar destfile="GSearchInstaller.jar"
233 basedir="${gsearchinstaller.rootdir}/"
234 manifest="${gsearchinstaller.rootdir}/Manifest.MF"/>
237<!-- Targets that check for and ensure the existence of project-specific jar files -->
238<target name="check-QBRdata-jar" description="Checks for existence of dependency file QBRdata.jar">
239 <condition property="QBRdata.exists">
240 <available file="${basedir}/lib/QBRdata.jar"/>
241 </condition>
244<target name="ensure-QBRdata-jar" description="Will generate QBRdata.jar if it did not exist" depends="check-QBRdata-jar" unless="QBRdata.exists">
245 <antcall target="QBRdatajar"/>
248<target name="check-fedoraGS3-jar" description="Checks for existence of dependency file fedoraGS3.jar">
249 <condition property="fedoraGS3.exists">
250 <available file="${basedir}/lib/fedoraGS3.jar"/>
251 </condition>
254<target name="ensure-fedoraGS3-jar" description="Will generate fedoraGS3.jar if it did not exist" depends="check-fedoraGS3-jar" unless="fedoraGS3.exists">
255 <antcall target="fedoraGS3jar"/>
258<!-- generates the project's executable -->
259<target name="check-exec-jar" description="Checks for existence of executable file ${}">
260 <condition property="executable.exists">
261 <available file="${basedir}/${}"/>
262 </condition>
265<target name="ensure-exec-jar" description="Will generate ${} if it did not exist" depends="check-exec-jar" unless="executable.exists">
266 <antcall target="build-demo-client"/>
269<!-- Targets that check for and ensure the existence of standalone application GSearchInstaller.jar -->
270<target name="check-gsearchinstall-jar" description="Checks for existence of stand-alone application GSearchInstaller.jar">
271 <condition property="gsearchinstaller.exists">
272 <available file="GSearchInstaller.jar"/>
273 </condition>
276<target name="ensure-gsearchinstall-jar" description="Will generate GSearchInstaller.jar if it did not exist" depends="check-gsearchinstall-jar" unless="gsearchinstaller.exists">
277 <antcall target="GSearchInstallerjar"/>
280<!-- User input for generating compressed output file for one of the chosen file types. A choice of zip, tar.gz (tar gzip), or tar.bz2 (tar bzip)-->
281<target name="create-targzip" if="zip.type" description="User chose to create a tar.gz file of the project">
282 <tar destfile="${dist}/${}.tar.gz" compression="gzip" longfile="gnu">
283 <tarfileset dir="${basedir}" prefix="${}" excludes="${zip.excludes}" />
284 </tar>
285 <echo>If the filepaths are longer than 100 characters, GNU compatible tar commands are necessary to untar the tar.gz</echo>
288<target name="create-tarbzip" if="zip.type" description="User chose to create a tar.bz2 file of the project">
289 <tar destfile="${dist}/${}.tar.bz2" compression="bzip2" longfile="gnu">
290 <tarfileset dir="${basedir}" prefix="${}" excludes="${zip.excludes}" />
291 </tar>
292 <echo>If the filepaths are longer than 100 characters, GNU compatible tar commands are necessary to untar the tar.gz</echo>
295<target name="create-zip" if="zip.type" description="User chose to create a zip file of the project">
296 <zip destfile="${dist}/${}.zip">
297 <zipfileset dir="${basedir}" prefix="${}" excludes="${zip.excludes}" />
298 </zip>
301<target name="get-zipformat">
302<!--<input addproperty="zip.type" validargs="zip,gzip,bzip">--><!-- doesn't work with default value-->
303 <input addproperty="zip.format" defaultvalue="zip">What type of compressed output file do you want to generate?
304Type one of: zip, tar.gz, tar.bz2
305Press enter for default: zip /></input>
306 <condition property="zip.type" value="targzip">
307 <equals arg1="tar.gz" arg2="${zip.format}"/>
308 </condition>
309 <condition property="zip.type" value="zip">
310 <equals arg1="zip" arg2="${zip.format}"/>
311 </condition>
312 <condition property="zip.type" value="tarbzip">
313 <equals arg1="tar.bz2" arg2="${zip.format}"/>
314 </condition>
315 <echo>You chose output file type: ${zip.type}</echo>
316 </target>
Note: See TracBrowser for help on using the repository browser.