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.236 by jsr166, Mon Mar 20 00:03:57 2017 UTC vs.
Revision 1.263 by jsr166, Tue Jan 23 06:09:53 2018 UTC

# Line 18 | Line 18
18    itself.  Because the JDK version matters and because different
19    targets require different JDKs, we assume that users have created a
20    hierarchy containing:
21  $HOME/jdk/jdk7
21    $HOME/jdk/jdk8
22    $HOME/jdk/jdk9
23    $HOME/jdk/jdk10
24 +  $HOME/jdk/jdk11
25    where each of the above is a JDK or a symlink to same, and
26  $HOME/jdk/src/jdk7
26    $HOME/jdk/src/jdk8
27    $HOME/jdk/src/jdk9
28    $HOME/jdk/src/jdk10
29 +  $HOME/jdk/src/jdk11
30    where each of the above is a complete JDK source tree
31    (e.g. mercurial forest) or a symlink to same.
32  
33    Alternatively, define ant variables thus:
34    ant -Djdk$N.home=... -Djdk$N.src.home=...
35 <  for $N in 7 8 9 10 ...
35 >  for $N in 8 9 10 ...
36  
37    As of 2016-03, the sources in src/main are for jdk9+ only.
38   ------------------------------------------------------------------------------
# Line 134 | Line 134
134    <defjdklocations v="8"/>
135    <defjdklocations v="9"/>
136    <defjdklocations v="10"/>
137 +  <defjdklocations v="11"/>
138  
139    <!-- Source locations -->
140    <property name="src.dir"              location="${basedir}/src/main"/>
# Line 144 | Line 145
145    <property name="jtreg8.src.dir"       location="${test.src.dir}/jtreg-jdk8"/>
146    <property name="jtreg9.src.dir"       location="${test.src.dir}/jtreg"/>
147    <property name="jtreg10.src.dir"      location="${test.src.dir}/jtreg"/>
148 +  <property name="jtreg11.src.dir"      location="${test.src.dir}/jtreg"/>
149    <property name="jtreg.src.dir"        location="${jtreg9.src.dir}"/>
150    <property name="lib.dir"              location="${basedir}/lib"/>
151    <property name="dist.dir"             location="${basedir}/dist"/>
# Line 183 | Line 185
185    <property name="junit.jar"        location="${lib.dir}/junit.jar"/>
186  
187    <!-- Canonical location of jdk docs root, to use with javadoc -Xdocrootparent flag -->
188 <  <property name="java5.docroot.url"      value="http://docs.oracle.com/javase/1.5.0/docs"/>
189 <  <property name="java6.docroot.url"      value="http://docs.oracle.com/javase/6/docs"/>
190 <  <property name="java7.docroot.url"      value="http://docs.oracle.com/javase/7/docs"/>
191 <  <property name="java8.docroot.url"      value="http://docs.oracle.com/javase/8/docs"/>
192 <  <!-- The expected canonical location does not yet exist as of 2016-04 -->
193 <  <!-- <property name="java9.docroot.url" value="http://docs.oracle.com/javase/9/docs"/> -->
194 <  <property name="java9.docroot.url"      value="http://download.java.net/java/jdk9/docs"/>
188 >  <!-- Switched to https: in 2017-10 - JDK-8190312 -->
189 >  <property name="java5.docroot.url"  value="https://docs.oracle.com/javase/1.5.0/docs"/>
190 >  <property name="java6.docroot.url"  value="https://docs.oracle.com/javase/6/docs"/>
191 >  <property name="java7.docroot.url"  value="https://docs.oracle.com/javase/7/docs"/>
192 >  <property name="java8.docroot.url"  value="https://docs.oracle.com/javase/8/docs"/>
193 >  <property name="java9.docroot.url"  value="https://docs.oracle.com/javase/9/docs"/>
194 >  <!-- The location of jdk9 early access docs (RIP) -->
195 >  <!-- <property name="java9.docroot.url" value="http://download.java.net/java/jdk9/docs"/> -->
196    <!-- Default jdk doc location (latest stable release seems best) -->
197 <  <property name="java.docroot.url"       value="${java8.docroot.url}"/>
197 >  <property name="java10.docroot.url" value="http://download.java.net/java/jdk10/docs"/>
198 >  <property name="java11.docroot.url" value="http://download.java.net/java/jdk11/docs"/>
199 >  <property name="java.docroot.url"   value="${java9.docroot.url}"/>
200  
201    <!-- Canonical location of jdk API docs, to use with javadoc link attribute -->
202    <property name="java5.api.url"      value="${java5.docroot.url}/api/"/>
# Line 199 | Line 204
204    <property name="java7.api.url"      value="${java7.docroot.url}/api/"/>
205    <property name="java8.api.url"      value="${java8.docroot.url}/api/"/>
206    <property name="java9.api.url"      value="${java9.docroot.url}/api/"/>
207 +  <property name="java10.api.url"     value="${java10.docroot.url}/api/"/>
208 +  <property name="java11.api.url"     value="${java11.docroot.url}/api/"/>
209    <property name="java.api.url"       value="${java.docroot.url}/api/"/>
210  
211    <!-- Define the "jtreg" task -->
# Line 234 | Line 241
241        <available file="${jdk@{compile-target}.home}/jmods" type="dir"/>
242      </condition>
243  
244 +    <local name="use-doclint"/>
245 +    <condition property="use-doclint">
246 +      <not> <equals arg1="@{target}" arg2="7"/> </not>
247 +    </condition>
248 +
249      <mkdir dir="@{workdir}/tck-classes"/>
250  
251      <javac srcdir="@{tck.src.dir}"
# Line 253 | Line 265
265        <include name="*.java"/>
266        <compilerarg value="-XDignore.symbol.file=true"/>
267        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation,-try"/>
268 <      <compilerarg value="-Xdoclint:reference/private"/>
268 >      <compilerarg value="-Xdoclint:reference/private" if:set="use-doclint"/>
269        <compilerarg value="-Xbootclasspath/p:@{classes}" unless:set="modules"/>
270        <compilerarg value="--patch-module=java.base=@{classes}" if:set="modules"/>
271        <compilerarg line="${build.args}"/>
# Line 293 | Line 305
305    </macrodef>
306  
307    <!-- Define jtreg test sets for different jdk versions -->
308 +  <fileset dir="${jtreg11.src.dir}">
309 +    <patternset id="jdk11.jtreg.tests">
310 +      <include name="**/*.java"/>
311 +    </patternset>
312 +  </fileset>
313 +
314 +  <fileset dir="${jtreg10.src.dir}">
315 +    <patternset id="jdk10.jtreg.tests">
316 +      <include name="**/*.java"/>
317 +    </patternset>
318 +  </fileset>
319 +
320    <fileset dir="${jtreg9.src.dir}">
321      <patternset id="jdk9.jtreg.tests">
322        <include name="**/*.java"/>
# Line 316 | Line 340
340  
341    <macrodef name="run-jtreg-tests">
342      <!-- ant -Djtreg9.src.dir=src/test/jtreg/util/concurrent/CompletableFuture jtreg -->
319    <attribute name="source" default="7"/>
343      <attribute name="target"/>
344      <attribute name="workdir"/>
345      <attribute name="classes"/>
346 +    <attribute name="verbose" default="${jtreg.verbose}"/>
347      <attribute name="jtregflags" default=""/>
348 +    <element name="jtreg-elements" optional="true"/>
349  
350      <sequential>
351  
# Line 338 | Line 363
363             workDir="@{workdir}/JTwork">
364        <patternset refid="jdk@{target}.jtreg.tests"/>
365        <arg value="-Xbootclasspath/p:@{classes}" unless:set="modules"/>
366 <      <arg value="-javacoptions:--patch-module java.base=@{classes}" if:set="modules"/>
367 <      <arg value="-vmoptions:--patch-module java.base=@{classes}" if:set="modules"/>
366 >      <arg value="-javacoptions:--patch-module=java.base=@{classes}" if:set="modules"/>
367 >      <arg value="-vmoptions:--patch-module=java.base=@{classes}" if:set="modules"/>
368        <arg value="-agentvm"/>
369        <arg value="-noreport"/>
370 <      <arg value="-verbose:${jtreg.verbose}"/>
370 >      <arg value="-verbose:@{verbose}"/>
371        <arg value="-vmoptions:-esa -ea"/>
372        <arg value="-automatic"/>
373        <arg value="-k:!ignore"/>
374        <arg line="@{jtregflags}"/>
375        <arg line="${jtreg.flags}"/>
376 +      <jtreg-elements/>
377      </jtreg>
378      </sequential>
379    </macrodef>
# Line 364 | Line 390
390    <!-- Main targets -->
391  
392    <property name="build.main.java.version" value="9"/>
393 <  <property name="build.main.javac" value="${javac9}"/>
393 >  <!-- Workaround "no nested properties in ant" -->
394 >  <macrodef name="define-build-main-properties">
395 >    <attribute name="v"/>
396 >    <sequential>
397 >      <property name="build.main.java"    value="${java@{v}}"/>
398 >      <property name="build.main.javac"   value="${javac@{v}}"/>
399 >      <property name="build.main.javadoc" value="${javadoc@{v}}"/>
400 >    </sequential>
401 >  </macrodef>
402 >  <define-build-main-properties v="${build.main.java.version}"/>
403  
404    <target name="dists"
405 <          depends="dist, 4jdk8dist, 4jdk7dist, jsr166edist, jsr166ydist, extra166ydist, jsr166xdist"
405 >          depends="dist, 4jdk8dist"
406            description="Builds all public jars and docs"/>
407 +          <!--
408 +              depends="dist, 4jdk8dist, 4jdk7dist, jsr166edist, jsr166ydist, extra166ydist, jsr166xdist"
409 +          -->
410  
411    <target name="compile"
412            depends="configure-compiler"
413            description="Compiles src/main sources to build dir">
414  
377    <local name="modules"/>
378    <condition property="modules">
379      <and>
380        <available file="${jdk9.home}/jmods" type="dir"/>
381        <equals arg1="9" arg2="${build.main.java.version}"/>
382      </and>
383    </condition>
384
415      <local name="destdir"/>
416 <    <property name="destdir" value="${build.classes.dir}/java.base" if:set="modules"/>
387 <    <property name="destdir" value="${build.classes.dir}" unless:set="modules"/>
416 >    <property name="destdir" value="${build.classes.dir}/java.base"/>
417  
418      <mkdir dir="${destdir}"/>
419  
# Line 401 | Line 430
430             fork="true">
431  
432        <include name="**/*.java"/>
433 <      <compilerarg value="--patch-module=java.base=${src.dir}" if:set="modules"/>
433 >      <compilerarg value="--patch-module=java.base=${src.dir}"/>
434        <compilerarg value="-Xprefer:source"/>
435        <compilerarg value="-XDignore.symbol.file=true"/>
436        <compilerarg value="-Xlint:all"/>
437 <      <compilerarg value="-Werror"/>
437 >      <compilerarg line="--doclint-format html5"/>
438        <compilerarg value="-Xdoclint:all/protected,reference/private"/>
439 +      <compilerarg value="-Werror"/>
440        <compilerarg line="-Xmaxerrs 1000 -Xmaxwarns 1000"/>
441        <compilerarg line="${build.args}"/>
442  
# Line 450 | Line 480
480               access="${build.javadoc.access}"
481               sourcepath="${src.dir}"
482               classpath=""
483 <             executable="${javadoc9}">
483 >             source="9"
484 >             executable="${build.main.javadoc}">
485        <fileset dir="${src.dir}" defaultexcludes="yes">
486          <include name="**/*.java"/>
487        </fileset>
488        <arg line="-Xdocrootparent ${java9.docroot.url}"/>
489        <arg line="-Xmaxerrs 1000 -Xmaxwarns 1000"/>
490        <arg value="-XDignore.symbol.file=true"/>
491 +      <arg value="-html5"/>
492        <arg value="--patch-module=java.base=${src.dir}"/>
493        <arg value="-tag"/>
494        <arg value="${javadoc.jls.option}"/>
# Line 505 | Line 537
537  
538    <target name="clean"
539            description="Removes all build products">
508
540      <delete dir="${build.dir}"/>
510
541    </target>
542  
543  
544    <target name="dist-clean"
545            description="Removes all build and distribution products">
516
546      <delete dir="${build.dir}"/>
547      <delete dir="${dist.dir}"/>
519
548    </target>
549  
550  
# Line 576 | Line 604
604  
605    <target name="test"
606            depends="tck, tck-parallelism-1, tck-parallelism-0, jtreg"
607 <          description="Runs tck and jtreg tests for src/main">
580 <  </target>
607 >          description="Runs tck and jtreg tests for src/main"/>
608  
609   <!--   <target name="jtreg8" description="Runs jtreg tests with jdk8"> -->
610  
# Line 588 | Line 615
615  
616   <!--   </target> -->
617  
618 < <!--   <target name="test89" -->
619 < <!--           description="Runs tck and jtreg tests for src/main for multiple java versions"> -->
618 >  <target name="test91011"
619 >          description="Runs tck and jtreg tests for src/main for multiple java versions">
620  
621 < <!--     <antcall target="clean"/> -->
622 < <!--     <antcall target="test"> -->
623 < <!--       <param name="build.main.java.version" value="8"/> -->
624 < <!--       <param name="build.main.javac" value="${javac8}"/> -->
598 < <!--     </antcall> -->
621 >    <antcall target="clean"/>
622 >    <antcall target="test">
623 >      <param name="build.main.java.version" value="9"/>
624 >    </antcall>
625  
626 < <!--     <antcall target="clean"/> -->
627 < <!--     <antcall target="test"> -->
628 < <!--       <param name="build.main.java.version" value="9"/> -->
629 < <!--       <param name="build.main.javac" value="${javac9}"/> -->
604 < <!--     </antcall> -->
626 >    <antcall target="clean"/>
627 >    <antcall target="test">
628 >      <param name="build.main.java.version" value="10"/>
629 >    </antcall>
630  
631 < <!--   </target> -->
631 >    <antcall target="clean"/>
632 >    <antcall target="test">
633 >      <param name="build.main.java.version" value="11"/>
634 >    </antcall>
635 >
636 >    <!-- Clean up to avoid obscure wrong class file version bugs -->
637 >    <antcall target="clean"/>
638 >
639 >  </target>
640  
641  
642  
643    <target name="configure-compiler">
644      <fail message="ant version too old">
645 <      <condition>
613 <        <not> <antversion atleast="1.9.1"/> </not>
614 <      </condition>
645 >      <condition> <not> <antversion atleast="1.9.1"/> </not> </condition>
646      </fail>
647  
648      <property name="unchecked.option" value="-Xlint:unchecked"/>
# Line 657 | Line 688
688      <java classname="ALoops" fork="true">
689        <classpath refid="loops.classpath"/>
690      </java>
660
691    </target>
692  
693  
694    <target name="compile-test-loops" depends="jar"
695 <          description="compile all the perf tests in src/test/loops">
695 >          description="Compiles all the perf tests in src/test/loops">
696  
697      <mkdir dir="${build.dir}/test/loops"/>
698  
# Line 674 | Line 704
704             includeAntRuntime="false"
705             includeJavaRuntime="false"
706             encoding="ASCII"
707 <           executable="${javac9}"
707 >           executable="${build.main.javac}"
708             fork="true">
709  
710        <include name="*.java"/>
# Line 682 | Line 712
712        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial"/>
713        <compilerarg value="-Xbootclasspath/p:${product.jar}"/>
714        <compilerarg line="${build.args}"/>
685
715      </javac>
687
716    </target>
717  
718  
# Line 710 | Line 738
738             encoding="ASCII"
739             executable="${javac8}"
740             fork="true">
713
741        <include name="**/*.java"/>
742        <compilerarg value="-Xprefer:source"/>
743        <compilerarg value="-XDignore.symbol.file=true"/>
744        <compilerarg value="-Xlint:all"/>
745        <compilerarg value="-Werror"/>
746        <compilerarg line="${build.args}"/>
720
747      </javac>
748    </target>
749  
# Line 741 | Line 767
767             encoding="ASCII"
768             executable="${javac8}"
769             fork="true">
744
770        <include name="**/*.java"/>
771        <compilerarg value="-Xprefer:source"/>
772        <compilerarg value="-XDignore.symbol.file=true"/>
773        <compilerarg value="-Xlint:all"/>
774        <compilerarg value="-Xdoclint:all/protected,reference/private"/>
775        <compilerarg line="${build.args}"/>
751
776      </javac>
777    </target>
778  
# Line 764 | Line 788
788          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
789        </manifest>
790      </jar>
767
791    </target>
792  
793  
# Line 798 | Line 821
821  
822    <target name="4jdk8-test"
823            depends="4jdk8-tck, 4jdk8-jtreg"
824 <          description="Runs tck and jtreg tests for jsr166-4jdk8">
802 <  </target>
824 >          description="Runs tck and jtreg tests for jsr166-4jdk8"/>
825  
826  
827    <target name="4jdk8docs"
# Line 815 | Line 837
837               access="${build.javadoc.access}"
838               sourcepath="${4jdk8src.dir}:${jdk8.src.dir}"
839               classpath=""
840 +             source="8"
841               executable="${javadoc8}"
842               failonerror = "true">
843        <fileset dir="${4jdk8src.dir}" defaultexcludes="yes">
# Line 842 | Line 865
865  
866    <target name="4jdk8clean"
867            description="Removes all 4jdk8 build products">
845
868      <delete dir="${build.4jdk8.dir}"/>
847
869    </target>
870  
871  
# Line 860 | Line 881
881    </target>
882  
883  
884 +  <!-- jsr166 4jdk7 (no longer maintained) -->
885  
886 <  <!-- jsr166 4jdk7 -->
865 <
866 <  <target name="4jdk7compile"
867 <          depends="configure-compiler"
868 <          description="Compiles src/jdk7 sources, targeting jdk7">
869 <
886 >  <target name="4jdk7compile" depends="configure-compiler">
887      <mkdir dir="${build.4jdk7.classes.dir}"/>
888  
889      <javac srcdir="${4jdk7src.dir}"
# Line 890 | Line 907
907        <compilerarg value="-Xlint:all"/>
908        <compilerarg value="-Werror"/>
909        <compilerarg line="${build.args}"/>
893
910      </javac>
911    </target>
912  
913 <  <target name="4jdk7doclint"
898 <          depends="configure-compiler"
899 <          description="Finds doclint warnings">
900 <
913 >  <target name="4jdk7doclint" depends="configure-compiler">
914      <mkdir dir="${build.4jdk7.classes.dir}"/>
915  
916      <javac srcdir="${4jdk7src.dir}"
# Line 921 | Line 934
934        <compilerarg value="-Xlint:all"/>
935        <compilerarg value="-Xdoclint:all/protected"/>
936        <compilerarg line="${build.args}"/>
924
937      </javac>
938    </target>
939  
940 <
929 <  <target name="4jdk7jar"
930 <          depends="4jdk7compile"
931 <          description="Builds library jar from compiled sources">
932 <
940 >  <target name="4jdk7jar" depends="4jdk7compile">
941      <jar destfile="${4jdk7product.jar}">
942        <fileset dir="${build.4jdk7.classes.dir}"/>
943        <manifest>
# Line 937 | Line 945
945          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
946        </manifest>
947      </jar>
940
948    </target>
949  
950 <
944 <  <target name="4jdk7-tck"
945 <          depends="4jdk7jar"
946 <          description="Runs tck tests for jsr166-4jdk7 directly">
947 <
950 >  <target name="4jdk7-tck" depends="4jdk7jar">
951      <run-tck-tests
952        target="7"
953        workdir="${build.4jdk7.dir}"
# Line 967 | Line 970
970      </run-tck-tests>
971    </target>
972  
970
973    <!-- Runs tck tests for jsr166-4jdk7 via junit task (dead experiment) -->
974 <  <target name="4jdk7-tck-junit"
973 <          depends="4jdk7compile">
974 >  <target name="4jdk7-tck-junit" depends="4jdk7compile">
975  
976      <junit printsummary="true"
977             showoutput="true"
# Line 992 | Line 993
993  
994        <test name="${jsr166.tckTestClass}" haltonfailure="no">
995        </test>
995
996      </junit>
997    </target>
998  
999 <  <target name="4jdk7-jtreg"
1000 <          depends="4jdk7jar"
1001 <          description="Runs jtreg tests for jsr166-4jdk7 using the jtreg ant task">
999 >  <target name="4jdk7-jtreg" depends="4jdk7jar">
1000      <run-jtreg-tests
1001         target="7"
1002         workdir="${build.4jdk7.dir}"
1003         classes="${4jdk7product.jar}"/>
1004    </target>
1005  
1006 +  <target name="4jdk7-test" depends="4jdk7-tck, 4jdk7-jtreg"/>
1007  
1008 <  <target name="4jdk7-test"
1010 <          depends="4jdk7-tck, 4jdk7-jtreg"
1011 <          description="Runs tck and jtreg tests for jsr166-4jdk7">
1012 <  </target>
1013 <
1014 <
1015 <  <target name="4jdk7docs"
1016 <          description="Builds javadocs for src/jdk7 to dist dir">
1017 <
1008 >  <target name="4jdk7docs">
1009      <delete dir="${4jdk7docs.dir}"/>
1010      <mkdir dir="${4jdk7docs.dir}"/>
1011  
# Line 1035 | Line 1026
1026      </javadoc>
1027    </target>
1028  
1029 +  <target name="4jdk7dist" depends="4jdk7dist-jar, 4jdk7dist-docs"/>
1030  
1031 <  <target name="4jdk7dist"
1040 <          depends="4jdk7dist-jar, 4jdk7dist-docs"
1041 <          description="Puts all distributable products in single hierarchy"/>
1042 <
1043 <
1044 <  <target name="4jdk7clean"
1045 <          description="Removes all 4jdk7 build products">
1046 <
1031 >  <target name="4jdk7clean">
1032      <delete dir="${build.4jdk7.dir}"/>
1048
1033    </target>
1034  
1035 <
1052 <  <target name="4jdk7dist-jar"
1053 <          depends="4jdk7clean, 4jdk7jar">
1035 >  <target name="4jdk7dist-jar" depends="4jdk7clean, 4jdk7jar">
1036      <copy file="${4jdk7product.jar}" todir="${dist.dir}"/>
1037    </target>
1038  
1039 <
1058 <  <target name="4jdk7dist-docs"
1059 <          depends="4jdk7clean, 4jdk7docs">
1039 >  <target name="4jdk7dist-docs" depends="4jdk7clean, 4jdk7docs">
1040      <mirror-dir src="${4jdk7docs.dir}" dst="${dist.4jdk7docs.dir}"/>
1041    </target>
1042  
1043  
1044 <  <!-- jsr166x -->
1065 <
1066 <  <target name="jsr166xcompile"
1067 <          depends="configure-compiler"
1068 <          description="Compiles jsr166x sources to build dir">
1044 >  <!-- jsr166x (no longer maintained) -->
1045  
1046 +  <target name="jsr166xcompile" depends="configure-compiler">
1047      <mkdir dir="${build.jsr166x.classes.dir}"/>
1048  
1049      <javac srcdir="${topsrc.dir}"
# Line 1083 | Line 1060
1060             encoding="ASCII"
1061             executable="${javac7}"
1062             fork="true">
1086
1063        <include name="jsr166x/**/*.java"/>
1064        <compilerarg value="-XDignore.symbol.file=true"/>
1065        <compilerarg value="-Xlint:all,-unchecked,-rawtypes"/>
1066        <compilerarg value="-Werror"/>
1067        <compilerarg line="${build.args}"/>
1092
1068      </javac>
1069    </target>
1070  
1071 <
1097 <  <target name="jsr166xjar"
1098 <          depends="jsr166xcompile"
1099 <          description="Builds library jar from compiled sources">
1100 <
1071 >  <target name="jsr166xjar" depends="jsr166xcompile">
1072      <jar destfile="${jsr166x.jar}">
1073        <fileset dir="${build.jsr166x.classes.dir}"/>
1074        <manifest>
# Line 1105 | Line 1076
1076          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1077        </manifest>
1078      </jar>
1108
1079    </target>
1080  
1081 <
1112 <  <target name="jsr166xdocs"
1113 <          description="Builds javadocs to dist dir">
1114 <
1081 >  <target name="jsr166xdocs">
1082      <delete dir="${jsr166xdocs.dir}"/>
1083      <mkdir dir="${jsr166xdocs.dir}"/>
1084  
# Line 1126 | Line 1093
1093               failonerror = "true">
1094        <arg line="-Xdocrootparent ${java.docroot.url}"/>
1095        <arg value="-XDignore.symbol.file=true"/>
1129
1096      </javadoc>
1097    </target>
1098  
1099 +  <target name="jsr166xdist" depends="jsr166xdist-jar, jsr166xdist-docs"/>
1100  
1101 <  <target name="jsr166xdist"
1135 <          depends="jsr166xdist-jar, jsr166xdist-docs"
1136 <          description="Puts all distributable products in single hierarchy"/>
1137 <
1138 <
1139 <  <target name="jsr166xclean"
1140 <          description="Removes all jsr166x build products">
1141 <
1101 >  <target name="jsr166xclean">
1102      <delete dir="${build.jsr166x.dir}"/>
1143
1103    </target>
1104  
1105 <
1147 <  <target name="jsr166xdist-jar"
1148 <          depends="jsr166xclean, jsr166xjar">
1105 >  <target name="jsr166xdist-jar" depends="jsr166xclean, jsr166xjar">
1106      <copy file="${jsr166x.jar}" todir="${dist.dir}"/>
1107    </target>
1108  
1109 <  <target name="jsr166xdist-docs"
1153 <          depends="jsr166xclean, jsr166xdocs">
1109 >  <target name="jsr166xdist-docs" depends="jsr166xclean, jsr166xdocs">
1110      <mirror-dir src="${jsr166xdocs.dir}" dst="${dist.jsr166xdocs.dir}"/>
1111    </target>
1112  
1157  <!-- jsr166y -->
1113  
1114 +  <!-- jsr166y (no longer maintained) -->
1115  
1116 <  <target name="jsr166ycompile"
1161 <          depends="configure-compiler"
1162 <          description="Compiles jsr166y sources">
1163 <
1116 >  <target name="jsr166ycompile" depends="configure-compiler">
1117      <mkdir dir="${build.jsr166y.classes.dir}"/>
1118  
1119      <javac srcdir="${topsrc.dir}"
# Line 1183 | Line 1136
1136        <compilerarg value="-Xlint:all"/>
1137        <compilerarg value="-Werror"/>
1138        <compilerarg line="${build.args}"/>
1186
1139      </javac>
1140    </target>
1141  
1142 <
1191 <  <target name="jsr166yjar"
1192 <          depends="jsr166ycompile"
1193 <          description="Builds library jar from compiled sources">
1194 <
1142 >  <target name="jsr166yjar" depends="jsr166ycompile">
1143      <jar destfile="${jsr166y.jar}" index="true">
1144        <fileset dir="${build.jsr166y.classes.dir}"/>
1145        <manifest>
# Line 1199 | Line 1147
1147          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1148        </manifest>
1149      </jar>
1202
1150    </target>
1151  
1152 <
1206 <  <target name="jsr166ydocs"
1207 <          description="Builds javadocs to dist dir">
1208 <
1152 >  <target name="jsr166ydocs">
1153      <delete dir="${jsr166ydocs.dir}"/>
1154      <mkdir dir="${jsr166ydocs.dir}"/>
1155  
# Line 1220 | Line 1164
1164               failonerror = "true">
1165        <arg line="-Xdocrootparent ${java.docroot.url}"/>
1166        <arg value="-XDignore.symbol.file=true"/>
1223
1167      </javadoc>
1168    </target>
1169  
1170 +  <target name="jsr166ydist" depends="jsr166ydist-jar, jsr166ydist-docs"/>
1171  
1172 <  <target name="jsr166ydist"
1229 <          depends="jsr166ydist-jar, jsr166ydist-docs"
1230 <          description="Puts all distributable products in single hierarchy"/>
1231 <
1232 <
1233 <  <target name="jsr166yclean"
1234 <          description="Removes all jsr166y build products">
1235 <
1172 >  <target name="jsr166yclean">
1173      <delete dir="${build.jsr166y.dir}"/>
1237
1174    </target>
1175  
1176 <
1241 <  <target name="jsr166ydist-jar"
1242 <          depends="jsr166yclean, jsr166yjar">
1176 >  <target name="jsr166ydist-jar" depends="jsr166yclean, jsr166yjar">
1177      <copy file="${jsr166y.jar}" todir="${dist.dir}"/>
1178    </target>
1179  
1180 <  <target name="jsr166ydist-docs"
1247 <          depends="jsr166yclean, jsr166ydocs">
1180 >  <target name="jsr166ydist-docs" depends="jsr166yclean, jsr166ydocs">
1181      <mirror-dir src="${jsr166ydocs.dir}" dst="${dist.jsr166ydocs.dir}"/>
1182    </target>
1183  
1184  
1185 <  <!-- extra166y -->
1253 <
1254 <
1255 <  <target name="extra166ycompile"
1256 <          depends="configure-compiler, jsr166yjar"
1257 <          description="Compiles extra166y sources">
1185 >  <!-- extra166y (no longer maintained) -->
1186  
1187 +  <target name="extra166ycompile" depends="configure-compiler, jsr166yjar">
1188      <mkdir dir="${build.extra166y.classes.dir}"/>
1189  
1190      <javac srcdir="${topsrc.dir}"
# Line 1278 | Line 1207
1207        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial"/>
1208        <compilerarg value="-Werror"/>
1209        <compilerarg line="${build.args}"/>
1281
1210      </javac>
1211    </target>
1212  
1213 <
1286 <  <target name="extra166yjar"
1287 <          depends="extra166ycompile"
1288 <          description="Builds library jar from compiled sources">
1289 <
1213 >  <target name="extra166yjar" depends="extra166ycompile">
1214      <jar destfile="${extra166y.jar}" index="true">
1215        <fileset dir="${build.extra166y.classes.dir}"/>
1216        <manifest>
# Line 1294 | Line 1218
1218          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1219        </manifest>
1220      </jar>
1297
1221    </target>
1222  
1223 <
1301 <  <target name="extra166ydocs"
1302 <          description="Builds javadocs to build dir">
1303 <
1223 >  <target name="extra166ydocs">
1224      <delete dir="${extra166ydocs.dir}"/>
1225      <mkdir dir="${extra166ydocs.dir}"/>
1226  
# Line 1314 | Line 1234
1234               executable="${javadoc7}">
1235        <arg line="-Xdocrootparent ${java.docroot.url}"/>
1236        <arg value="-XDignore.symbol.file=true"/>
1317
1237      </javadoc>
1238    </target>
1239  
1240 +  <target name="extra166ydist" depends="extra166ydist-jar, extra166ydist-docs"/>
1241  
1242 <  <target name="extra166ydist"
1323 <          depends="extra166ydist-jar, extra166ydist-docs"
1324 <          description="Puts all distributable products in single hierarchy"/>
1325 <
1326 <
1327 <  <target name="extra166yclean"
1328 <          description="Removes all extra166y build products">
1329 <
1242 >  <target name="extra166yclean">
1243      <delete dir="${build.extra166y.dir}"/>
1331
1244    </target>
1245  
1246 <
1335 <  <target name="extra166ydist-jar"
1336 <          depends="extra166yclean, extra166yjar">
1246 >  <target name="extra166ydist-jar" depends="extra166yclean, extra166yjar">
1247      <copy file="${extra166y.jar}" todir="${dist.dir}"/>
1248    </target>
1249  
1250 <  <target name="extra166ydist-docs"
1341 <          depends="extra166yclean, extra166ydocs">
1250 >  <target name="extra166ydist-docs" depends="extra166yclean, extra166ydocs">
1251      <mirror-dir src="${extra166ydocs.dir}" dst="${dist.extra166ydocs.dir}"/>
1252    </target>
1253  
1254 <  <!-- jsr166e -->
1254 >
1255 >  <!-- jsr166e (no longer maintained) -->
1256  
1257    <property name="build.jsr166e.java.version" value="6"/>
1258    <property name="build.jsr166e.javac" value="${javac6}"/>
1259  
1260 <  <target name="jsr166ecompile"
1351 <          depends="configure-compiler"
1352 <          description="Compiles jsr166e sources">
1353 <
1260 >  <target name="jsr166ecompile" depends="configure-compiler">
1261      <mkdir dir="${build.jsr166e.classes.dir}"/>
1262  
1263      <javac srcdir="${topsrc.dir}"
# Line 1371 | Line 1278
1278        <compilerarg value="-Xlint:all"/>
1279        <compilerarg value="-Werror"/>
1280        <compilerarg line="${build.args}"/>
1374
1281      </javac>
1282    </target>
1283  
1378  <!-- jsr166e: find doclint errors -->
1284    <target name="jsr166edoclint">
1380
1285      <mkdir dir="${build.jsr166e.classes.dir}"/>
1286  
1287      <javac srcdir="${topsrc.dir}"
# Line 1399 | Line 1303
1303        <compilerarg value="-Xlint:all"/>
1304        <compilerarg value="-Werror"/>
1305        <compilerarg value="-Xdoclint:all/protected"/>
1402
1306      </javac>
1307    </target>
1308  
1309 <
1407 <  <target name="jsr166ejar"
1408 <          depends="jsr166ecompile"
1409 <          description="Builds library jar from compiled sources">
1410 <
1309 >  <target name="jsr166ejar" depends="jsr166ecompile">
1310      <jar destfile="${jsr166e.jar}" index="true">
1311        <fileset dir="${build.jsr166e.classes.dir}"/>
1312        <manifest>
# Line 1415 | Line 1314
1314          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1315        </manifest>
1316      </jar>
1418
1317    </target>
1318  
1319 <
1422 <  <target name="jsr166edocs"
1423 <          description="Builds javadocs to build dir">
1424 <
1319 >  <target name="jsr166edocs">
1320      <delete dir="${jsr166edocs.dir}"/>
1321      <mkdir dir="${jsr166edocs.dir}"/>
1322  
# Line 1435 | Line 1330
1330               failonerror = "true">
1331        <arg line="-Xdocrootparent ${java.docroot.url}"/>
1332        <arg value="-XDignore.symbol.file=true"/>
1438
1333      </javadoc>
1334    </target>
1335  
1336 <
1443 <  <target name="jsr166e-tck-one-java-version"
1444 <          depends="jsr166ejar">
1445 <
1336 >  <target name="jsr166e-tck-one-java-version" depends="jsr166ejar">
1337      <echo message="Testing with jdk${build.jsr166e.java.version} ..."/>
1447
1338      <run-tck-tests
1339        tck.src.dir="${test.src.dir}/tck-jsr166e"
1340        target="${build.jsr166e.java.version}"
# Line 1452 | Line 1342
1342        classes="${jsr166e.jar}"/>
1343    </target>
1344  
1345 <  <target name="jsr166e-tck"
1456 <          description="Runs tck tests for jsr166e for multiple java versions">
1345 >  <target name="jsr166e-tck">
1346  
1347   <!--     <antcall target="clean"/> -->
1348   <!--     <antcall target="jsr166e-tck-one-java-version"> -->
# Line 1474 | Line 1363
1363      </antcall>
1364    </target>
1365  
1366 +  <target name="jsr166e-test" depends="jsr166e-tck"/>
1367  
1368 <  <target name="jsr166e-test"
1479 <          depends="jsr166e-tck"
1480 <          description="Runs all tests for jsr166e">
1481 <  </target>
1368 >  <target name="jsr166edist" depends="jsr166edist-jar, jsr166edist-docs"/>
1369  
1370 <  <target name="jsr166edist"
1484 <          depends="jsr166edist-jar, jsr166edist-docs"
1485 <          description="Puts all distributable products in single hierarchy"/>
1486 <
1487 <
1488 <  <target name="jsr166eclean"
1489 <          description="Removes all jsr166e build products">
1370 >  <target name="jsr166eclean">
1371      <delete dir="${build.jsr166e.dir}"/>
1372    </target>
1373  
1493
1374    <target name="jsr166edist-jar"
1375            depends="jsr166eclean, jsr166ejar">
1376      <copy file="${jsr166e.jar}" todir="${dist.dir}"/>
1377    </target>
1378  
1379 <  <target name="jsr166edist-docs"
1500 <          depends="jsr166eclean, jsr166edocs">
1379 >  <target name="jsr166edist-docs" depends="jsr166eclean, jsr166edocs">
1380      <mirror-dir src="${jsr166edocs.dir}" dst="${dist.jsr166edocs.dir}"/>
1381    </target>
1382  
# Line 1520 | Line 1399
1399  
1400   <!-- ==============================================================
1401    Experimental errorprone support - http://errorprone.info
1523  You may need to bring your own errorprone jar.
1402   =================================================================== -->
1403 +  <property name="errorprone.jar" location="${lib.dir}/error_prone_ant-2.2.0.jar"/>
1404 +  <property name="errorprone.jsr166.flags"
1405 +            value="-Xep:HashtableContains:OFF
1406 +                   -Xep:JdkObsolete:OFF
1407 +                   -Xep:MissingOverride:OFF
1408 +                   -Xep:MissingFail:OFF
1409 +                   -Xep:MixedArrayDimensions:ERROR
1410 +                   -Xep:RemoveUnusedImports:ERROR
1411 +                   -Xep:EmptyIf:ERROR
1412 +                   -Xep:MultipleTopLevelClasses:ERROR
1413 +                   -Xep:ClassName:ERROR
1414 +                   -Xep:LongLiteralLowerCaseSuffix:ERROR
1415 +                   -Xep:RedundantThrows:ERROR
1416 +                   -Xep:IdentityBinaryExpression:WARN
1417 +                   -Xep:MethodCanBeStatic:WARN"/>
1418 +  <!-- -Xep:WildcardImport:ERROR -->
1419 +  <property name="errorprone.jsr166.test.flags"
1420 +            value="-Xep:StringSplitter:OFF
1421 +                   -Xep:BoxedPrimitiveConstructor:OFF
1422 +                   -Xep:ModifyingCollectionWithItself:OFF"/>
1423 +  <!-- ant -emacs errorprone |& grep -EA1 '(warning|error):|warnings' -->
1424    <target name="errorprone"
1425            depends="clean, configure-compiler"
1426 <          description="Run errorprone over jsr166 source code">
1426 >          description="Run errorprone over jsr166 source code (experimental)">
1427  
1428      <local name="destdir"/>
1429      <property name="destdir" value="${build.classes.dir}/java.base"/>
# Line 1543 | Line 1442
1442             fork="true">
1443  
1444        <include name="**/*.java"/>
1445 <      <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.api=ALL-UNNAMED"/>
1547 <      <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.util=ALL-UNNAMED"/>
1548 <      <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.tree=ALL-UNNAMED"/>
1549 <      <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.main=ALL-UNNAMED"/>
1550 <      <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.code=ALL-UNNAMED"/>
1551 <      <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.processing=ALL-UNNAMED"/>
1552 <      <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.parser=ALL-UNNAMED"/>
1553 <      <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.comp=ALL-UNNAMED"/>
1554 <      <compilerarg value="-J--add-opens=jdk.compiler/com.sun.tools.javac.comp=ALL-UNNAMED"/>
1555 <      <compilerarg line="-processorpath ${lib.dir}/error_prone_ant-2.0.20-SNAPSHOT.jar"/>
1445 >      <compilerarg line="-processorpath ${errorprone.jar}"/>
1446        <compilerarg value="-Xplugin:ErrorProne
1447 <                          -Xep:IdentityBinaryExpression:WARN
1558 <                          -Xep:MissingOverride:OFF
1559 <                          -Xep:MixedArrayDimensions:WARN
1560 <                          -Xep:RemoveUnusedImports:ERROR
1561 <                          -Xep:MethodCanBeStatic:WARN"/>
1447 >                          ${errorprone.jsr166.flags}"/>
1448        <compilerarg value="--patch-module=java.base=${src.dir}"/>
1449        <compilerarg value="-Xprefer:source"/>
1450        <compilerarg value="-XDignore.symbol.file=true"/>
# Line 1577 | Line 1463
1463        workdir="${build.dir}"
1464        classes="${product.jar}">
1465        <javac-elements>
1466 <        <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.api=ALL-UNNAMED"/>
1467 <        <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.util=ALL-UNNAMED"/>
1468 <        <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.tree=ALL-UNNAMED"/>
1469 <        <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.main=ALL-UNNAMED"/>
1584 <        <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.code=ALL-UNNAMED"/>
1585 <        <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.processing=ALL-UNNAMED"/>
1586 <        <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.parser=ALL-UNNAMED"/>
1587 <        <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.comp=ALL-UNNAMED"/>
1588 <        <compilerarg value="-J--add-opens=jdk.compiler/com.sun.tools.javac.comp=ALL-UNNAMED"/>
1589 <        <compilerarg line="-processorpath ${lib.dir}/error_prone_ant-2.0.20-SNAPSHOT.jar"/>
1590 <        <compilerarg value="-Xplugin:ErrorProne
1591 <                            -Xep:IdentityBinaryExpression:WARN
1592 <                            -Xep:BoxedPrimitiveConstructor:OFF
1593 <                            -Xep:HashtableContains:OFF
1594 <                            -Xep:ModifyingCollectionWithItself:OFF
1595 <                            -Xep:MissingOverride:OFF
1596 <                            -Xep:MixedArrayDimensions:WARN
1597 <                            -Xep:RemoveUnusedImports:ERROR
1598 <                            -Xep:MethodCanBeStatic:WARN"/>
1466 >        <compilerarg line="-processorpath ${errorprone.jar}"/>
1467 >        <compilerarg value="-Xplugin:ErrorProne
1468 >                            ${errorprone.jsr166.flags}
1469 >                            ${errorprone.jsr166.test.flags}"/>
1470          <compilerarg line="-Xmaxerrs 3000 -Xmaxwarns 3000"/>
1471        </javac-elements>
1472      </run-tck-tests>
1473    </target>
1474  
1475 +  <!-- ant -emacs errorprone-jtreg |& grep -EA1 '(warning|error):' -->
1476 +  <!-- -XDcompilePolicy=simple or byfile avoids confusing UnusedImports -->
1477 +  <target name="errorprone-jtreg"
1478 +          depends="jar"
1479 +          description="Run errorprone over jtreg tests (experimental)">
1480 +
1481 +    <run-jtreg-tests
1482 +       target="${build.main.java.version}"
1483 +       workdir="${build.dir}"
1484 +       classes="${product.jar}"
1485 +       verbose="all">
1486 +      <jtreg-elements>
1487 +        <arg value="-javacoption:-XDcompilePolicy=byfile"/>
1488 +        <arg value="-javacoption:-processorpath"/>
1489 +        <arg value="-javacoption:${errorprone.jar}"/>
1490 +        <arg value="-javacoption:-Xplugin:ErrorProne
1491 +                            ${errorprone.jsr166.flags}
1492 +                            ${errorprone.jsr166.test.flags}
1493 +                            -Xep:NonAtomicVolatileUpdate:OFF"/>
1494 +      </jtreg-elements>
1495 +    </run-jtreg-tests>
1496 +  </target>
1497 +
1498  
1499   <!-- ==============================================================
1500    Running guava tests against jsr166 code
# Line 1654 | Line 1548
1548      <get src="http://repo2.maven.org/maven2/com/google/guava/guava-testlib/${guava.version}/guava-testlib-${guava.version}-tests.jar"
1549           dest="${guava.dir}/guava-testlib-tests.jar" usetimestamp="true"/>
1550      <junit printsummary="true" showoutput="true" haltonfailure="true"
1551 <           jvm="${java9}" fork="true">
1552 <      <jvmarg line="-ea -esa --patch-module java.base=${product.jar}"/>
1551 >           jvm="${build.main.java}" fork="true">
1552 >      <jvmarg line="-ea -esa --patch-module=java.base=${product.jar}"/>
1553        <formatter type="brief"/>
1554        <classpath>
1555          <pathelement location="${guava.dir}/guava-testlib-tests.jar"/>

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines