ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/jsr166/jsr166/build.xml
(Generate patch)

Comparing jsr166/build.xml (file contents):
Revision 1.112 by jsr166, Sun Jan 20 03:44:54 2013 UTC vs.
Revision 1.131 by jsr166, Fri Feb 1 18:31:17 2013 UTC

# Line 22 | Line 22
22    $HOME/jdk/src/jdk8
23    where each of the above is a complete JDK source tree
24    (e.g. mercurial forest) or a symlink to same.
25 + As of 2013-02, the very latest lambda 8 jdk is needed for jdk8.
26   ------------------------------------------------------------------------------
27    </description>
28  
29 <  <target name="usage" description="Advises user to run with -projecthelp">
30 <    <echo>Run "ant -projecthelp" for full usage information.</echo>
29 >  <target name="usage" description="Display main targets by running 'ant -projecthelp'">
30 >    <java classname="org.apache.tools.ant.Main">
31 >      <arg value="-projecthelp" />
32 >    </java>
33    </target>
34  
35  
# Line 35 | Line 38
38  
39  
40    <!-- Compilation options -->
41 <  <property name="build.sourcelevel"    value="1.6"/>
41 >  <property name="build.sourcelevel"    value="6"/>
42    <property name="build.debug"          value="true"/>
43    <property name="build.debuglevel"     value="source,lines,vars"/>
44    <property name="build.deprecation"    value="false"/>
45 +  <property name="build.javadoc.access" value="protected"/>
46  
47    <!-- Build locations -->
48    <property name="build.dir"                   location="build"/>
# Line 49 | Line 53
53  
54    <property name="build.4jdk7.dir"             location="${build.dir}/jsr166-4jdk7"/>
55    <property name="build.4jdk7.classes.dir"     location="${build.4jdk7.dir}/classes"/>
56 <  <property name="build.4jdk7.tck.classes.dir" location="${build.4jdk7.dir}/tck/classes"/>
56 >  <property name="build.4jdk7.tck.classes.dir" location="${build.4jdk7.dir}/tck-classes"/>
57    <property name="build.4jdk7.docs.dir"        location="${build.4jdk7.dir}/docs"/>
58  
59    <property name="build.jsr166x.dir"           location="${build.dir}/jsr166x"/>
# Line 57 | Line 61
61    <property name="build.jsr166e.dir"           location="${build.dir}/jsr166e"/>
62    <property name="build.extra166y.dir"         location="${build.dir}/extra166y"/>
63  
64 <  <!-- JDK binary locations -->
64 >  <property name="build.jsr166x.classes.dir"   location="${build.jsr166x.dir}/classes"/>
65 >  <property name="build.jsr166y.classes.dir"   location="${build.jsr166y.dir}/classes"/>
66 >  <property name="build.jsr166e.classes.dir"   location="${build.jsr166e.dir}/classes"/>
67 >  <property name="build.extra166y.classes.dir" location="${build.extra166y.dir}/classes"/>
68 >
69 >  <!-- JDK locations -->
70    <property name="jdks.home"  location="${user.home}/jdk"/>
71  
72    <macrodef name="defjdklocations">
# Line 67 | Line 76
76      <property name="java@{v}"       location="${jdk@{v}.home}/bin/java"/>
77      <property name="javac@{v}"      location="${jdk@{v}.home}/bin/javac"/>
78      <property name="javadoc@{v}"    location="${jdk@{v}.home}/bin/javadoc"/>
70    <property name="bootdir@{v}"    location="${jdk@{v}.home}/jre/lib"/>
79      <property name="jdk@{v}src.dir" location="${jdks.home}/src/jdk@{v}/jdk/src/share/classes"/>
80 <    <property name="bootclasspath@{v}"
81 <     value="${bootdir@{v}}/resources.jar:${bootdir@{v}}/rt.jar:${bootdir@{v}}/jsse.jar:${bootdir@{v}}/jce.jar:${bootdir@{v}}/:${bootdir@{v}}/charsets.jar"/>
80 >    <local name="boot.jar.dir"/>
81 >    <property name="boot.jar.dir"   location="${jdk@{v}.home}/jre/lib"/>
82 >    <path id="bootclasspath@{v}">
83 >      <pathelement path="${boot.jar.dir}/resources.jar"/>
84 >      <pathelement path="${boot.jar.dir}/rt.jar"/>
85 >      <pathelement path="${boot.jar.dir}/jsse.jar"/>
86 >      <pathelement path="${boot.jar.dir}/jce.jar"/>
87 >      <pathelement path="${boot.jar.dir}/charsets.jar"/>
88 >    </path>
89 >    <property name="bootclasspath@{v}" value="${toString:bootclasspath@{v}}"/>
90      </sequential>
91    </macrodef>
92  
93 <  <defjdklocations v="6"/>
94 <  <defjdklocations v="7"/>
95 <  <defjdklocations v="8"/>
80 <
81 <  <macrodef name="run-tck-tests">
82 <    <attribute name="jvm"/>
83 <    <attribute name="tck.classes"/>
84 <    <attribute name="product.jar" default="${product.jar}"/>
85 <    <attribute name="jvmflags" default=""/>
93 >  <macrodef name="mirror-dir">
94 >    <attribute name="src"/>
95 >    <attribute name="dst"/>
96      <sequential>
97 <    <java classname="JSR166TestCase"
98 <          jvm="@{jvm}" fork="true">
99 <        <jvmarg value="-Xbootclasspath/p:@{product.jar}"/>
100 <        <jvmarg line="@{jvmflags}"/>
101 <        <classpath>
92 <          <pathelement location="${junit.jar}"/>
93 <          <pathelement location="@{tck.classes}"/>
94 <        </classpath>
95 <    </java>
97 >    <delete dir="@{dst}"/>
98 >    <mkdir dir="@{dst}"/>
99 >    <copy todir="@{dst}" preservelastmodified="true">
100 >      <fileset dir="@{src}"/>
101 >    </copy>
102      </sequential>
103    </macrodef>
104  
105 +  <defjdklocations v="6"/>
106 +  <defjdklocations v="7"/>
107 +  <defjdklocations v="8"/>
108 +
109    <!-- Source locations -->
110    <property name="src.dir"              location="${basedir}/src/main"/>
111    <property name="test.src.dir"         location="${basedir}/src/test"/>
# Line 111 | Line 121
121    <property name="jsr166esrc.dir"       location="${topsrc.dir}/jsr166e"/>
122    <property name="extra166ysrc.dir"     location="${topsrc.dir}/extra166y"/>
123  
124 <  <!-- Distribution locations -->
125 <  <property name="dist.javadocs.dir"          location="${dist.dir}/jsr166.docs"/>
126 <  <property name="dist.4jdk7.docs.dir"        location="${dist.dir}/jsr166-4jdk7.docs"/>
127 <  <property name="dist.jsr166xjavadocs.dir"   location="${dist.dir}/jsr166x.docs"/>
128 <  <property name="dist.jsr166yjavadocs.dir"   location="${dist.dir}/jsr166y.docs"/>
129 <  <property name="dist.jsr166ejavadocs.dir"   location="${dist.dir}/jsr166e.docs"/>
130 <  <property name="dist.extra166yjavadocs.dir" location="${dist.dir}/extra166y.docs"/>
124 >  <!-- Javadoc locations -->
125 >  <property name="docs.dir"          location="${build.dir}/docs"/>
126 >  <property name="4jdk7docs.dir"     location="${build.4jdk7.dir}/docs"/>
127 >  <property name="jsr166xdocs.dir"   location="${build.jsr166x.dir}/docs"/>
128 >  <property name="jsr166ydocs.dir"   location="${build.jsr166y.dir}/docs"/>
129 >  <property name="jsr166edocs.dir"   location="${build.jsr166e.dir}/docs"/>
130 >  <property name="extra166ydocs.dir" location="${build.extra166y.dir}/docs"/>
131 >
132 >  <property name="dist.docs.dir"          location="${dist.dir}/docs"/>
133 >  <property name="dist.4jdk7docs.dir"     location="${dist.dir}/jsr166-4jdk7docs"/>
134 >  <property name="dist.jsr166xdocs.dir"   location="${dist.dir}/jsr166xdocs"/>
135 >  <property name="dist.jsr166ydocs.dir"   location="${dist.dir}/jsr166ydocs"/>
136 >  <property name="dist.jsr166edocs.dir"   location="${dist.dir}/jsr166edocs"/>
137 >  <property name="dist.extra166ydocs.dir" location="${dist.dir}/extra166ydocs"/>
138  
139    <!-- Jar locations -->
140    <property name="product.jar"      location="${build.dir}/jsr166.jar"/>
# Line 128 | Line 145
145    <property name="extra166y.jar"    location="${build.extra166y.dir}/extra166y.jar"/>
146    <property name="junit.jar"        location="${lib.dir}/junit.jar"/>
147  
131  <!-- Bootclasspath argument -->
132  <property name="bootclasspath.args"   value="-Xbootclasspath/p:${product.jar}"/>
133
148    <!-- Canonical location of jdk API docs, to use with javadoc link attribute -->
149    <property name="jdkapi5docs.url"      value="http://docs.oracle.com/javase/1.5.0/docs/api/"/>
150    <property name="jdkapi6docs.url"      value="http://docs.oracle.com/javase/6/docs/api/"/>
151    <property name="jdkapi7docs.url"      value="http://docs.oracle.com/javase/7/docs/api/"/>
152  
153    <property name="jdkapi8docs.url"      value="http://download.java.net/jdk8/docs/api/"/>
154 <  <!-- The below does not yet exist as of 2012-11 -->
154 >  <!-- The below does not yet exist as of 2013-01 -->
155    <!-- <property name="jdkapi8docs.url" value="http://docs.oracle.com/javase/8/docs/api/"/> -->
156  
157    <!-- Default jdk api doc location (latest stable release seems best) -->
158    <property name="jdkapidocs.url"       value="${jdkapi7docs.url}"/>
159  
160 +  <!-- Define the "jtreg" task -->
161 +  <!-- See the docs in "jtreg -onlineHelp" -->
162 +  <taskdef name="jtreg" classname="com.sun.javatest.regtest.Main$$Ant"
163 +           classpath="${lib.dir}/jtreg.jar" />
164 +
165    <!-- Test classpath -->
166    <path id="test.classpath">
167      <pathelement location="${build.testcases.dir}"/>
168      <pathelement location="${junit.jar}"/>
169    </path>
170  
171 +  <macrodef name="run-tck-tests">
172 +    <attribute name="tck.src.dir" default="${tck.src.dir}"/>
173 +    <attribute name="source" default="6"/>
174 +    <attribute name="target"/>
175 +    <attribute name="workdir"/>
176 +    <attribute name="classes"/>
177 +    <attribute name="jvmflags" default=""/>
178 +    <sequential>
179 +
180 +    <mkdir dir="@{workdir}/tck-classes"/>
181 +
182 +    <javac srcdir="@{tck.src.dir}"
183 +           destdir="@{workdir}/tck-classes"
184 +           debug="${build.debug}"
185 +           debuglevel="${build.debuglevel}"
186 +           deprecation="${build.deprecation}"
187 +           source="@{source}"
188 +           classpath="${junit.jar}"
189 +           bootclasspath="@{classes}:${bootclasspath@{source}}"
190 +           includeAntRuntime="false"
191 +           includeJavaRuntime="false"
192 +           executable="${javac@{target}}"
193 +           fork="true">
194 +
195 +      <include name="*.java"/>
196 +      <compilerarg value="-XDignore.symbol.file=true"/>
197 +      <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
198 +      <compilerarg line="${build.args}"/>
199 +
200 +    </javac>
201 +
202 +    <java classname="JSR166TestCase"
203 +          failonerror="true"
204 +          jvm="${java@{target}}"
205 +          fork="true">
206 +        <jvmarg value="-Xbootclasspath/p:@{classes}"/>
207 +        <jvmarg line="@{jvmflags}"/>
208 +        <classpath>
209 +          <pathelement location="${junit.jar}"/>
210 +          <pathelement location="@{workdir}/tck-classes"/>
211 +        </classpath>
212 +    </java>
213 +
214 +    </sequential>
215 +  </macrodef>
216 +
217    <!-- ALoops classpath -->
218    <path id="loops.classpath">
219      <pathelement location="${build.loops.dir}"/>
220    </path>
221  
222    <!-- Support @jls tag, used in jdk8+ javadoc -->
223 <  <!-- TODO: How do we get &trade to work? -->
159 <  <!-- TODO: Why isn't @jls a "standard" tag? -->
160 <  <!--   property name="javadoc.jls.cite" value="The Java&trade; Language Specification" -->
161 <  <property name="javadoc.jls.cite" value="The Java Language Specification"/>
223 >  <property name="javadoc.jls.cite" value="The Java&amp;trade; Language Specification"/>
224    <property name="javadoc.jls.option" value="jls:a:See &lt;cite&gt;${javadoc.jls.cite}&lt;/cite&gt;:"/>
225  
226    <!-- Main targets -->
# Line 185 | Line 247
247             fork="true">
248  
249        <include name="**/*.java"/>
188      <compilerarg line="${build.args}"/>
250        <compilerarg value="-XDignore.symbol.file=true"/>
251        <compilerarg value="-Xlint:all"/>
191
192 <!--
193      <exclude name="java/lang/**"/>
252        <compilerarg line="${build.args}"/>
195      <compilerarg line="-Xlint -Xmaxwarns 1000"/>
196 -->
253  
254      </javac>
199
255    </target>
256  
257  
203
258    <target name="jar"
259            depends="compile"
260            description="Builds library jar from compiled sources">
# Line 208 | Line 262
262      <jar destfile="${product.jar}">
263        <fileset dir="${build.classes.dir}"/>
264      </jar>
211
265    </target>
266  
267  
215
268    <target name="test"
269            depends="configure-tests, report-tests"
270            description="Runs all tests (requires JUnit 3.8.1 in ${ant.home}/lib)" />
271  
272  
221
273    <target name="docs"
274            description="Builds javadocs for src/main to dist dir">
275  
276 <    <delete dir="${dist.javadocs.dir}"/>
277 <    <mkdir dir="${dist.javadocs.dir}"/>
276 >    <delete dir="${docs.dir}"/>
277 >    <mkdir dir="${docs.dir}"/>
278  
279      <!-- the packagenames="none" hack below prevents scanning the -->
280      <!-- sourcepath for packages -->
281  
282 <    <javadoc destdir="${dist.javadocs.dir}"
282 >    <javadoc destdir="${docs.dir}"
283               packagenames="none"
284               link="${jdkapi8docs.url}"
285               overview="${src.dir}/intro.html"
286 +             access="${build.javadoc.access}"
287               sourcepath="${src.dir}:${jdk8src.dir}"
288               classpath=""
289               executable="${javadoc8}">
238      <arg value="-XDignore.symbol.file=true"/>
239      <arg value="-tag"/>
240      <arg value="${javadoc.jls.option}"/>
290        <fileset dir="${src.dir}" defaultexcludes="yes">
291          <include name="**/*.java"/>
292        </fileset>
293 +      <arg value="-XDignore.symbol.file=true"/>
294 +      <arg value="-tag"/>
295 +      <arg value="${javadoc.jls.option}"/>
296      </javadoc>
245
297    </target>
298  
299  
249
300    <target name="dist"
301 <          depends="dist-clean, dist-jar, docs"
301 >          depends="dist-clean, dist-jar, dist-docs"
302            description="Puts all distributable products in single hierarchy"/>
303  
304  
# Line 267 | Line 317
317        <exclude name="**/SyntaxTest.java"/>
318        <exclude name="**/SuperfluousAbstract.java"/>
319      </jar>
270
320    </target>
321  
322  
274
323    <target name="clean"
324            description="Removes all build products">
325  
# Line 280 | Line 328
328    </target>
329  
330  
283
331    <target name="dist-clean"
332            description="Removes all build and distribution products">
333  
# Line 289 | Line 336
336    </target>
337  
338  
292
339    <!-- Internal targets -->
340  
341  
342    <target name="dist-jar"
343            depends="clean, jar">
298
344      <copy file="${product.jar}" todir="${dist.dir}"/>
345 +  </target>
346  
347 +  <target name="dist-docs"
348 +          depends="clean, docs">
349 +    <mirror-dir src="${docs.dir}" dst="${dist.docs.dir}"/>
350    </target>
351  
352  
# Line 313 | Line 362
362             deprecation="${build.deprecation}"
363             source="6"
364             classpath="${junit.jar}"
365 <           bootclasspath="${product.jar}:${bootclasspath6}"
365 >           bootclasspath="@{product.jar}:${bootclasspath6}"
366             includeAntRuntime="false"
367             includeJavaRuntime="false"
368             executable="${javac8}"
369             fork="true">
370  
371        <include name="**/*.java"/>
323      <compilerarg line="${build.args}"/>
372        <compilerarg value="-XDignore.symbol.file=true"/>
373        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
374 +      <compilerarg line="${build.args}"/>
375  
376      </javac>
377  
# Line 333 | Line 382
382             deprecation="${build.deprecation}"
383             source="6"
384             classpath=""
385 <           bootclasspath="${product.jar}:${bootclasspath6}"
385 >           bootclasspath="@{product.jar}:${bootclasspath6}"
386             includeAntRuntime="false"
387             includeJavaRuntime="false"
388             executable="${javac8}"
389             fork="true">
390  
391        <include name="jsr166/test/**/*.java"/>
343
344      <compilerarg line="${build.args}"/>
392        <compilerarg value="-XDignore.symbol.file=true"/>
393        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
394 +      <compilerarg line="${build.args}"/>
395  
396      </javac>
397  
# Line 356 | Line 404
404             source="${build.sourcelevel}"
405               fork="true">
406  
407 <      <compilerarg value="${bootclasspath.args}"/>
360 <      <compilerarg line="${build.args}"/>
407 >      <compilerarg value="-Xbootclasspath/p:${product.jar}"/>
408        <compilerarg value="-XDignore.symbol.file=true"/>
409 +      <compilerarg line="${build.args}"/>
410  
411      </javac>
412   -->
413  
414    </target>
415  
416 +  <target name="test-tck"
417 +          depends="jar"
418 +          description="Runs tck tests for main directly">
419 +
420 +    <run-tck-tests
421 +      target="8"
422 +      workdir="${build.dir}"
423 +      classes="${product.jar}"/>
424 +  </target>
425  
426    <target name="run-tests"
427            depends="compile-tests">
# Line 511 | Line 568
568  
569    <!-- jsr166 4jdk7 -->
570  
514
571    <target name="4jdk7compile"
572            depends="configure-compiler"
573            description="Compiles src/jdk7 sources, targeting jdk7">
# Line 532 | Line 588
588             fork="true">
589  
590        <include name="**/*.java"/>
535      <compilerarg line="${build.args}"/>
591        <compilerarg value="-XDignore.symbol.file=true"/>
592        <compilerarg value="-Xlint:all"/>
593 +      <compilerarg line="${build.args}"/>
594  
595      </javac>
596 +  </target>
597  
541    <jar destfile="${4jdk7product.jar}" index="true">
542      <fileset dir="${build.4jdk7.classes.dir}"/>
543    </jar>
544
545    <mkdir dir="${build.4jdk7.tck.classes.dir}"/>
546
547    <javac srcdir="${tck.src.dir}"
548           destdir="${build.4jdk7.tck.classes.dir}"
549           debug="${build.debug}"
550           debuglevel="${build.debuglevel}"
551           deprecation="${build.deprecation}"
552           source="6"
553           classpath="${junit.jar}"
554           bootclasspath="${4jdk7product.jar}:${bootclasspath6}"
555           includeAntRuntime="false"
556           includeJavaRuntime="false"
557           executable="${javac7}"
558           fork="true">
598  
599 <      <include name="**/*.java"/>
600 <      <compilerarg line="${build.args}"/>
601 <      <compilerarg value="-XDignore.symbol.file=true"/>
563 <      <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
599 >  <target name="4jdk7jar"
600 >          depends="4jdk7compile"
601 >          description="Builds library jar from compiled sources">
602  
603 <    </javac>
603 >    <jar destfile="${4jdk7product.jar}">
604 >      <fileset dir="${build.4jdk7.classes.dir}"/>
605 >    </jar>
606  
607    </target>
608  
609  
610    <target name="4jdk7-test-tck"
611 <          depends="4jdk7compile"
611 >          depends="4jdk7jar"
612            description="Runs tck tests for jsr166-4jdk7 directly">
613 +
614      <run-tck-tests
615 <      jvm="${java7}"
616 <      tck.classes="${build.4jdk7.tck.classes.dir}"
617 <      product.jar="${4jdk7product.jar}"/>
615 >      target="7"
616 >      workdir="${build.4jdk7.dir}"
617 >      classes="${4jdk7product.jar}"/>
618    </target>
619  
620  
# Line 605 | Line 646
646      </junit>
647    </target>
648  
649 +  <target name="4jdk7-test-jtreg"
650 +          depends="4jdk7compile"
651 +          description="Runs jtreg tests for jsr166-4jdk7 using the jtreg ant task">
652 +    <delete dir="${build.4jdk7.dir}/JTwork"   quiet="true"/>
653 +    <delete dir="${build.4jdk7.dir}/JTreport" quiet="true"/>
654 +    <mkdir dir="${build.4jdk7.dir}/JTwork/scratch"/>
655 +    <mkdir dir="${build.4jdk7.dir}/JTreport"/>
656 +    <jtreg dir="${jtreg.src.dir}"
657 +           jdk="${jdk7.home}"
658 +           workDir="${build.4jdk7.dir}/JTwork"
659 +           reportDir="${build.4jdk7.dir}/JTreport">
660 +
661 +      <arg value="-Xbootclasspath/p:${4jdk7product.jar}"/>
662 +      <arg value="-agentvm"/>
663 +      <arg value="-v:nopass,fail"/>
664 +      <arg value="-vmoptions:-esa -ea"/>
665 +      <arg value="-automatic"/>
666 +      <arg value="-k:!ignore"/>
667 +    </jtreg>
668 +  </target>
669 +
670 +
671 +  <target name="4jdk7-test"
672 +          depends="4jdk7-test-tck, 4jdk7-test-jtreg"
673 +          description="Runs tck and jtreg tests for jsr166-4jdk7">
674 +  </target>
675 +
676  
677    <target name="4jdk7docs"
678            description="Builds javadocs for src/jdk7 to dist dir">
679  
680 <    <delete dir="${dist.4jdk7.docs.dir}"/>
681 <    <mkdir dir="${dist.4jdk7.docs.dir}"/>
680 >    <delete dir="${4jdk7docs.dir}"/>
681 >    <mkdir dir="${4jdk7docs.dir}"/>
682  
683 <    <javadoc destdir="${dist.4jdk7.docs.dir}"
683 >    <javadoc destdir="${4jdk7docs.dir}"
684               packagenames="none"
685               link="${jdkapi7docs.url}"
686               overview="${4jdk7src.dir}/intro.html"
687 +             access="${build.javadoc.access}"
688               sourcepath="${4jdk7src.dir}:${jdk7src.dir}"
689               classpath=""
690               executable="${javadoc7}">
622      <arg value="-XDignore.symbol.file=true"/>
691        <fileset dir="${4jdk7src.dir}" defaultexcludes="yes">
692          <include name="**/*.java"/>
693        </fileset>
694 +      <arg value="-XDignore.symbol.file=true"/>
695      </javadoc>
627
696    </target>
697  
698  
699    <target name="4jdk7dist"
700 <          depends="4jdk7dist-clean, 4jdk7dist-jar, 4jdk7docs"
700 >          depends="4jdk7dist-jar, 4jdk7dist-docs"
701            description="Puts all distributable products in single hierarchy"/>
702  
703  
636
704    <target name="4jdk7clean"
705            description="Removes all 4jdk7 build products">
706  
# Line 642 | Line 709
709    </target>
710  
711  
645
712    <target name="4jdk7dist-clean"
713            description="Removes all build and distribution products">
714  
715    </target>
716  
717    <target name="4jdk7dist-jar"
718 <          depends="4jdk7clean, 4jdk7compile">
653 <
718 >          depends="4jdk7clean, 4jdk7jar">
719      <copy file="${4jdk7product.jar}" todir="${dist.dir}"/>
720 +  </target>
721  
722 +
723 +  <target name="4jdk7dist-docs"
724 +          depends="4jdk7clean, 4jdk7docs">
725 +    <mirror-dir src="${4jdk7docs.dir}" dst="${dist.4jdk7docs.dir}"/>
726    </target>
727  
728  
# Line 662 | Line 732
732            depends="configure-compiler"
733            description="Compiles jsr166x sources to build dir">
734  
735 <    <mkdir dir="${build.jsr166x.dir}"/>
735 >    <mkdir dir="${build.jsr166x.classes.dir}"/>
736  
737      <javac srcdir="${topsrc.dir}"
738 <           destdir="${build.jsr166x.dir}"
738 >           destdir="${build.jsr166x.classes.dir}"
739             debug="${build.debug}"
740             debuglevel="${build.debuglevel}"
741             deprecation="${build.deprecation}"
742             classpath=""
673           source="5"
743             bootclasspath="${bootclasspath6}"
744 +           source="5"
745             includeAntRuntime="false"
746             includeJavaRuntime="false"
747             executable="${javac7}"
748             fork="true">
749  
750        <include name="jsr166x/**/*.java"/>
681      <compilerarg line="${build.args}"/>
751        <compilerarg value="-XDignore.symbol.file=true"/>
752        <compilerarg value="-Xlint:all,-unchecked,-rawtypes"/>
753 +      <compilerarg line="${build.args}"/>
754  
755      </javac>
686
756    </target>
757  
758  
690
759    <target name="jsr166xjar"
760            depends="jsr166xcompile"
761            description="Builds library jar from compiled sources">
762  
763      <jar destfile="${jsr166x.jar}">
764 <      <fileset dir="${build.jsr166x.dir}"/>
764 >      <fileset dir="${build.jsr166x.classes.dir}"/>
765      </jar>
766  
767    </target>
768  
769  
702
770    <target name="jsr166xdocs"
771            description="Builds javadocs to dist dir">
772  
773 <    <delete dir="${dist.jsr166xjavadocs.dir}"/>
774 <    <mkdir dir="${dist.jsr166xjavadocs.dir}"/>
773 >    <delete dir="${jsr166xdocs.dir}"/>
774 >    <mkdir dir="${jsr166xdocs.dir}"/>
775  
776 <    <javadoc destdir="${dist.jsr166xjavadocs.dir}"
776 >    <javadoc destdir="${jsr166xdocs.dir}"
777               packagenames="jsr166x.*"
778               link="${jdkapidocs.url}"
779 <             source="5"
713 <             bootclasspath="${bootclasspath6}"
779 >             access="${build.javadoc.access}"
780               sourcepath="${topsrc.dir}:${jdk6src.dir}"
781 <             executable="${javadoc7}"
782 <             additionalparam="-XDignore.symbol.file=true" />
781 >             bootclasspath="${bootclasspath6}"
782 >             source="5"
783 >             executable="${javadoc7}">
784 >      <arg value="-XDignore.symbol.file=true"/>
785  
786 +    </javadoc>
787    </target>
788  
789  
790    <target name="jsr166xdist"
791 <          depends="jsr166xdist-clean, jsr166xdist-jar, jsr166xdocs"
791 >          depends="jsr166xdist-jar, jsr166xdist-docs"
792            description="Puts all distributable products in single hierarchy"/>
793  
794  
726
795    <target name="jsr166xclean"
796            description="Removes all jsr166x build products">
797  
# Line 732 | Line 800
800    </target>
801  
802  
735
803    <target name="jsr166xdist-clean"
804            description="Removes all build and distribution products">
805  
# Line 741 | Line 808
808  
809    <target name="jsr166xdist-jar"
810            depends="jsr166xclean, jsr166xjar">
744
811      <copy file="${jsr166x.jar}" todir="${dist.dir}"/>
812 +  </target>
813  
814 +  <target name="jsr166xdist-docs"
815 +          depends="jsr166xclean, jsr166xdocs">
816 +    <mirror-dir src="${jsr166xdocs.dir}" dst="${dist.jsr166xdocs.dir}"/>
817    </target>
818  
819    <!-- jsr166y -->
# Line 753 | Line 823
823            depends="configure-compiler"
824            description="Compiles jsr166y sources">
825  
826 <    <mkdir dir="${build.jsr166y.dir}"/>
826 >    <mkdir dir="${build.jsr166y.classes.dir}"/>
827  
828      <javac srcdir="${topsrc.dir}"
829 <           destdir="${build.jsr166y.dir}"
829 >           destdir="${build.jsr166y.classes.dir}"
830             debug="${build.debug}"
831             debuglevel="${build.debuglevel}"
832             deprecation="${build.deprecation}"
# Line 769 | Line 839
839             fork="true">
840  
841        <include name="jsr166y/**/*.java"/>
772      <compilerarg line="${build.args}"/>
842        <compilerarg value="-XDignore.symbol.file=true"/>
843        <compilerarg value="-Xlint:all"/>
844 +      <compilerarg line="${build.args}"/>
845 +
846      </javac>
847    </target>
848  
# Line 781 | Line 852
852            description="Builds library jar from compiled sources">
853  
854      <jar destfile="${jsr166y.jar}" index="true">
855 <      <fileset dir="${build.jsr166y.dir}"/>
855 >      <fileset dir="${build.jsr166y.classes.dir}"/>
856      </jar>
857  
858    </target>
859  
860  
790
861    <target name="jsr166ydocs"
862            description="Builds javadocs to dist dir">
863  
864 <    <delete dir="${dist.jsr166yjavadocs.dir}"/>
865 <    <mkdir dir="${dist.jsr166yjavadocs.dir}"/>
864 >    <delete dir="${jsr166ydocs.dir}"/>
865 >    <mkdir dir="${jsr166ydocs.dir}"/>
866  
867 <    <javadoc destdir="${dist.jsr166yjavadocs.dir}"
867 >    <javadoc destdir="${jsr166ydocs.dir}"
868               packagenames="jsr166y.*"
869               link="${jdkapidocs.url}"
870 <             source="6"
801 <             bootclasspath="${bootclasspath6}"
870 >             access="${build.javadoc.access}"
871               sourcepath="${topsrc.dir}:${jdk6src.dir}"
872 <             executable="${javadoc7}"
873 <             additionalparam="-XDignore.symbol.file=true" />
872 >             bootclasspath="${bootclasspath6}"
873 >             source="6"
874 >             executable="${javadoc7}">
875 >      <arg value="-XDignore.symbol.file=true"/>
876  
877 +    </javadoc>
878    </target>
879  
880  
881    <target name="jsr166ydist"
882 <          depends="jsr166ydist-clean, jsr166ydist-jar, jsr166ydocs"
882 >          depends="jsr166ydist-jar, jsr166ydist-docs"
883            description="Puts all distributable products in single hierarchy"/>
884  
885  
814
886    <target name="jsr166yclean"
887            description="Removes all jsr166y build products">
888  
# Line 820 | Line 891
891    </target>
892  
893  
823
894    <target name="jsr166ydist-clean"
895            description="Removes all build and distribution products">
896  
# Line 828 | Line 898
898  
899    <target name="jsr166ydist-jar"
900            depends="jsr166yclean, jsr166yjar">
831
901      <copy file="${jsr166y.jar}" todir="${dist.dir}"/>
902 +  </target>
903  
904 +  <target name="jsr166ydist-docs"
905 +          depends="jsr166yclean, jsr166ydocs">
906 +    <mirror-dir src="${jsr166ydocs.dir}" dst="${dist.jsr166ydocs.dir}"/>
907    </target>
908  
909  
# Line 841 | Line 914
914            depends="configure-compiler, jsr166yjar"
915            description="Compiles extra166y sources">
916  
917 <    <mkdir dir="${build.extra166y.dir}"/>
917 >    <mkdir dir="${build.extra166y.classes.dir}"/>
918  
919      <javac srcdir="${topsrc.dir}"
920 <           destdir="${build.extra166y.dir}"
920 >           destdir="${build.extra166y.classes.dir}"
921             debug="${build.debug}"
922             debuglevel="${build.debuglevel}"
923             deprecation="${build.deprecation}"
924 +           bootclasspath="@{jsr166y.jar}:${bootclasspath6}"
925             classpath=""
926             source="6"
853           bootclasspath="${jsr166y.jar}:${bootclasspath6}"
927             includeAntRuntime="false"
928             includeJavaRuntime="false"
929             executable="${javac7}"
930             fork="true">
931  
932        <include name="extra166y/**/*.java"/>
860      <compilerarg line="${build.args}"/>
933        <compilerarg value="-XDignore.symbol.file=true"/>
934        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial"/>
935 +      <compilerarg line="${build.args}"/>
936  
937      </javac>
865
938    </target>
939  
940  
869
941    <target name="extra166yjar"
942            depends="extra166ycompile"
943            description="Builds library jar from compiled sources">
944  
945      <jar destfile="${extra166y.jar}" index="true">
946 <      <fileset dir="${build.extra166y.dir}"/>
946 >      <fileset dir="${build.extra166y.classes.dir}"/>
947      </jar>
948  
949    </target>
950  
951  
881
952    <target name="extra166ydocs"
953            description="Builds javadocs to build dir">
954  
955 <    <delete dir="${dist.extra166yjavadocs.dir}"/>
956 <    <mkdir dir="${dist.extra166yjavadocs.dir}"/>
955 >    <delete dir="${extra166ydocs.dir}"/>
956 >    <mkdir dir="${extra166ydocs.dir}"/>
957  
958 <    <javadoc destdir="${dist.extra166yjavadocs.dir}"
958 >    <javadoc destdir="${extra166ydocs.dir}"
959               packagenames="extra166y.*"
960               link="${jdkapidocs.url}"
961 <             source="6"
892 <             bootclasspath="${bootclasspath6}"
961 >             access="${build.javadoc.access}"
962               sourcepath="${topsrc.dir}:${jdk6src.dir}"
963 <             executable="${javadoc7}"
964 <             additionalparam="-XDignore.symbol.file=true" />
963 >             bootclasspath="${bootclasspath6}"
964 >             source="6"
965 >             executable="${javadoc7}">
966 >      <arg value="-XDignore.symbol.file=true"/>
967  
968 +    </javadoc>
969    </target>
970  
971  
972    <target name="extra166ydist"
973 <          depends="extra166ydist-clean, extra166ydist-jar, extra166ydocs"
973 >          depends="extra166ydist-jar, extra166ydist-docs"
974            description="Puts all distributable products in single hierarchy"/>
975  
976  
905
977    <target name="extra166yclean"
978            description="Removes all extra166y build products">
979  
# Line 911 | Line 982
982    </target>
983  
984  
914
985    <target name="extra166ydist-clean"
986            description="Removes all build and distribution products">
987  
# Line 919 | Line 989
989  
990    <target name="extra166ydist-jar"
991            depends="extra166yclean, extra166yjar">
922
992      <copy file="${extra166y.jar}" todir="${dist.dir}"/>
993 +  </target>
994  
995 +  <target name="extra166ydist-docs"
996 +          depends="extra166yclean, extra166ydocs">
997 +    <mirror-dir src="${extra166ydocs.dir}" dst="${dist.extra166ydocs.dir}"/>
998    </target>
999  
1000    <!-- jsr166e -->
# Line 930 | Line 1003
1003            depends="configure-compiler"
1004            description="Compiles jsr166e sources">
1005  
1006 <    <mkdir dir="${build.jsr166e.dir}"/>
1006 >    <mkdir dir="${build.jsr166e.classes.dir}"/>
1007  
1008      <javac srcdir="${topsrc.dir}"
1009 <           destdir="${build.jsr166e.dir}"
1009 >           destdir="${build.jsr166e.classes.dir}"
1010             debug="${build.debug}"
1011             debuglevel="${build.debuglevel}"
1012             deprecation="${build.deprecation}"
# Line 945 | Line 1018
1018             fork="true">
1019  
1020        <include name="jsr166e/**/*.java"/>
948      <compilerarg line="${build.args}"/>
1021        <compilerarg value="-XDignore.symbol.file=true"/>
1022        <compilerarg value="-Xlint:all"/>
1023 +      <compilerarg line="${build.args}"/>
1024  
1025      </javac>
953
1026    </target>
1027  
1028  
957
1029    <target name="jsr166ejar"
1030            depends="jsr166ecompile"
1031            description="Builds library jar from compiled sources">
1032  
1033      <jar destfile="${jsr166e.jar}" index="true">
1034 <      <fileset dir="${build.jsr166e.dir}"/>
1034 >      <fileset dir="${build.jsr166e.classes.dir}"/>
1035      </jar>
1036  
1037    </target>
1038  
1039  
969
1040    <target name="jsr166edocs"
1041            description="Builds javadocs to build dir">
1042  
1043 <    <delete dir="${dist.jsr166ejavadocs.dir}"/>
1044 <    <mkdir dir="${dist.jsr166ejavadocs.dir}"/>
1043 >    <delete dir="${jsr166edocs.dir}"/>
1044 >    <mkdir dir="${jsr166edocs.dir}"/>
1045  
1046 <    <javadoc destdir="${dist.jsr166ejavadocs.dir}"
1046 >    <javadoc destdir="${jsr166edocs.dir}"
1047               packagenames="jsr166e.*"
1048               link="${jdkapidocs.url}"
1049 <             source="7"
1049 >             access="${build.javadoc.access}"
1050               sourcepath="${topsrc.dir}:${jdk7src.dir}"
1051 <             executable="${javadoc7}"
1052 <             additionalparam="-XDignore.symbol.file=true" >
1051 >             source="7"
1052 >             executable="${javadoc7}">
1053 >      <arg value="-XDignore.symbol.file=true"/>
1054 >
1055      </javadoc>
1056 +  </target>
1057 +
1058  
1059 +  <target name="jsr166e-test-tck"
1060 +          depends="jsr166ejar"
1061 +          description="Runs tck tests for jsr166e">
1062 +
1063 +    <run-tck-tests
1064 +      tck.src.dir="${test.src.dir}/tck-jsr166e"
1065 +      source="7"
1066 +      target="8"
1067 +      workdir="${build.jsr166e.dir}"
1068 +      classes="${jsr166e.jar}"/>
1069    </target>
1070  
1071  
1072    <target name="jsr166edist"
1073 <          depends="jsr166edist-clean, jsr166edist-jar, jsr166edocs"
1073 >          depends="jsr166edist-jar, jsr166edist-docs"
1074            description="Puts all distributable products in single hierarchy"/>
1075  
1076  
993
1077    <target name="jsr166eclean"
1078            description="Removes all jsr166e build products">
996
1079      <delete dir="${build.jsr166e.dir}"/>
998
1080    </target>
1081  
1082  
# Line 1006 | Line 1087
1087  
1088    <target name="jsr166edist-jar"
1089            depends="jsr166eclean, jsr166ejar">
1009
1090      <copy file="${jsr166e.jar}" todir="${dist.dir}"/>
1091 +  </target>
1092 +
1093 +  <target name="jsr166edist-docs"
1094 +          depends="jsr166eclean, jsr166edocs">
1095 +    <mirror-dir src="${jsr166edocs.dir}" dst="${dist.jsr166edocs.dir}"/>
1096 +  </target>
1097  
1098 +
1099 + <!-- Find buglets that can be detected by static build tools -->
1100 +
1101 +  <target name="lint">
1102 +    <antcall target="dists">
1103 +      <param name="build.javadoc.access" value="private"/>
1104 +    </antcall>
1105    </target>
1106  
1107 +
1108   </project>

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines