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.115 by jsr166, Sun Jan 20 06:11:07 2013 UTC vs.
Revision 1.138 by jsr166, Fri Mar 22 18:04:56 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 39 | Line 42
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 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 <  <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"/>
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 binary locations -->
69 >  <!-- JDK locations -->
70    <property name="jdks.home"  location="${user.home}/jdk"/>
71  
72    <macrodef name="defjdklocations">
# Line 72 | 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"/>
75    <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"/>
85 <
86 <  <macrodef name="run-tck-tests">
87 <    <attribute name="jvm"/>
88 <    <attribute name="tck.classes"/>
89 <    <attribute name="product.jar" default="${product.jar}"/>
90 <    <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>
97 <          <pathelement location="${junit.jar}"/>
98 <          <pathelement location="@{tck.classes}"/>
99 <        </classpath>
100 <    </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 116 | 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 133 | Line 145
145    <property name="extra166y.jar"    location="${build.extra166y.dir}/extra166y.jar"/>
146    <property name="junit.jar"        location="${lib.dir}/junit.jar"/>
147  
136  <!-- Bootclasspath argument -->
137  <property name="bootclasspath.args"   value="-Xbootclasspath/p:${product.jar}"/>
138
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) -->
# Line 159 | Line 168
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="target"/>
174 +    <attribute name="compile-target" default="@{target}"/>
175 +    <attribute name="workdir"/>
176 +    <attribute name="classes"/>
177 +    <attribute name="jvmflags" default=""/>
178 +    <element name="javac-elements" optional="true"/>
179 +    <sequential>
180 +
181 +    <mkdir dir="@{workdir}/tck-classes"/>
182 +
183 +    <javac srcdir="@{tck.src.dir}"
184 +           destdir="@{workdir}/tck-classes"
185 +           debug="${build.debug}"
186 +           debuglevel="${build.debuglevel}"
187 +           deprecation="${build.deprecation}"
188 +           source="@{compile-target}"
189 +           target="@{compile-target}"
190 +           classpath="${junit.jar}"
191 +           bootclasspath="@{classes}:${bootclasspath@{compile-target}}"
192 +           includeAntRuntime="false"
193 +           includeJavaRuntime="false"
194 +           executable="${javac@{compile-target}}"
195 +           fork="true">
196 +
197 +      <include name="*.java"/>
198 +      <compilerarg value="-XDignore.symbol.file=true"/>
199 +      <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
200 +      <compilerarg line="${build.args}"/>
201 +      <javac-elements/>
202 +
203 +    </javac>
204 +
205 +    <java classname="JSR166TestCase"
206 +          failonerror="true"
207 +          jvm="${java@{target}}"
208 +          fork="true">
209 +        <jvmarg value="-Xbootclasspath/p:@{classes}"/>
210 +        <jvmarg line="@{jvmflags}"/>
211 +        <classpath>
212 +          <pathelement location="${junit.jar}"/>
213 +          <pathelement location="@{workdir}/tck-classes"/>
214 +        </classpath>
215 +    </java>
216 +
217 +    </sequential>
218 +  </macrodef>
219 +
220 +  <macrodef name="run-jtreg-tests">
221 +    <attribute name="jtreg.src.dir" default="${jtreg.src.dir}"/>
222 +    <attribute name="source" default="7"/>
223 +    <attribute name="target"/>
224 +    <attribute name="workdir"/>
225 +    <attribute name="classes"/>
226 +    <attribute name="jtregflags" default=""/>
227 +    <sequential>
228 +    <delete dir="@{workdir}/JTwork"   quiet="true"/>
229 +    <delete dir="@{workdir}/JTreport" quiet="true"/>
230 +    <mkdir dir="@{workdir}/JTwork/scratch"/>
231 +    <mkdir dir="@{workdir}/JTreport"/>
232 +    <jtreg dir="@{jtreg.src.dir}"
233 +           jdk="${jdk@{target}.home}"
234 +           workDir="@{workdir}/JTwork"
235 +           reportDir="@{workdir}/JTreport">
236 +
237 +      <arg value="-Xbootclasspath/p:@{classes}"/>
238 +      <arg value="-agentvm"/>
239 +      <arg value="-v:nopass,fail"/>
240 +      <arg value="-vmoptions:-esa -ea"/>
241 +      <arg value="-automatic"/>
242 +      <arg value="-k:!ignore"/>
243 +      <arg line="@{jtregflags}"/>
244 +    </jtreg>
245 +    </sequential>
246 +  </macrodef>
247 +
248    <!-- ALoops classpath -->
249    <path id="loops.classpath">
250      <pathelement location="${build.loops.dir}"/>
251    </path>
252  
253    <!-- Support @jls tag, used in jdk8+ javadoc -->
254 <  <!-- TODO: How do we get &trade to work? -->
169 <  <!-- TODO: Why isn't @jls a "standard" tag? -->
170 <  <!--   property name="javadoc.jls.cite" value="The Java&trade; Language Specification" -->
171 <  <property name="javadoc.jls.cite" value="The Java Language Specification"/>
254 >  <property name="javadoc.jls.cite" value="The Java&amp;trade; Language Specification"/>
255    <property name="javadoc.jls.option" value="jls:a:See &lt;cite&gt;${javadoc.jls.cite}&lt;/cite&gt;:"/>
256  
257    <!-- Main targets -->
# Line 195 | Line 278
278             fork="true">
279  
280        <include name="**/*.java"/>
281 <      <compilerarg line="${build.args}"/>
281 >      <compilerarg value="-Xprefer:source"/>
282        <compilerarg value="-XDignore.symbol.file=true"/>
283        <compilerarg value="-Xlint:all"/>
201
202 <!--
203      <exclude name="java/lang/**"/>
284        <compilerarg line="${build.args}"/>
205      <compilerarg line="-Xlint -Xmaxwarns 1000"/>
206 -->
285  
286      </javac>
209
287    </target>
288  
289  
213
290    <target name="jar"
291            depends="compile"
292            description="Builds library jar from compiled sources">
# Line 218 | Line 294
294      <jar destfile="${product.jar}">
295        <fileset dir="${build.classes.dir}"/>
296      </jar>
221
297    </target>
298  
299  
225
300    <target name="test"
301            depends="configure-tests, report-tests"
302            description="Runs all tests (requires JUnit 3.8.1 in ${ant.home}/lib)" />
303  
304  
231
305    <target name="docs"
306            description="Builds javadocs for src/main to dist dir">
307  
308 <    <delete dir="${dist.javadocs.dir}"/>
309 <    <mkdir dir="${dist.javadocs.dir}"/>
308 >    <delete dir="${docs.dir}"/>
309 >    <mkdir dir="${docs.dir}"/>
310  
311      <!-- the packagenames="none" hack below prevents scanning the -->
312      <!-- sourcepath for packages -->
313  
314 <    <javadoc destdir="${dist.javadocs.dir}"
314 >    <javadoc destdir="${docs.dir}"
315               packagenames="none"
316               link="${jdkapi8docs.url}"
317               overview="${src.dir}/intro.html"
318 +             access="${build.javadoc.access}"
319               sourcepath="${src.dir}:${jdk8src.dir}"
320               classpath=""
321               executable="${javadoc8}">
248      <arg value="-XDignore.symbol.file=true"/>
249      <arg value="-tag"/>
250      <arg value="${javadoc.jls.option}"/>
322        <fileset dir="${src.dir}" defaultexcludes="yes">
323          <include name="**/*.java"/>
324        </fileset>
325 +      <arg value="-XDignore.symbol.file=true"/>
326 +      <arg value="-tag"/>
327 +      <arg value="${javadoc.jls.option}"/>
328      </javadoc>
255
329    </target>
330  
331  
259
332    <target name="dist"
333 <          depends="dist-clean, dist-jar, docs"
333 >          depends="dist-clean, dist-jar, dist-docs"
334            description="Puts all distributable products in single hierarchy"/>
335  
336  
# Line 277 | Line 349
349        <exclude name="**/SyntaxTest.java"/>
350        <exclude name="**/SuperfluousAbstract.java"/>
351      </jar>
280
352    </target>
353  
354  
284
355    <target name="clean"
356            description="Removes all build products">
357  
# Line 290 | Line 360
360    </target>
361  
362  
293
363    <target name="dist-clean"
364            description="Removes all build and distribution products">
365  
# Line 299 | Line 368
368    </target>
369  
370  
302
371    <!-- Internal targets -->
372  
373  
374    <target name="dist-jar"
375            depends="clean, jar">
308
376      <copy file="${product.jar}" todir="${dist.dir}"/>
377 +  </target>
378  
379 +  <target name="dist-docs"
380 +          depends="clean, docs">
381 +    <mirror-dir src="${docs.dir}" dst="${dist.docs.dir}"/>
382    </target>
383  
384  
# Line 323 | Line 394
394             deprecation="${build.deprecation}"
395             source="6"
396             classpath="${junit.jar}"
397 <           bootclasspath="${product.jar}:${bootclasspath6}"
397 >           bootclasspath="@{product.jar}:${bootclasspath6}"
398             includeAntRuntime="false"
399             includeJavaRuntime="false"
400             executable="${javac8}"
401             fork="true">
402  
403        <include name="**/*.java"/>
333      <compilerarg line="${build.args}"/>
404        <compilerarg value="-XDignore.symbol.file=true"/>
405        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
406 +      <compilerarg line="${build.args}"/>
407  
408      </javac>
409  
# Line 343 | Line 414
414             deprecation="${build.deprecation}"
415             source="6"
416             classpath=""
417 <           bootclasspath="${product.jar}:${bootclasspath6}"
417 >           bootclasspath="@{product.jar}:${bootclasspath6}"
418             includeAntRuntime="false"
419             includeJavaRuntime="false"
420             executable="${javac8}"
421             fork="true">
422  
423        <include name="jsr166/test/**/*.java"/>
353
354      <compilerarg line="${build.args}"/>
424        <compilerarg value="-XDignore.symbol.file=true"/>
425        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
426 +      <compilerarg line="${build.args}"/>
427  
428      </javac>
429  
# Line 366 | Line 436
436             source="${build.sourcelevel}"
437               fork="true">
438  
439 <      <compilerarg value="${bootclasspath.args}"/>
370 <      <compilerarg line="${build.args}"/>
439 >      <compilerarg value="-Xbootclasspath/p:${product.jar}"/>
440        <compilerarg value="-XDignore.symbol.file=true"/>
441 +      <compilerarg line="${build.args}"/>
442  
443      </javac>
444   -->
445  
446    </target>
447  
448 +  <target name="test-tck"
449 +          depends="jar"
450 +          description="Runs tck tests for main directly">
451 +
452 +    <run-tck-tests
453 +      target="8"
454 +      workdir="${build.dir}"
455 +      classes="${product.jar}"/>
456 +  </target>
457 +
458 +  <target name="test-jtreg"
459 +          depends="jar"
460 +          description="Runs jtreg tests for main using the jtreg ant task">
461 +    <run-jtreg-tests
462 +       target="8"
463 +       workdir="${build.dir}"
464 +       classes="${product.jar}"/>
465 +  </target>
466 +
467 +  <target name="test-ng"
468 +          depends="test-tck, test-jtreg"
469 +          description="Runs tck and jtreg tests for main">
470 +  </target>
471  
472    <target name="run-tests"
473            depends="compile-tests">
# Line 521 | Line 614
614  
615    <!-- jsr166 4jdk7 -->
616  
524
617    <target name="4jdk7compile"
618            depends="configure-compiler"
619            description="Compiles src/jdk7 sources, targeting jdk7">
# Line 542 | Line 634
634             fork="true">
635  
636        <include name="**/*.java"/>
637 <      <compilerarg line="${build.args}"/>
637 >      <compilerarg value="-Xprefer:source"/>
638        <compilerarg value="-XDignore.symbol.file=true"/>
639        <compilerarg value="-Xlint:all"/>
640 +      <compilerarg line="${build.args}"/>
641  
642      </javac>
643 +  </target>
644  
551    <jar destfile="${4jdk7product.jar}" index="true">
552      <fileset dir="${build.4jdk7.classes.dir}"/>
553    </jar>
554
555    <mkdir dir="${build.4jdk7.tck.classes.dir}"/>
645  
646 <    <javac srcdir="${tck.src.dir}"
647 <           destdir="${build.4jdk7.tck.classes.dir}"
648 <           debug="${build.debug}"
560 <           debuglevel="${build.debuglevel}"
561 <           deprecation="${build.deprecation}"
562 <           source="6"
563 <           classpath="${junit.jar}"
564 <           bootclasspath="${4jdk7product.jar}:${bootclasspath6}"
565 <           includeAntRuntime="false"
566 <           includeJavaRuntime="false"
567 <           executable="${javac7}"
568 <           fork="true">
569 <
570 <      <include name="**/*.java"/>
571 <      <compilerarg line="${build.args}"/>
572 <      <compilerarg value="-XDignore.symbol.file=true"/>
573 <      <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
646 >  <target name="4jdk7jar"
647 >          depends="4jdk7compile"
648 >          description="Builds library jar from compiled sources">
649  
650 <    </javac>
650 >    <jar destfile="${4jdk7product.jar}">
651 >      <fileset dir="${build.4jdk7.classes.dir}"/>
652 >    </jar>
653  
654    </target>
655  
656  
657    <target name="4jdk7-test-tck"
658 <          depends="4jdk7compile"
658 >          depends="4jdk7jar"
659            description="Runs tck tests for jsr166-4jdk7 directly">
660 +
661      <run-tck-tests
662 <      jvm="${java7}"
663 <      tck.classes="${build.4jdk7.tck.classes.dir}"
664 <      product.jar="${4jdk7product.jar}"/>
662 >      target="7"
663 >      workdir="${build.4jdk7.dir}"
664 >      classes="${4jdk7product.jar}">
665 >      <javac-elements>
666 >        <!-- JDK8+ test classes -->
667 >        <exclude name="*8Test.java"/>
668 >        <exclude name="DoubleAccumulatorTest.java"/>
669 >        <exclude name="DoubleAdderTest.java"/>
670 >        <exclude name="LongAccumulatorTest.java"/>
671 >        <exclude name="LongAdderTest.java"/>
672 >        <exclude name="CompletableFutureTest.java"/>
673 >        <exclude name="StampedLockTest.java"/>
674 >      </javac-elements>
675 >    </run-tck-tests>
676    </target>
677  
678  
# Line 616 | Line 705
705    </target>
706  
707    <target name="4jdk7-test-jtreg"
708 <          depends="4jdk7compile"
708 >          depends="4jdk7jar"
709            description="Runs jtreg tests for jsr166-4jdk7 using the jtreg ant task">
710 <    <delete dir="${build.4jdk7.dir}/JTwork"   quiet="true"/>
711 <    <delete dir="${build.4jdk7.dir}/JTreport" quiet="true"/>
712 <    <mkdir dir="${build.4jdk7.dir}/JTwork/scratch"/>
713 <    <mkdir dir="${build.4jdk7.dir}/JTreport"/>
625 <    <jtreg dir="${jtreg.src.dir}"
626 <           jdk="${jdk7.home}"
627 <           workDir="${build.4jdk7.dir}/JTwork"
628 <           reportDir="${build.4jdk7.dir}/JTreport">
629 <
630 <      <arg value="-Xbootclasspath/p:${4jdk7product.jar}"/>
631 <      <arg value="-agentvm"/>
632 <      <arg value="-v:nopass,fail"/>
633 <      <arg value="-vmoptions:-esa -ea"/>
634 <      <arg value="-automatic"/>
635 <      <arg value="-k:!ignore"/>
636 <    </jtreg>
710 >    <run-jtreg-tests
711 >       target="7"
712 >       workdir="${build.4jdk7.dir}"
713 >       classes="${4jdk7product.jar}"/>
714    </target>
715  
716  
# Line 646 | Line 723
723    <target name="4jdk7docs"
724            description="Builds javadocs for src/jdk7 to dist dir">
725  
726 <    <delete dir="${dist.4jdk7.docs.dir}"/>
727 <    <mkdir dir="${dist.4jdk7.docs.dir}"/>
726 >    <delete dir="${4jdk7docs.dir}"/>
727 >    <mkdir dir="${4jdk7docs.dir}"/>
728  
729 <    <javadoc destdir="${dist.4jdk7.docs.dir}"
729 >    <javadoc destdir="${4jdk7docs.dir}"
730               packagenames="none"
731               link="${jdkapi7docs.url}"
732               overview="${4jdk7src.dir}/intro.html"
733 +             access="${build.javadoc.access}"
734               sourcepath="${4jdk7src.dir}:${jdk7src.dir}"
735               classpath=""
736               executable="${javadoc7}">
659      <arg value="-XDignore.symbol.file=true"/>
737        <fileset dir="${4jdk7src.dir}" defaultexcludes="yes">
738          <include name="**/*.java"/>
739        </fileset>
740 +      <arg value="-XDignore.symbol.file=true"/>
741      </javadoc>
664
742    </target>
743  
744  
745    <target name="4jdk7dist"
746 <          depends="4jdk7dist-clean, 4jdk7dist-jar, 4jdk7docs"
746 >          depends="4jdk7dist-jar, 4jdk7dist-docs"
747            description="Puts all distributable products in single hierarchy"/>
748  
749  
673
750    <target name="4jdk7clean"
751            description="Removes all 4jdk7 build products">
752  
# Line 679 | Line 755
755    </target>
756  
757  
682
758    <target name="4jdk7dist-clean"
759            description="Removes all build and distribution products">
760  
761    </target>
762  
763    <target name="4jdk7dist-jar"
764 <          depends="4jdk7clean, 4jdk7compile">
690 <
764 >          depends="4jdk7clean, 4jdk7jar">
765      <copy file="${4jdk7product.jar}" todir="${dist.dir}"/>
766 +  </target>
767 +
768  
769 +  <target name="4jdk7dist-docs"
770 +          depends="4jdk7clean, 4jdk7docs">
771 +    <mirror-dir src="${4jdk7docs.dir}" dst="${dist.4jdk7docs.dir}"/>
772    </target>
773  
774  
# Line 707 | Line 786
786             debuglevel="${build.debuglevel}"
787             deprecation="${build.deprecation}"
788             classpath=""
710           source="5"
789             bootclasspath="${bootclasspath6}"
790 +           source="5"
791             includeAntRuntime="false"
792             includeJavaRuntime="false"
793             executable="${javac7}"
794             fork="true">
795  
796        <include name="jsr166x/**/*.java"/>
718      <compilerarg line="${build.args}"/>
797        <compilerarg value="-XDignore.symbol.file=true"/>
798        <compilerarg value="-Xlint:all,-unchecked,-rawtypes"/>
799 +      <compilerarg line="${build.args}"/>
800  
801      </javac>
723
802    </target>
803  
804  
727
805    <target name="jsr166xjar"
806            depends="jsr166xcompile"
807            description="Builds library jar from compiled sources">
# Line 736 | Line 813
813    </target>
814  
815  
739
816    <target name="jsr166xdocs"
817            description="Builds javadocs to dist dir">
818  
819 <    <delete dir="${dist.jsr166xjavadocs.dir}"/>
820 <    <mkdir dir="${dist.jsr166xjavadocs.dir}"/>
819 >    <delete dir="${jsr166xdocs.dir}"/>
820 >    <mkdir dir="${jsr166xdocs.dir}"/>
821  
822 <    <javadoc destdir="${dist.jsr166xjavadocs.dir}"
822 >    <javadoc destdir="${jsr166xdocs.dir}"
823               packagenames="jsr166x.*"
824               link="${jdkapidocs.url}"
825 <             source="5"
750 <             bootclasspath="${bootclasspath6}"
825 >             access="${build.javadoc.access}"
826               sourcepath="${topsrc.dir}:${jdk6src.dir}"
827 <             executable="${javadoc7}"
828 <             additionalparam="-XDignore.symbol.file=true"/>
827 >             bootclasspath="${bootclasspath6}"
828 >             source="5"
829 >             executable="${javadoc7}">
830 >      <arg value="-XDignore.symbol.file=true"/>
831  
832 +    </javadoc>
833    </target>
834  
835  
836    <target name="jsr166xdist"
837 <          depends="jsr166xdist-clean, jsr166xdist-jar, jsr166xdocs"
837 >          depends="jsr166xdist-jar, jsr166xdist-docs"
838            description="Puts all distributable products in single hierarchy"/>
839  
840  
763
841    <target name="jsr166xclean"
842            description="Removes all jsr166x build products">
843  
# Line 769 | Line 846
846    </target>
847  
848  
772
849    <target name="jsr166xdist-clean"
850            description="Removes all build and distribution products">
851  
# Line 778 | Line 854
854  
855    <target name="jsr166xdist-jar"
856            depends="jsr166xclean, jsr166xjar">
781
857      <copy file="${jsr166x.jar}" todir="${dist.dir}"/>
858 +  </target>
859  
860 +  <target name="jsr166xdist-docs"
861 +          depends="jsr166xclean, jsr166xdocs">
862 +    <mirror-dir src="${jsr166xdocs.dir}" dst="${dist.jsr166xdocs.dir}"/>
863    </target>
864  
865    <!-- jsr166y -->
# Line 806 | Line 885
885             fork="true">
886  
887        <include name="jsr166y/**/*.java"/>
809      <compilerarg line="${build.args}"/>
888        <compilerarg value="-XDignore.symbol.file=true"/>
889        <compilerarg value="-Xlint:all"/>
890 +      <compilerarg line="${build.args}"/>
891 +
892      </javac>
893    </target>
894  
# Line 824 | Line 904
904    </target>
905  
906  
827
907    <target name="jsr166ydocs"
908            description="Builds javadocs to dist dir">
909  
910 <    <delete dir="${dist.jsr166yjavadocs.dir}"/>
911 <    <mkdir dir="${dist.jsr166yjavadocs.dir}"/>
910 >    <delete dir="${jsr166ydocs.dir}"/>
911 >    <mkdir dir="${jsr166ydocs.dir}"/>
912  
913 <    <javadoc destdir="${dist.jsr166yjavadocs.dir}"
913 >    <javadoc destdir="${jsr166ydocs.dir}"
914               packagenames="jsr166y.*"
915               link="${jdkapidocs.url}"
916 <             source="6"
838 <             bootclasspath="${bootclasspath6}"
916 >             access="${build.javadoc.access}"
917               sourcepath="${topsrc.dir}:${jdk6src.dir}"
918 <             executable="${javadoc7}"
919 <             additionalparam="-XDignore.symbol.file=true"/>
918 >             bootclasspath="${bootclasspath6}"
919 >             source="6"
920 >             executable="${javadoc7}">
921 >      <arg value="-XDignore.symbol.file=true"/>
922  
923 +    </javadoc>
924    </target>
925  
926  
927    <target name="jsr166ydist"
928 <          depends="jsr166ydist-clean, jsr166ydist-jar, jsr166ydocs"
928 >          depends="jsr166ydist-jar, jsr166ydist-docs"
929            description="Puts all distributable products in single hierarchy"/>
930  
931  
851
932    <target name="jsr166yclean"
933            description="Removes all jsr166y build products">
934  
# Line 857 | Line 937
937    </target>
938  
939  
860
940    <target name="jsr166ydist-clean"
941            description="Removes all build and distribution products">
942  
# Line 865 | Line 944
944  
945    <target name="jsr166ydist-jar"
946            depends="jsr166yclean, jsr166yjar">
868
947      <copy file="${jsr166y.jar}" todir="${dist.dir}"/>
948 +  </target>
949  
950 +  <target name="jsr166ydist-docs"
951 +          depends="jsr166yclean, jsr166ydocs">
952 +    <mirror-dir src="${jsr166ydocs.dir}" dst="${dist.jsr166ydocs.dir}"/>
953    </target>
954  
955  
# Line 885 | Line 967
967             debug="${build.debug}"
968             debuglevel="${build.debuglevel}"
969             deprecation="${build.deprecation}"
970 +           bootclasspath="@{jsr166y.jar}:${bootclasspath6}"
971             classpath=""
972             source="6"
890           bootclasspath="${jsr166y.jar}:${bootclasspath6}"
973             includeAntRuntime="false"
974             includeJavaRuntime="false"
975             executable="${javac7}"
976             fork="true">
977  
978        <include name="extra166y/**/*.java"/>
897      <compilerarg line="${build.args}"/>
979        <compilerarg value="-XDignore.symbol.file=true"/>
980        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial"/>
981 +      <compilerarg line="${build.args}"/>
982  
983      </javac>
902
984    </target>
985  
986  
906
987    <target name="extra166yjar"
988            depends="extra166ycompile"
989            description="Builds library jar from compiled sources">
# Line 915 | Line 995
995    </target>
996  
997  
918
998    <target name="extra166ydocs"
999            description="Builds javadocs to build dir">
1000  
1001 <    <delete dir="${dist.extra166yjavadocs.dir}"/>
1002 <    <mkdir dir="${dist.extra166yjavadocs.dir}"/>
1001 >    <delete dir="${extra166ydocs.dir}"/>
1002 >    <mkdir dir="${extra166ydocs.dir}"/>
1003  
1004 <    <javadoc destdir="${dist.extra166yjavadocs.dir}"
1004 >    <javadoc destdir="${extra166ydocs.dir}"
1005               packagenames="extra166y.*"
1006               link="${jdkapidocs.url}"
1007 <             source="6"
929 <             bootclasspath="${bootclasspath6}"
1007 >             access="${build.javadoc.access}"
1008               sourcepath="${topsrc.dir}:${jdk6src.dir}"
1009 <             executable="${javadoc7}"
1010 <             additionalparam="-XDignore.symbol.file=true"/>
1009 >             bootclasspath="${bootclasspath6}"
1010 >             source="6"
1011 >             executable="${javadoc7}">
1012 >      <arg value="-XDignore.symbol.file=true"/>
1013  
1014 +    </javadoc>
1015    </target>
1016  
1017  
1018    <target name="extra166ydist"
1019 <          depends="extra166ydist-clean, extra166ydist-jar, extra166ydocs"
1019 >          depends="extra166ydist-jar, extra166ydist-docs"
1020            description="Puts all distributable products in single hierarchy"/>
1021  
1022  
942
1023    <target name="extra166yclean"
1024            description="Removes all extra166y build products">
1025  
# Line 948 | Line 1028
1028    </target>
1029  
1030  
951
1031    <target name="extra166ydist-clean"
1032            description="Removes all build and distribution products">
1033  
# Line 956 | Line 1035
1035  
1036    <target name="extra166ydist-jar"
1037            depends="extra166yclean, extra166yjar">
959
1038      <copy file="${extra166y.jar}" todir="${dist.dir}"/>
1039 +  </target>
1040  
1041 +  <target name="extra166ydist-docs"
1042 +          depends="extra166yclean, extra166ydocs">
1043 +    <mirror-dir src="${extra166ydocs.dir}" dst="${dist.extra166ydocs.dir}"/>
1044    </target>
1045  
1046    <!-- jsr166e -->
# Line 982 | Line 1064
1064             fork="true">
1065  
1066        <include name="jsr166e/**/*.java"/>
985      <compilerarg line="${build.args}"/>
1067        <compilerarg value="-XDignore.symbol.file=true"/>
1068        <compilerarg value="-Xlint:all"/>
1069 +      <compilerarg line="${build.args}"/>
1070  
1071      </javac>
990
1072    </target>
1073  
1074  
994
1075    <target name="jsr166ejar"
1076            depends="jsr166ecompile"
1077            description="Builds library jar from compiled sources">
# Line 1003 | Line 1083
1083    </target>
1084  
1085  
1006
1086    <target name="jsr166edocs"
1087            description="Builds javadocs to build dir">
1088  
1089 <    <delete dir="${dist.jsr166ejavadocs.dir}"/>
1090 <    <mkdir dir="${dist.jsr166ejavadocs.dir}"/>
1089 >    <delete dir="${jsr166edocs.dir}"/>
1090 >    <mkdir dir="${jsr166edocs.dir}"/>
1091  
1092 <    <javadoc destdir="${dist.jsr166ejavadocs.dir}"
1092 >    <javadoc destdir="${jsr166edocs.dir}"
1093               packagenames="jsr166e.*"
1094               link="${jdkapidocs.url}"
1095 <             source="7"
1095 >             access="${build.javadoc.access}"
1096               sourcepath="${topsrc.dir}:${jdk7src.dir}"
1097 <             executable="${javadoc7}"
1098 <             additionalparam="-XDignore.symbol.file=true" >
1097 >             source="7"
1098 >             executable="${javadoc7}">
1099 >      <arg value="-XDignore.symbol.file=true"/>
1100 >
1101      </javadoc>
1102 +  </target>
1103 +
1104  
1105 +  <target name="jsr166e-test-tck"
1106 +          depends="jsr166ejar"
1107 +          description="Runs tck tests for jsr166e">
1108 +
1109 +    <run-tck-tests
1110 +      tck.src.dir="${test.src.dir}/tck-jsr166e"
1111 +      target="7"
1112 +      workdir="${build.jsr166e.dir}"
1113 +      classes="${jsr166e.jar}"/>
1114    </target>
1115  
1116  
1117    <target name="jsr166edist"
1118 <          depends="jsr166edist-clean, jsr166edist-jar, jsr166edocs"
1118 >          depends="jsr166edist-jar, jsr166edist-docs"
1119            description="Puts all distributable products in single hierarchy"/>
1120  
1121  
1030
1122    <target name="jsr166eclean"
1123            description="Removes all jsr166e build products">
1033
1124      <delete dir="${build.jsr166e.dir}"/>
1035
1125    </target>
1126  
1127  
# Line 1043 | Line 1132
1132  
1133    <target name="jsr166edist-jar"
1134            depends="jsr166eclean, jsr166ejar">
1046
1135      <copy file="${jsr166e.jar}" todir="${dist.dir}"/>
1136 +  </target>
1137 +
1138 +  <target name="jsr166edist-docs"
1139 +          depends="jsr166eclean, jsr166edocs">
1140 +    <mirror-dir src="${jsr166edocs.dir}" dst="${dist.jsr166edocs.dir}"/>
1141 +  </target>
1142  
1143 +
1144 + <!-- Find buglets that can be detected by static build tools -->
1145 +
1146 +  <target name="lint">
1147 +    <antcall target="dists">
1148 +      <param name="build.javadoc.access" value="private"/>
1149 +    </antcall>
1150    </target>
1151  
1152 +
1153   </project>

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines