[cvs] / jsr166 / build.xml Repository:
ViewVC logotype

Diff of /jsr166/build.xml

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1.27, Wed May 28 00:33:17 2003 UTC revision 1.41, Fri Jun 6 20:48:55 2003 UTC
# Line 1  Line 1 
1  <project name="jsr166" default="usage">  <project name="jsr166" default="usage">
2    
3    <description>    <description>
4    ------------------------------------------------------------------------------
5      Build file for JSR-166      Build file for JSR-166
6    
7      JUnit 3.8 or better must be in ${ant.home}/lib for the test target to work.    Usage: ant [target]
   </description>  
8    
9      User-specific settings are read from user.properties.
10      See user.properties.sample for an explanation of some useful settings.
11    ------------------------------------------------------------------------------
12      </description>
13    
14    <target name="usage" description="Prints this message">    <target name="usage" description="Advises user to run with -projecthelp">
15      <echo>      <echo>Run "ant -projecthelp" for full usage information.</echo>
 ant [target], where target is one of:  
   
  usage       (default) Prints this message  
  compile     Compiles all sources to build folder  
  jar         Builds library jar from compiled sources  
  test        Runs all tests (requires JUnit 1.8 in ${ant.home}/lib)  
  docs        Builds javadocs with custom tags to build folder  
  dist-docs   Builds javadocs without custom tags to dist folder  
  dist        Puts all distributable products in single hierarchy  
   
  clean       Removes all build products  
  dist-clean  Removes all build and distribution products  
   
  checkstyle  Reports on style errors in Java source (verbose, mostly chaff)  
  doccheck    Reports on javadoc style errors (not working yet)  
     </echo>  
16    </target>    </target>
17    
18    
19    <!-- User-specific settings -->    <!-- User-specific settings -->
20    <property file="user.properties"/>    <property file="user.properties"/>
21    
   <!-- Set build.warnings in user.properties to turn on -warnunchecked -->  
   <!-- <property name="build.warnings" value=""/> -->  
   
22    
23    <!-- Compilation options -->    <!-- Compilation options -->
24    <property name="build.sourcelevel"    value="1.5"/>    <property name="build.sourcelevel"    value="1.5"/>
# Line 68  Line 54 
54    
55    <!-- Jar locations -->    <!-- Jar locations -->
56    <property name="product.jar"          location="${build.lib.dir}/jsr166.jar"/>    <property name="product.jar"          location="${build.lib.dir}/jsr166.jar"/>
   <property name="javac.jar"            location="${lib.dir}/javac.jar"/>  
   <property name="collect.jar"          location="${lib.dir}/collect.jar"/>  
57    <property name="junit.jar"            location="${lib.dir}/junit.jar"/>    <property name="junit.jar"            location="${lib.dir}/junit.jar"/>
58    <property name="rt.jar"               location="${java.home}/lib/rt.jar"/>    <property name="rt.jar"               location="${java.home}/lib/rt.jar"/>
59    
60    
   <!--  
    ! Bootclasspath munging for source compilation.  
    -->  
   
   <path id="javac.bootclasspath.prepend">  
     <!-- <pathelement location="${src.dir}"/> -->  
     <pathelement location="${javac.jar}"/>  
   </path>  
   
   <path id="javac.bootclasspath">  
     <!-- <pathelement location="${src.dir}"/> -->  
     <pathelement location="${collect.jar}"/>  
     <pathelement location="${rt.jar}"/>  
   </path>  
   
   <!-- Flatten bootclasspath prefix into a platform-appropriate string -->  
   <property name="javac.bootclasspath.prepend" refid="javac.bootclasspath.prepend"/>  
   
   <!-- Turn the flattened bootclasspath prefix into a javac argument -->  
   <property name="javac.args" value='-J-Xbootclasspath/p:${javac.bootclasspath.prepend}'/>  
   
   
   <!--  
    ! Bootclasspath munging for testing, so JUnit can test our local  
    ! modifications to java.*.  
    -->  
   
   <path id="test.classpath">  
     <pathelement location="${product.jar}"/>  
     <pathelement location="${build.testcases.dir}"/>  
     <pathelement location="${junit.jar}"/>  
   </path>  
   
   <!-- Flatten test classpath into a platform-appropriate string -->  
   <property name="test.classpath" refid="test.classpath"/>  
61    
62    <!-- Turn the flattened test classpath into a javac argument -->    <!-- Files excluded from dist-docs and emulation jar -->
63    <property name="test.javac.args" value='-Xbootclasspath/p:${test.classpath}'/>    <patternset id="unsafe.exclusion">
64        <exclude name="java/util/Random.*"/>
65        <exclude name="sun/misc/Unsafe.*"/>
66      </patternset>
67    
68      <!-- Files excludes from emulation jar -->
69      <patternset id="atomic.exclusion">
70        <exclude name="java/util/concurrent/atomic/AtomicBoolean*"/>
71        <exclude name="java/util/concurrent/atomic/AtomicInteger*"/>
72        <exclude name="java/util/concurrent/atomic/AtomicLong*"/>
73        <exclude name="java/util/concurrent/atomic/AtomicReference*"/>
74      </patternset>
75    
76    
77    
78    <!-- Main targets -->    <!-- Main targets -->
79    
80    <target name="compile" depends="init"    <target name="compile"
81              depends="init, configure-compiler, prepare-src"
82            description="Compiles main sources to build folder">            description="Compiles main sources to build folder">
83    
84        <property name="prepare.src.dir" value="${src.dir}"/>
85    
86      <mkdir dir="${build.classes.dir}"/>      <mkdir dir="${build.classes.dir}"/>
87    
88      <javac srcdir="${src.dir}"  <!--
89        <echo>javac ${gjc.args}</echo>
90        <echo>bootclasspath=${compile.bootclasspath}</echo>
91    -->
92    
93        <javac srcdir="${prepare.src.dir}"
94            destdir="${build.classes.dir}"            destdir="${build.classes.dir}"
95              debug="${build.debug}"              debug="${build.debug}"
96         debuglevel="${build.debuglevel}"         debuglevel="${build.debuglevel}"
# Line 130  Line 98 
98             source="${build.sourcelevel}"             source="${build.sourcelevel}"
99               fork="true">               fork="true">
100    
101        <bootclasspath refid="javac.bootclasspath"/>        <compilerarg    line="${gjc.args}"/>
102        <compilerarg line="${javac.args} ${build.warnings.option}"/>        <bootclasspath refid="compile.bootclasspath"/>
103    
104      </javac>      </javac>
105    
106    </target>    </target>
107    
108    
109    <target name="jar" depends="native-jar, emulation-jar"/>    <target name="jar"
110              depends="configure-emulation, init-jar, native-jar, emulation-jar"
111              description="Builds library jar from compiled sources"/>
112    
113    
114    <target name="test" depends="init, check-junit, report-tests"    <target name="test"
115            description="Runs all tests (requires JUnit 3.8+ in ${ant.home}/lib)"            depends="init, configure-tests, report-tests"
116    />            description="Runs all tests (requires JUnit 3.8.1 in ${ant.home}/lib)" />
117    
118    
119    <target name="checkstyle" depends="filter-src"    <target name="checkstyle"
120              depends="filter-src"
121            description="Reports on style errors in Java source (verbose, mostly chaff)">            description="Reports on style errors in Java source (verbose, mostly chaff)">
122    
123      <taskdef resource="checkstyletask.properties"      <taskdef resource="checkstyletask.properties"
# Line 160  Line 131 
131    </target>    </target>
132    
133    
134    <target name="doccheck" depends="filter-src"    <target name="doccheck"
135              depends="filter-src"
136            description="Reports on javadoc style errors (not working yet)">            description="Reports on javadoc style errors (not working yet)">
137    
138      <delete dir="${build.doccheck.dir}"/>      <delete dir="${build.doccheck.dir}"/>
# Line 175  Line 147 
147    </target>    </target>
148    
149    
150    <target name="docs" depends="filter-src"    <target name="docs"
151              depends="filter-src"
152            description="Builds javadocs with custom tags to build folder">            description="Builds javadocs with custom tags to build folder">
153    
154      <delete dir="${build.javadocs.dir}"/>      <delete dir="${build.javadocs.dir}"/>
# Line 190  Line 163 
163        <tag name="spec" description="Specified by:"/>        <tag name="spec" description="Specified by:"/>
164        <tag name="editor" description="Last edited by:"/>        <tag name="editor" description="Last edited by:"/>
165        <tag name="fixme" description="FIX ME:"/>        <tag name="fixme" description="FIX ME:"/>
166    
167        <packageset dir="${build.filter.src.dir}"/>        <packageset dir="${build.filter.src.dir}"/>
168    
169      </javadoc>      </javadoc>
# Line 197  Line 171 
171    </target>    </target>
172    
173    
174      <target name="strip"
175              depends="init, configure-compiler"
176              description="Strip generics from java source (not working yet)">
177    
178        <mkdir dir="${build.stripped.dir}"/>
179    
180    <!--    <!--
181     # javac -s doesn't reliably generate compilable code. It generates     # javac -s doesn't reliably generate compilable code. It generates
182     # bridge methods (marked as "synthetic") that can have identical     # bridge methods (marked as "synthetic") that can have identical
183     # signatures to existing methods except for the return value.     # signatures to existing methods except for the return value.
184     -->     -->
   <target name="strip" depends="init">  
   
     <mkdir dir="${build.stripped.dir}"/>  
   
185      <javac srcdir="${src.dir}"      <javac srcdir="${src.dir}"
186            destdir="${build.stripped.dir}"            destdir="${build.stripped.dir}"
187              debug="${build.debug}"              debug="${build.debug}"
# Line 214  Line 190 
190             source="${build.sourcelevel}"             source="${build.sourcelevel}"
191               fork="true">               fork="true">
192    
193        <bootclasspath refid="javac.bootclasspath"/>        <compilerarg    line="${gjc.args} -s"/>
194        <compilerarg line="${javac.args} ${build.warnings.option} -s"/>        <bootclasspath refid="compile.bootclasspath"/>
195    
196      </javac>      </javac>
197    
198    </target>    </target>
199    
200    
201    <target name="dist" depends="init, dist-clean, dist-jar, dist-docs"    <target name="dist"
202              depends="init, dist-clean, dist-jar, dist-docs"
203            description="Puts all distributable products in single hierarchy"/>            description="Puts all distributable products in single hierarchy"/>
204    
205    
# Line 244  Line 221 
221    </target>    </target>
222    
223    
224    <!-- Anthill targets -->    <target name="dist-docs"
225              depends="filter-src"
226    <!-- Should really run the tests instead of just the jar target -->            description="Builds javadocs without custom tags to dist folder">
   <target name="anthill-build" depends="jar, test, docs, dist-docs"/>  
   
   <target name="anthill-publish">  
     <copy todir="${deployDir}/docs/private">  
       <fileset dir="${build.javadocs.dir}"/>  
     </copy>  
     <copy todir="${deployDir}/docs/public">  
       <fileset dir="${dist.javadocs.dir}"/>  
     </copy>  
     <copy tofile="${deployDir}/index.html"  
           file="${basedir}/etc/anthill-index.html"/>  
     <copy todir="${deployDir}/notes">  
       <fileset dir="${basedir}/etc/notes"/>  
     </copy>  
   </target>  
227    
228        <delete dir="${dist.javadocs.dir}"/>
229        <mkdir dir="${dist.javadocs.dir}"/>
230    
231    <!-- Internal targets -->      <javadoc destdir="${dist.javadocs.dir}"
232                    link="http://java.sun.com/j2se/1.4.1/docs/api"
233                overview="${src.dir}/intro.html"
234                  source="${build.docsourcelevel}">
235    
236    <target name="set-warnings-if" if="build.warnings">        <packageset dir="${build.filter.src.dir}"/>
237    
238      <property name="build.warnings.option" value="-warnunchecked"/>      </javadoc>
239    
240    </target>    </target>
241    
242    
   <target name="set-warnings-unless" unless="build.warnings">  
   
     <property name="build.warnings.option" value=""/>  
243    
244    </target>    <!-- Internal targets -->
245    
246    
247    <target name="init" depends="set-warnings-if, set-warnings-unless">    <target name="init">
248    
249      <!-- Version is kept in a separate file -->      <!-- Version is kept in a separate file -->
250      <loadfile property="version" srcFile="version.properties"/>      <loadfile property="version" srcFile="version.properties"/>
# Line 289  Line 253 
253    </target>    </target>
254    
255    
256    <target name="native-jar" depends="compile"    <target name="init-jar">
           description="Builds library jar from compiled sources">  
257    
258      <mkdir dir="${build.lib.dir}"/>      <mkdir dir="${build.lib.dir}"/>
259    
260      </target>
261    
262    
263      <target name="native-jar"
264              depends="compile"
265              unless="build.emulation.true">
266    
267      <jar destfile="${product.jar}">      <jar destfile="${product.jar}">
268        <fileset dir="${build.classes.dir}"/>        <fileset dir="${build.classes.dir}"/>
269      </jar>      </jar>
# Line 301  Line 271 
271    </target>    </target>
272    
273    
274    <target name="compile-emulation" depends="init"    <target name="compile-emulation"
275            if="build.emulation"            depends="init, configure-compiler"
276            description="Compiles emulation sources to build folder">            if="build.emulation.true">
277    
278      <mkdir dir="${build.emulation.dir}"/>      <mkdir dir="${build.emulation.dir}"/>
279    
# Line 315  Line 285 
285             source="${build.sourcelevel}"             source="${build.sourcelevel}"
286               fork="true">               fork="true">
287    
288        <bootclasspath refid="javac.bootclasspath"/>        <compilerarg    line="${gjc.args}"/>
289        <compilerarg line="${javac.args} ${build.warnings.option}"/>        <bootclasspath refid="compile.bootclasspath"/>
290    
291      </javac>      </javac>
292    
293    </target>    </target>
294    
295    
296    <target name="emulation-jar" depends="native-jar, compile-emulation"    <target name="emulation-jar"
297            if="build.emulation">            depends="compile-emulation"
298              if="build.emulation.true">
299    
300    
301      <jar destfile="${product.jar}" update="true" duplicate="add">      <jar destfile="${product.jar}" duplicate="add">
302          <fileset dir="${build.classes.dir}">
303            <patternset refid="atomic.exclusion"/>
304            <patternset refid="unsafe.exclusion"/>
305          </fileset>
306        <fileset dir="${build.emulation.dir}"/>        <fileset dir="${build.emulation.dir}"/>
307      </jar>      </jar>
308    
309    </target>    </target>
310    
311    
312    <target name="dist-jar" depends="clean, jar">    <target name="dist-jar"
313              depends="clean, jar">
314    
315      <copy file="${product.jar}" todir="${dist.dir}"/>      <copy file="${product.jar}" todir="${dist.dir}"/>
316    
317    </target>    </target>
318    
319    
320    <target name="dist-docs" depends="filter-src"    <target name="compile-ant-filter"
321            description="Builds javadocs without custom tags to dist folder">            depends="init">
   
     <delete dir="${dist.javadocs.dir}"/>  
     <mkdir dir="${dist.javadocs.dir}"/>  
   
     <javadoc destdir="${dist.javadocs.dir}"  
                 link="http://java.sun.com/j2se/1.4.1/docs/api"  
             overview="${src.dir}/intro.html"  
               source="${build.docsourcelevel}">  
   
       <packageset dir="${build.filter.src.dir}"/>  
   
     </javadoc>  
   
   </target>  
   
   
   <target name="compile-ant-filter" depends="init">  
322    
323      <mkdir dir="${build.ant.dir}"/>      <mkdir dir="${build.ant.dir}"/>
324    
# Line 370  Line 330 
330    </target>    </target>
331    
332    
333    <target name="filter-src" depends="compile-ant-filter">    <target name="filter-src"
334              depends="compile-ant-filter">
335    
336      <mkdir dir="${build.filter.src.dir}"/>      <mkdir dir="${build.filter.src.dir}"/>
337    
338      <copy todir="${build.filter.src.dir}">      <copy todir="${build.filter.src.dir}">
339        <fileset dir="${src.dir}">        <fileset dir="${src.dir}">
340          <include name="**/*.java"/>          <include name="**/*.html"/>
341          <exclude name="**/Random.java"/>        </fileset>
342          <exclude name="**/Unsafe.java"/>      </copy>
343    
344        <!-- Not needed now, used for doccheck filtering:
345        <property name="generic.declarations"
346                 value="public interface E {} public interface T {} public interface K {} public interface V {}"
347        />
348        -->
349    
350        <copy todir="${build.filter.src.dir}">
351          <fileset dir="${src.dir}">
352            <exclude name="**/*.html"/>
353            <patternset refid="unsafe.exclusion"/>
354        </fileset>        </fileset>
355        <filterchain>        <filterchain>
356          <filterreader classname="jsr166.ant.filters.ReplaceFilter"  
                       classpath="${build.ant.dir}">  
357            <!--            <!--
358             # These arguments are to get rid of angle-bracketed type           # This filter gets rid of angle-bracketed type parameters
359             # parameters so that javadoc can run on the result. The           # so that javadoc can run on the result. The following
360             # following heuristic that seems to work:           # heuristic seems to work:
361             #             #
362             # For all lines not starting with space(s)-asterisk-space(s),             # For all lines not starting with space(s)-asterisk-space(s),
363             #   replace <something> with a space, where there may be more             #   replace <something> with a space, where there may be more
# Line 394  Line 365 
365             #   must not contain parens or pipes. (This may need some             #   must not contain parens or pipes. (This may need some
366             #   tweaking.)             #   tweaking.)
367             -->             -->
368    
369            <filterreader classname="jsr166.ant.filters.ReplaceFilter"
370                          classpath="${build.ant.dir}">
371            <param name="notmatching" value="^\s+\*\s.*$"/>            <param name="notmatching" value="^\s+\*\s.*$"/>
372            <param name="pattern" value="&lt;[^|>()]+?>+"/>            <param name="pattern" value="&lt;[^|>()]+?>+"/>
373            <param name="replacement" value=" "/>            <param name="replacement" value=" "/>
374          </filterreader>          </filterreader>
375          <filterreader classname="jsr166.ant.filters.ReplaceFilter"  
376                        classpath="${build.ant.dir}">  
377            <!--            <!--
378             # These arguments are to uncomment lines beginning with           # This filter uncomments lines beginning with "//@" so that
379             # "//@" so that javadoc can see imports that are needed           # javadoc can see imports that are needed to resolve links
380             # to resolve links but that shouldn't be in the compiled           # but that shouldn't be in the compiled code.
            # code.  
381             -->             -->
382    
383            <filterreader classname="jsr166.ant.filters.ReplaceFilter"
384                          classpath="${build.ant.dir}">
385            <param name="matching" value="^//@.*$"/>            <param name="matching" value="^//@.*$"/>
386            <param name="pattern" value="^//@"/>            <param name="pattern" value="^//@"/>
387            <param name="replacement" value=""/>            <param name="replacement" value=""/>
388          </filterreader>          </filterreader>
389    
390    
391            <!--
392             # The next two filters try to make the source look like
393             # something that doccheck can process. The first removes
394             # -source 1.4 assertions and the second adds in a bunch
395             # of single letter public nested marker interfaces so that
396             # the generic type parameters are recognized.
397             #
398             # Currently commented out because doccheck doesn't work. :-(
399             -->
400    
401            <!--
402            <filterreader classname="jsr166.ant.filters.ReplaceFilter"
403                          classpath="${build.ant.dir}">
404              <param name="matching"    value="^\s*assert[\s ].*$"/>
405              <param name="pattern"     value="assert"/>
406              <param name="replacement" value="//assert"/>
407            </filterreader>
408    
409            <filterreader classname="jsr166.ant.filters.ReplaceFilter"
410                          classpath="${build.ant.dir}">
411              <param name="matching"    value="^(.*(class|interface|implements) .*|)\{.*$"/>
412              <param name="pattern"     value="$"/>
413              <param name="replacement" value=" ${generic.declarations}"/>
414            </filterreader>
415            -->
416    
417        </filterchain>        </filterchain>
418      </copy>      </copy>
419    
420    </target>    </target>
421    
422    
423    <target name="compile-tests" depends="jar">    <target name="compile-tests"
424              depends="jar">
425    
426      <mkdir dir="${build.testcases.dir}"/>      <mkdir dir="${build.testcases.dir}"/>
427    
428    <!--
429        <echo>javac ${gjc.args}</echo>
430        <echo>bootclasspath=${test.compile.bootclasspath}</echo>
431        <echo>classpath="${test.classpath}"</echo>
432    -->
433    
434      <javac srcdir="${test.src.dir}"      <javac srcdir="${test.src.dir}"
435            destdir="${build.testcases.dir}"            destdir="${build.testcases.dir}"
436              debug="${build.debug}"              debug="${build.debug}"
# Line 428  Line 439 
439             source="${build.sourcelevel}"             source="${build.sourcelevel}"
440               fork="true">               fork="true">
441    
442        <bootclasspath refid="javac.bootclasspath"/>        <compilerarg    line="${gjc.args}"/>
443        <compilerarg line="${javac.args} ${build.warnings.option}"/>        <bootclasspath refid="test.compile.bootclasspath"/>
444        <classpath refid="test.classpath"/>        <classpath refid="test.classpath"/>
445    
446      </javac>      </javac>
# Line 437  Line 448 
448    </target>    </target>
449    
450    
451    <target name="run-tests" depends="compile-tests">    <target name="run-tests"
452              depends="compile-tests">
453    
454      <!-- May be overridden by user.properties -->      <!-- May be overridden by user.properties -->
455      <property name="testcase" value="*"/>      <property name="testcase" value="*"/>
# Line 451  Line 463 
463                      dir="${build.reports.dir}"                      dir="${build.reports.dir}"
464                     fork="true">                     fork="true">
465    
466        <jvmarg value="${test.javac.args}"/>        <jvmarg value="-Xbootclasspath/p:${test.run.bootclasspath}"/>
467    
468        <formatter type="xml"/>        <formatter type="xml"/>
469    
# Line 466  Line 478 
478    </target>    </target>
479    
480    
481    <target name="report-tests" depends="run-tests">    <target name="report-tests"
482              depends="run-tests">
483    
484      <!-- Sets junit.report.format to frames if Xalan is present,      <!-- Sets junit.report.format to frames if Xalan is present,
485           otherwise sets it to noframes. -->           otherwise sets it to noframes. -->
486      <available property="junit.report.format"      <available property="junit.report.format"
# Line 486  Line 500 
500      </junitreport>      </junitreport>
501    
502      <fail message="Test Cases Failed" if="junit.failed"/>      <fail message="Test Cases Failed" if="junit.failed"/>
503    
504      </target>
505    
506    
507      <target name="configure-compiler">
508    
509        <property name="gjc.version"
510                 value="2.0"/>
511    
512        <condition property="novariance.arg" value="-novariance">
513          <and>
514            <equals arg1="${gjc.version}" arg2="2.0"/>
515            <or>
516              <not><isset property="gjc.novariance"/></not>
517              <istrue value="${gjc.novariance}"/>
518            </or>
519          </and>
520        </condition>
521    
522        <property name="novariance.arg"
523                 value=""/>
524    
525        <property name="gjc.dir"
526                 value="${lib.dir}/gjc"/>
527    
528        <property name="javac.jar"
529              location="${gjc.dir}/${gjc.version}/javac.jar"/>
530    
531        <property name="collect.jar"
532              location="${gjc.dir}/${gjc.version}/collect${novariance.arg}.jar"/>
533    
534    
535        <condition property="warnunchecked.arg" value="-warnunchecked">
536          <istrue value="${gjc.warnunchecked}"/>
537        </condition>
538    
539        <property name="warnunchecked.arg" value=""/>
540    
541        <condition property="prepare.src.dir" value="${build.dir}/prepare-src">
542          <istrue value="${build.nothreads}"/>
543        </condition>
544    
545    
546        <!--
547         ! Bootclasspath munging for source compilation.
548         -->
549    
550        <path id="pre.bootclasspath">
551          <pathelement location="${javac.jar}"/>
552        </path>
553    
554        <path id="compile.bootclasspath">
555          <pathelement location="${build.classes.dir}"/>
556          <pathelement location="${collect.jar}"/>
557          <pathelement location="${rt.jar}"/>
558        </path>
559    
560        <!-- Flatten paths into platform-appropriate strings -->
561        <property name="pre.bootclasspath"     refid="pre.bootclasspath"/>
562        <property name="compile.bootclasspath" refid="compile.bootclasspath"/>
563    
564    
565        <!-- Common options in javac invocations -->
566        <property name="gjc.args"
567                 value="-J-Xbootclasspath/p:${pre.bootclasspath} ${warnunchecked.arg} ${novariance.arg}"
568        />
569    
570      </target>
571    
572    
573      <target name="prepare-src"
574              depends="configure-compiler"
575              if="prepare.src.dir">
576    
577        <mkdir dir="${prepare.src.dir}"/>
578        <copy todir="${prepare.src.dir}">
579          <fileset dir="${src.dir}">
580            <exclude name="java/lang/**"/>
581          </fileset>
582        </copy>
583    
584      </target>
585    
586    
587      <target name="configure-emulation">
588    
589        <condition property="build.emulation.true">
590          <or>
591            <and>
592              <os family="windows"/>
593              <not>
594                <isset property="build.emulation"/>
595              </not>
596            </and>
597            <istrue value="${build.emulation}"/>
598          </or>
599        </condition>
600    
601    </target>    </target>
602    
603    
604    <target name="check-junit">    <target name="configure-tests"
605      <!-- FIXME: this test isn't specific enough -->         depends="configure-compiler">
606    
607        <!-- junit.framework.Protectable is in JUnit 3.8.1 but not in 3.7 -->
608      <available property="junit.available"      <available property="junit.available"
609                 classname="junit.framework.TestCase"/>                 classname="junit.framework.Protectable"/>
610      <fail message="Need JUnit 3.8 to run tests" unless="junit.available"/>  
611        <fail message="Need JUnit 3.8.1 in ${ant.home}${file.separator}lib to run tests"
612              unless="junit.available"/>
613    
614    
615        <!--
616         ! Bootclasspath munging for testing, so JUnit can test our local
617         ! modifications to java.*.
618         -->
619    
620        <path id="test.classpath">
621          <pathelement location="${product.jar}"/>
622          <pathelement location="${build.testcases.dir}"/>
623          <pathelement location="${junit.jar}"/>
624        </path>
625    
626        <path id="test.compile.bootclasspath">
627          <pathelement location="${javac.jar}"/>
628          <pathelement location="${collect.jar}"/>
629          <pathelement location="${rt.jar}"/>
630        </path>
631    
632        <path id="test.run.bootclasspath">
633          <pathelement location="${javac.jar}"/>
634          <path refid="test.classpath"/>
635        </path>
636    
637        <!-- Flatten test classpaths into platform-appropriate strings -->
638        <property name="test.classpath"             refid="test.classpath"/>
639        <property name="test.compile.bootclasspath" refid="test.compile.bootclasspath"/>
640        <property name="test.run.bootclasspath"     refid="test.run.bootclasspath"/>
641    
642      </target>
643    
644    
645    
646      <!-- Anthill targets -->
647    
648      <target name="anthill-build"
649              depends="jar, test, docs, dist-docs"/>
650    
651      <target name="anthill-publish">
652    
653        <copy todir="${deployDir}/docs/private">
654          <fileset dir="${build.javadocs.dir}"/>
655        </copy>
656    
657        <copy todir="${deployDir}/docs/public">
658          <fileset dir="${dist.javadocs.dir}"/>
659        </copy>
660    
661        <copy tofile="${deployDir}/index.html"
662              file="${basedir}/etc/anthill-index.html"/>
663    
664        <copy todir="${deployDir}/notes">
665          <fileset dir="${basedir}/etc/notes"/>
666        </copy>
667    
668    </target>    </target>
669    
670    

Legend:
Removed from v.1.27  
changed lines
  Added in v.1.41

Doug Lea
ViewVC Help
Powered by ViewVC 1.0.8