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.235 by jsr166, Sun Mar 19 01:37:51 2017 UTC vs.
Revision 1.254 by jsr166, Mon Sep 25 22:54:09 2017 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    where each of the above is a JDK or a symlink to same, and
26  $HOME/jdk/src/jdk7
25    $HOME/jdk/src/jdk8
26    $HOME/jdk/src/jdk9
27    $HOME/jdk/src/jdk10
# Line 32 | Line 30
30  
31    Alternatively, define ant variables thus:
32    ant -Djdk$N.home=... -Djdk$N.src.home=...
33 <  for $N in 7 8 9 10 ...
33 >  for $N in 8 9 10 ...
34  
35    As of 2016-03, the sources in src/main are for jdk9+ only.
36   ------------------------------------------------------------------------------
# Line 183 | Line 181
181    <property name="junit.jar"        location="${lib.dir}/junit.jar"/>
182  
183    <!-- Canonical location of jdk docs root, to use with javadoc -Xdocrootparent flag -->
184 <  <property name="java5.docroot.url"      value="http://docs.oracle.com/javase/1.5.0/docs"/>
185 <  <property name="java6.docroot.url"      value="http://docs.oracle.com/javase/6/docs"/>
186 <  <property name="java7.docroot.url"      value="http://docs.oracle.com/javase/7/docs"/>
187 <  <property name="java8.docroot.url"      value="http://docs.oracle.com/javase/8/docs"/>
188 <  <!-- The expected canonical location does not yet exist as of 2016-04 -->
189 <  <!-- <property name="java9.docroot.url" value="http://docs.oracle.com/javase/9/docs"/> -->
190 <  <property name="java9.docroot.url"      value="http://download.java.net/java/jdk9/docs"/>
184 >  <property name="java5.docroot.url"  value="http://docs.oracle.com/javase/1.5.0/docs"/>
185 >  <property name="java6.docroot.url"  value="http://docs.oracle.com/javase/6/docs"/>
186 >  <property name="java7.docroot.url"  value="http://docs.oracle.com/javase/7/docs"/>
187 >  <property name="java8.docroot.url"  value="http://docs.oracle.com/javase/8/docs"/>
188 >  <property name="java9.docroot.url"  value="http://docs.oracle.com/javase/9/docs"/>
189 >  <!-- The location of jdk9 early access docs -->
190 >  <!-- <property name="java9.docroot.url" value="http://download.java.net/java/jdk9/docs"/> -->
191    <!-- Default jdk doc location (latest stable release seems best) -->
192 <  <property name="java.docroot.url"       value="${java8.docroot.url}"/>
192 >  <property name="java.docroot.url"   value="${java9.docroot.url}"/>
193  
194    <!-- Canonical location of jdk API docs, to use with javadoc link attribute -->
195    <property name="java5.api.url"      value="${java5.docroot.url}/api/"/>
# Line 234 | Line 232
232        <available file="${jdk@{compile-target}.home}/jmods" type="dir"/>
233      </condition>
234  
235 +    <local name="use-doclint"/>
236 +    <condition property="use-doclint">
237 +      <not> <equals arg1="@{target}" arg2="7"/> </not>
238 +    </condition>
239 +
240      <mkdir dir="@{workdir}/tck-classes"/>
241  
242      <javac srcdir="@{tck.src.dir}"
# Line 253 | Line 256
256        <include name="*.java"/>
257        <compilerarg value="-XDignore.symbol.file=true"/>
258        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation,-try"/>
259 <      <compilerarg value="-Xdoclint:reference/private"/>
259 >      <compilerarg value="-Xdoclint:reference/private" if:set="use-doclint"/>
260        <compilerarg value="-Xbootclasspath/p:@{classes}" unless:set="modules"/>
261        <compilerarg value="--patch-module=java.base=@{classes}" if:set="modules"/>
262        <compilerarg line="${build.args}"/>
# Line 293 | Line 296
296    </macrodef>
297  
298    <!-- Define jtreg test sets for different jdk versions -->
299 +  <fileset dir="${jtreg10.src.dir}">
300 +    <patternset id="jdk10.jtreg.tests">
301 +      <include name="**/*.java"/>
302 +    </patternset>
303 +  </fileset>
304 +
305    <fileset dir="${jtreg9.src.dir}">
306      <patternset id="jdk9.jtreg.tests">
307        <include name="**/*.java"/>
# Line 316 | Line 325
325  
326    <macrodef name="run-jtreg-tests">
327      <!-- ant -Djtreg9.src.dir=src/test/jtreg/util/concurrent/CompletableFuture jtreg -->
319    <attribute name="source" default="7"/>
328      <attribute name="target"/>
329      <attribute name="workdir"/>
330      <attribute name="classes"/>
# Line 338 | Line 346
346             workDir="@{workdir}/JTwork">
347        <patternset refid="jdk@{target}.jtreg.tests"/>
348        <arg value="-Xbootclasspath/p:@{classes}" unless:set="modules"/>
349 <      <arg value="-javacoptions:--patch-module java.base=@{classes}" if:set="modules"/>
350 <      <arg value="-vmoptions:--patch-module java.base=@{classes}" if:set="modules"/>
349 >      <arg value="-javacoptions:--patch-module=java.base=@{classes}" if:set="modules"/>
350 >      <arg value="-vmoptions:--patch-module=java.base=@{classes}" if:set="modules"/>
351        <arg value="-agentvm"/>
352        <arg value="-noreport"/>
353        <arg value="-verbose:${jtreg.verbose}"/>
# Line 364 | Line 372
372    <!-- Main targets -->
373  
374    <property name="build.main.java.version" value="9"/>
375 <  <property name="build.main.javac" value="${javac9}"/>
375 >  <!-- Workaround "no nested properties in ant" -->
376 >  <macrodef name="define-build-main-properties">
377 >    <attribute name="v"/>
378 >    <sequential>
379 >      <property name="build.main.java"    value="${java@{v}}"/>
380 >      <property name="build.main.javac"   value="${javac@{v}}"/>
381 >      <property name="build.main.javadoc" value="${javadoc@{v}}"/>
382 >    </sequential>
383 >  </macrodef>
384 >  <define-build-main-properties v="${build.main.java.version}"/>
385  
386    <target name="dists"
387 <          depends="dist, 4jdk8dist, 4jdk7dist, jsr166edist, jsr166ydist, extra166ydist, jsr166xdist"
387 >          depends="dist, 4jdk8dist"
388            description="Builds all public jars and docs"/>
389 +          <!--
390 +              depends="dist, 4jdk8dist, 4jdk7dist, jsr166edist, jsr166ydist, extra166ydist, jsr166xdist"
391 +          -->
392  
393    <target name="compile"
394            depends="configure-compiler"
395            description="Compiles src/main sources to build dir">
396  
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
397      <local name="destdir"/>
398 <    <property name="destdir" value="${build.classes.dir}/java.base" if:set="modules"/>
387 <    <property name="destdir" value="${build.classes.dir}" unless:set="modules"/>
398 >    <property name="destdir" value="${build.classes.dir}/java.base"/>
399  
400      <mkdir dir="${destdir}"/>
401  
# Line 401 | Line 412
412             fork="true">
413  
414        <include name="**/*.java"/>
415 <      <compilerarg value="--patch-module=java.base=${src.dir}" if:set="modules"/>
415 >      <compilerarg value="--patch-module=java.base=${src.dir}"/>
416        <compilerarg value="-Xprefer:source"/>
417        <compilerarg value="-XDignore.symbol.file=true"/>
418        <compilerarg value="-Xlint:all"/>
419 <      <compilerarg value="-Werror"/>
419 >      <compilerarg line="--doclint-format html5"/>
420        <compilerarg value="-Xdoclint:all/protected,reference/private"/>
421 +      <compilerarg value="-Werror"/>
422        <compilerarg line="-Xmaxerrs 1000 -Xmaxwarns 1000"/>
423        <compilerarg line="${build.args}"/>
424  
# Line 450 | Line 462
462               access="${build.javadoc.access}"
463               sourcepath="${src.dir}"
464               classpath=""
465 <             executable="${javadoc9}">
465 >             source="9"
466 >             executable="${build.main.javadoc}">
467        <fileset dir="${src.dir}" defaultexcludes="yes">
468          <include name="**/*.java"/>
469        </fileset>
470        <arg line="-Xdocrootparent ${java9.docroot.url}"/>
471        <arg line="-Xmaxerrs 1000 -Xmaxwarns 1000"/>
472        <arg value="-XDignore.symbol.file=true"/>
473 +      <arg value="-html5"/>
474        <arg value="--patch-module=java.base=${src.dir}"/>
475        <arg value="-tag"/>
476        <arg value="${javadoc.jls.option}"/>
# Line 505 | Line 519
519  
520    <target name="clean"
521            description="Removes all build products">
508
522      <delete dir="${build.dir}"/>
510
523    </target>
524  
525  
526    <target name="dist-clean"
527            description="Removes all build and distribution products">
516
528      <delete dir="${build.dir}"/>
529      <delete dir="${dist.dir}"/>
519
530    </target>
531  
532  
# Line 537 | Line 547
547      <run-tck-tests
548        target="${build.main.java.version}"
549        workdir="${build.dir}"
550 <      classes="${product.jar}"/>
550 >      classes="${product.jar}">
551 >      <javac-elements>
552 >        <compilerarg value="-Werror"/>
553 >      </javac-elements>
554 >    </run-tck-tests>
555    </target>
556  
557    <target name="tck-parallelism-1"
# Line 572 | Line 586
586  
587    <target name="test"
588            depends="tck, tck-parallelism-1, tck-parallelism-0, jtreg"
589 <          description="Runs tck and jtreg tests for src/main">
576 <  </target>
589 >          description="Runs tck and jtreg tests for src/main"/>
590  
591   <!--   <target name="jtreg8" description="Runs jtreg tests with jdk8"> -->
592  
# Line 584 | Line 597
597  
598   <!--   </target> -->
599  
600 < <!--   <target name="test89" -->
601 < <!--           description="Runs tck and jtreg tests for src/main for multiple java versions"> -->
600 >  <target name="test910"
601 >          description="Runs tck and jtreg tests for src/main for multiple java versions">
602  
603 < <!--     <antcall target="clean"/> -->
604 < <!--     <antcall target="test"> -->
605 < <!--       <param name="build.main.java.version" value="8"/> -->
606 < <!--       <param name="build.main.javac" value="${javac8}"/> -->
594 < <!--     </antcall> -->
603 >    <antcall target="clean"/>
604 >    <antcall target="test">
605 >      <param name="build.main.java.version" value="9"/>
606 >    </antcall>
607  
608 < <!--     <antcall target="clean"/> -->
609 < <!--     <antcall target="test"> -->
610 < <!--       <param name="build.main.java.version" value="9"/> -->
611 < <!--       <param name="build.main.javac" value="${javac9}"/> -->
600 < <!--     </antcall> -->
608 >    <antcall target="clean"/>
609 >    <antcall target="test">
610 >      <param name="build.main.java.version" value="10"/>
611 >    </antcall>
612  
613 < <!--   </target> -->
613 >    <!-- Clean up to avoid obscure wrong class file version bugs -->
614 >    <antcall target="clean"/>
615 >
616 >  </target>
617  
618  
619  
620    <target name="configure-compiler">
621      <fail message="ant version too old">
622 <      <condition>
609 <        <not> <antversion atleast="1.9.1"/> </not>
610 <      </condition>
622 >      <condition> <not> <antversion atleast="1.9.1"/> </not> </condition>
623      </fail>
624  
625      <property name="unchecked.option" value="-Xlint:unchecked"/>
# Line 653 | Line 665
665      <java classname="ALoops" fork="true">
666        <classpath refid="loops.classpath"/>
667      </java>
656
668    </target>
669  
670  
671    <target name="compile-test-loops" depends="jar"
672 <          description="compile all the perf tests in src/test/loops">
672 >          description="Compiles all the perf tests in src/test/loops">
673  
674      <mkdir dir="${build.dir}/test/loops"/>
675  
# Line 670 | Line 681
681             includeAntRuntime="false"
682             includeJavaRuntime="false"
683             encoding="ASCII"
684 <           executable="${javac9}"
684 >           executable="${build.main.javac}"
685             fork="true">
686  
687        <include name="*.java"/>
# Line 678 | Line 689
689        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial"/>
690        <compilerarg value="-Xbootclasspath/p:${product.jar}"/>
691        <compilerarg line="${build.args}"/>
681
692      </javac>
683
693    </target>
694  
695  
# Line 706 | Line 715
715             encoding="ASCII"
716             executable="${javac8}"
717             fork="true">
709
718        <include name="**/*.java"/>
719        <compilerarg value="-Xprefer:source"/>
720        <compilerarg value="-XDignore.symbol.file=true"/>
721        <compilerarg value="-Xlint:all"/>
722        <compilerarg value="-Werror"/>
723        <compilerarg line="${build.args}"/>
716
724      </javac>
725    </target>
726  
# Line 737 | Line 744
744             encoding="ASCII"
745             executable="${javac8}"
746             fork="true">
740
747        <include name="**/*.java"/>
748        <compilerarg value="-Xprefer:source"/>
749        <compilerarg value="-XDignore.symbol.file=true"/>
750        <compilerarg value="-Xlint:all"/>
751        <compilerarg value="-Xdoclint:all/protected,reference/private"/>
752        <compilerarg line="${build.args}"/>
747
753      </javac>
754    </target>
755  
# Line 760 | Line 765
765          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
766        </manifest>
767      </jar>
763
768    </target>
769  
770  
# Line 776 | Line 780
780          <!-- JDK9+ test classes -->
781          <exclude name="*9Test.java"/>
782          <exclude name="*10Test.java"/>
783 +        <compilerarg value="-Werror"/>
784        </javac-elements>
785      </run-tck-tests>
786    </target>
# Line 793 | Line 798
798  
799    <target name="4jdk8-test"
800            depends="4jdk8-tck, 4jdk8-jtreg"
801 <          description="Runs tck and jtreg tests for jsr166-4jdk8">
797 <  </target>
801 >          description="Runs tck and jtreg tests for jsr166-4jdk8"/>
802  
803  
804    <target name="4jdk8docs"
# Line 810 | Line 814
814               access="${build.javadoc.access}"
815               sourcepath="${4jdk8src.dir}:${jdk8.src.dir}"
816               classpath=""
817 +             source="8"
818               executable="${javadoc8}"
819               failonerror = "true">
820        <fileset dir="${4jdk8src.dir}" defaultexcludes="yes">
# Line 837 | Line 842
842  
843    <target name="4jdk8clean"
844            description="Removes all 4jdk8 build products">
840
845      <delete dir="${build.4jdk8.dir}"/>
842
846    </target>
847  
848  
# Line 855 | Line 858
858    </target>
859  
860  
861 +  <!-- jsr166 4jdk7 (no longer maintained) -->
862  
863 <  <!-- jsr166 4jdk7 -->
860 <
861 <  <target name="4jdk7compile"
862 <          depends="configure-compiler"
863 <          description="Compiles src/jdk7 sources, targeting jdk7">
864 <
863 >  <target name="4jdk7compile" depends="configure-compiler">
864      <mkdir dir="${build.4jdk7.classes.dir}"/>
865  
866      <javac srcdir="${4jdk7src.dir}"
# Line 885 | Line 884
884        <compilerarg value="-Xlint:all"/>
885        <compilerarg value="-Werror"/>
886        <compilerarg line="${build.args}"/>
888
887      </javac>
888    </target>
889  
890 <  <target name="4jdk7doclint"
893 <          depends="configure-compiler"
894 <          description="Finds doclint warnings">
895 <
890 >  <target name="4jdk7doclint" depends="configure-compiler">
891      <mkdir dir="${build.4jdk7.classes.dir}"/>
892  
893      <javac srcdir="${4jdk7src.dir}"
# Line 916 | Line 911
911        <compilerarg value="-Xlint:all"/>
912        <compilerarg value="-Xdoclint:all/protected"/>
913        <compilerarg line="${build.args}"/>
919
914      </javac>
915    </target>
916  
917 <
924 <  <target name="4jdk7jar"
925 <          depends="4jdk7compile"
926 <          description="Builds library jar from compiled sources">
927 <
917 >  <target name="4jdk7jar" depends="4jdk7compile">
918      <jar destfile="${4jdk7product.jar}">
919        <fileset dir="${build.4jdk7.classes.dir}"/>
920        <manifest>
# Line 932 | Line 922
922          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
923        </manifest>
924      </jar>
935
925    </target>
926  
927 <
939 <  <target name="4jdk7-tck"
940 <          depends="4jdk7jar"
941 <          description="Runs tck tests for jsr166-4jdk7 directly">
942 <
927 >  <target name="4jdk7-tck" depends="4jdk7jar">
928      <run-tck-tests
929        target="7"
930        workdir="${build.4jdk7.dir}"
# Line 957 | Line 942
942          <exclude name="SplittableRandomTest.java"/>
943          <exclude name="StampedLockTest.java"/>
944          <exclude name="SubmissionPublisherTest.java"/>
945 +        <compilerarg value="-Werror"/>
946        </javac-elements>
947      </run-tck-tests>
948    </target>
949  
964
950    <!-- Runs tck tests for jsr166-4jdk7 via junit task (dead experiment) -->
951 <  <target name="4jdk7-tck-junit"
967 <          depends="4jdk7compile">
951 >  <target name="4jdk7-tck-junit" depends="4jdk7compile">
952  
953      <junit printsummary="true"
954             showoutput="true"
# Line 986 | Line 970
970  
971        <test name="${jsr166.tckTestClass}" haltonfailure="no">
972        </test>
989
973      </junit>
974    </target>
975  
976 <  <target name="4jdk7-jtreg"
994 <          depends="4jdk7jar"
995 <          description="Runs jtreg tests for jsr166-4jdk7 using the jtreg ant task">
976 >  <target name="4jdk7-jtreg" depends="4jdk7jar">
977      <run-jtreg-tests
978         target="7"
979         workdir="${build.4jdk7.dir}"
980         classes="${4jdk7product.jar}"/>
981    </target>
982  
983 +  <target name="4jdk7-test" depends="4jdk7-tck, 4jdk7-jtreg"/>
984  
985 <  <target name="4jdk7-test"
1004 <          depends="4jdk7-tck, 4jdk7-jtreg"
1005 <          description="Runs tck and jtreg tests for jsr166-4jdk7">
1006 <  </target>
1007 <
1008 <
1009 <  <target name="4jdk7docs"
1010 <          description="Builds javadocs for src/jdk7 to dist dir">
1011 <
985 >  <target name="4jdk7docs">
986      <delete dir="${4jdk7docs.dir}"/>
987      <mkdir dir="${4jdk7docs.dir}"/>
988  
# Line 1029 | Line 1003
1003      </javadoc>
1004    </target>
1005  
1006 +  <target name="4jdk7dist" depends="4jdk7dist-jar, 4jdk7dist-docs"/>
1007  
1008 <  <target name="4jdk7dist"
1034 <          depends="4jdk7dist-jar, 4jdk7dist-docs"
1035 <          description="Puts all distributable products in single hierarchy"/>
1036 <
1037 <
1038 <  <target name="4jdk7clean"
1039 <          description="Removes all 4jdk7 build products">
1040 <
1008 >  <target name="4jdk7clean">
1009      <delete dir="${build.4jdk7.dir}"/>
1042
1010    </target>
1011  
1012 <
1046 <  <target name="4jdk7dist-jar"
1047 <          depends="4jdk7clean, 4jdk7jar">
1012 >  <target name="4jdk7dist-jar" depends="4jdk7clean, 4jdk7jar">
1013      <copy file="${4jdk7product.jar}" todir="${dist.dir}"/>
1014    </target>
1015  
1016 <
1052 <  <target name="4jdk7dist-docs"
1053 <          depends="4jdk7clean, 4jdk7docs">
1016 >  <target name="4jdk7dist-docs" depends="4jdk7clean, 4jdk7docs">
1017      <mirror-dir src="${4jdk7docs.dir}" dst="${dist.4jdk7docs.dir}"/>
1018    </target>
1019  
1020  
1021 <  <!-- jsr166x -->
1059 <
1060 <  <target name="jsr166xcompile"
1061 <          depends="configure-compiler"
1062 <          description="Compiles jsr166x sources to build dir">
1021 >  <!-- jsr166x (no longer maintained) -->
1022  
1023 +  <target name="jsr166xcompile" depends="configure-compiler">
1024      <mkdir dir="${build.jsr166x.classes.dir}"/>
1025  
1026      <javac srcdir="${topsrc.dir}"
# Line 1077 | Line 1037
1037             encoding="ASCII"
1038             executable="${javac7}"
1039             fork="true">
1080
1040        <include name="jsr166x/**/*.java"/>
1041        <compilerarg value="-XDignore.symbol.file=true"/>
1042        <compilerarg value="-Xlint:all,-unchecked,-rawtypes"/>
1043        <compilerarg value="-Werror"/>
1044        <compilerarg line="${build.args}"/>
1086
1045      </javac>
1046    </target>
1047  
1048 <
1091 <  <target name="jsr166xjar"
1092 <          depends="jsr166xcompile"
1093 <          description="Builds library jar from compiled sources">
1094 <
1048 >  <target name="jsr166xjar" depends="jsr166xcompile">
1049      <jar destfile="${jsr166x.jar}">
1050        <fileset dir="${build.jsr166x.classes.dir}"/>
1051        <manifest>
# Line 1099 | Line 1053
1053          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1054        </manifest>
1055      </jar>
1102
1056    </target>
1057  
1058 <
1106 <  <target name="jsr166xdocs"
1107 <          description="Builds javadocs to dist dir">
1108 <
1058 >  <target name="jsr166xdocs">
1059      <delete dir="${jsr166xdocs.dir}"/>
1060      <mkdir dir="${jsr166xdocs.dir}"/>
1061  
# Line 1120 | Line 1070
1070               failonerror = "true">
1071        <arg line="-Xdocrootparent ${java.docroot.url}"/>
1072        <arg value="-XDignore.symbol.file=true"/>
1123
1073      </javadoc>
1074    </target>
1075  
1076 +  <target name="jsr166xdist" depends="jsr166xdist-jar, jsr166xdist-docs"/>
1077  
1078 <  <target name="jsr166xdist"
1129 <          depends="jsr166xdist-jar, jsr166xdist-docs"
1130 <          description="Puts all distributable products in single hierarchy"/>
1131 <
1132 <
1133 <  <target name="jsr166xclean"
1134 <          description="Removes all jsr166x build products">
1135 <
1078 >  <target name="jsr166xclean">
1079      <delete dir="${build.jsr166x.dir}"/>
1137
1080    </target>
1081  
1082 <
1141 <  <target name="jsr166xdist-jar"
1142 <          depends="jsr166xclean, jsr166xjar">
1082 >  <target name="jsr166xdist-jar" depends="jsr166xclean, jsr166xjar">
1083      <copy file="${jsr166x.jar}" todir="${dist.dir}"/>
1084    </target>
1085  
1086 <  <target name="jsr166xdist-docs"
1147 <          depends="jsr166xclean, jsr166xdocs">
1086 >  <target name="jsr166xdist-docs" depends="jsr166xclean, jsr166xdocs">
1087      <mirror-dir src="${jsr166xdocs.dir}" dst="${dist.jsr166xdocs.dir}"/>
1088    </target>
1089  
1151  <!-- jsr166y -->
1152
1090  
1091 <  <target name="jsr166ycompile"
1155 <          depends="configure-compiler"
1156 <          description="Compiles jsr166y sources">
1091 >  <!-- jsr166y (no longer maintained) -->
1092  
1093 +  <target name="jsr166ycompile" depends="configure-compiler">
1094      <mkdir dir="${build.jsr166y.classes.dir}"/>
1095  
1096      <javac srcdir="${topsrc.dir}"
# Line 1177 | Line 1113
1113        <compilerarg value="-Xlint:all"/>
1114        <compilerarg value="-Werror"/>
1115        <compilerarg line="${build.args}"/>
1180
1116      </javac>
1117    </target>
1118  
1119 <
1185 <  <target name="jsr166yjar"
1186 <          depends="jsr166ycompile"
1187 <          description="Builds library jar from compiled sources">
1188 <
1119 >  <target name="jsr166yjar" depends="jsr166ycompile">
1120      <jar destfile="${jsr166y.jar}" index="true">
1121        <fileset dir="${build.jsr166y.classes.dir}"/>
1122        <manifest>
# Line 1193 | Line 1124
1124          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1125        </manifest>
1126      </jar>
1196
1127    </target>
1128  
1129 <
1200 <  <target name="jsr166ydocs"
1201 <          description="Builds javadocs to dist dir">
1202 <
1129 >  <target name="jsr166ydocs">
1130      <delete dir="${jsr166ydocs.dir}"/>
1131      <mkdir dir="${jsr166ydocs.dir}"/>
1132  
# Line 1214 | Line 1141
1141               failonerror = "true">
1142        <arg line="-Xdocrootparent ${java.docroot.url}"/>
1143        <arg value="-XDignore.symbol.file=true"/>
1217
1144      </javadoc>
1145    </target>
1146  
1147 +  <target name="jsr166ydist" depends="jsr166ydist-jar, jsr166ydist-docs"/>
1148  
1149 <  <target name="jsr166ydist"
1223 <          depends="jsr166ydist-jar, jsr166ydist-docs"
1224 <          description="Puts all distributable products in single hierarchy"/>
1225 <
1226 <
1227 <  <target name="jsr166yclean"
1228 <          description="Removes all jsr166y build products">
1229 <
1149 >  <target name="jsr166yclean">
1150      <delete dir="${build.jsr166y.dir}"/>
1231
1151    </target>
1152  
1153 <
1235 <  <target name="jsr166ydist-jar"
1236 <          depends="jsr166yclean, jsr166yjar">
1153 >  <target name="jsr166ydist-jar" depends="jsr166yclean, jsr166yjar">
1154      <copy file="${jsr166y.jar}" todir="${dist.dir}"/>
1155    </target>
1156  
1157 <  <target name="jsr166ydist-docs"
1241 <          depends="jsr166yclean, jsr166ydocs">
1157 >  <target name="jsr166ydist-docs" depends="jsr166yclean, jsr166ydocs">
1158      <mirror-dir src="${jsr166ydocs.dir}" dst="${dist.jsr166ydocs.dir}"/>
1159    </target>
1160  
1161  
1162 <  <!-- extra166y -->
1247 <
1248 <
1249 <  <target name="extra166ycompile"
1250 <          depends="configure-compiler, jsr166yjar"
1251 <          description="Compiles extra166y sources">
1162 >  <!-- extra166y (no longer maintained) -->
1163  
1164 +  <target name="extra166ycompile" depends="configure-compiler, jsr166yjar">
1165      <mkdir dir="${build.extra166y.classes.dir}"/>
1166  
1167      <javac srcdir="${topsrc.dir}"
# Line 1272 | Line 1184
1184        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial"/>
1185        <compilerarg value="-Werror"/>
1186        <compilerarg line="${build.args}"/>
1275
1187      </javac>
1188    </target>
1189  
1190 <
1280 <  <target name="extra166yjar"
1281 <          depends="extra166ycompile"
1282 <          description="Builds library jar from compiled sources">
1283 <
1190 >  <target name="extra166yjar" depends="extra166ycompile">
1191      <jar destfile="${extra166y.jar}" index="true">
1192        <fileset dir="${build.extra166y.classes.dir}"/>
1193        <manifest>
# Line 1288 | Line 1195
1195          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1196        </manifest>
1197      </jar>
1291
1198    </target>
1199  
1200 <
1295 <  <target name="extra166ydocs"
1296 <          description="Builds javadocs to build dir">
1297 <
1200 >  <target name="extra166ydocs">
1201      <delete dir="${extra166ydocs.dir}"/>
1202      <mkdir dir="${extra166ydocs.dir}"/>
1203  
# Line 1308 | Line 1211
1211               executable="${javadoc7}">
1212        <arg line="-Xdocrootparent ${java.docroot.url}"/>
1213        <arg value="-XDignore.symbol.file=true"/>
1311
1214      </javadoc>
1215    </target>
1216  
1217 +  <target name="extra166ydist" depends="extra166ydist-jar, extra166ydist-docs"/>
1218  
1219 <  <target name="extra166ydist"
1317 <          depends="extra166ydist-jar, extra166ydist-docs"
1318 <          description="Puts all distributable products in single hierarchy"/>
1319 <
1320 <
1321 <  <target name="extra166yclean"
1322 <          description="Removes all extra166y build products">
1323 <
1219 >  <target name="extra166yclean">
1220      <delete dir="${build.extra166y.dir}"/>
1325
1221    </target>
1222  
1223 <
1329 <  <target name="extra166ydist-jar"
1330 <          depends="extra166yclean, extra166yjar">
1223 >  <target name="extra166ydist-jar" depends="extra166yclean, extra166yjar">
1224      <copy file="${extra166y.jar}" todir="${dist.dir}"/>
1225    </target>
1226  
1227 <  <target name="extra166ydist-docs"
1335 <          depends="extra166yclean, extra166ydocs">
1227 >  <target name="extra166ydist-docs" depends="extra166yclean, extra166ydocs">
1228      <mirror-dir src="${extra166ydocs.dir}" dst="${dist.extra166ydocs.dir}"/>
1229    </target>
1230  
1231 <  <!-- jsr166e -->
1231 >
1232 >  <!-- jsr166e (no longer maintained) -->
1233  
1234    <property name="build.jsr166e.java.version" value="6"/>
1235    <property name="build.jsr166e.javac" value="${javac6}"/>
1236  
1237 <  <target name="jsr166ecompile"
1345 <          depends="configure-compiler"
1346 <          description="Compiles jsr166e sources">
1347 <
1237 >  <target name="jsr166ecompile" depends="configure-compiler">
1238      <mkdir dir="${build.jsr166e.classes.dir}"/>
1239  
1240      <javac srcdir="${topsrc.dir}"
# Line 1365 | Line 1255
1255        <compilerarg value="-Xlint:all"/>
1256        <compilerarg value="-Werror"/>
1257        <compilerarg line="${build.args}"/>
1368
1258      </javac>
1259    </target>
1260  
1372  <!-- jsr166e: find doclint errors -->
1261    <target name="jsr166edoclint">
1374
1262      <mkdir dir="${build.jsr166e.classes.dir}"/>
1263  
1264      <javac srcdir="${topsrc.dir}"
# Line 1393 | Line 1280
1280        <compilerarg value="-Xlint:all"/>
1281        <compilerarg value="-Werror"/>
1282        <compilerarg value="-Xdoclint:all/protected"/>
1396
1283      </javac>
1284    </target>
1285  
1286 <
1401 <  <target name="jsr166ejar"
1402 <          depends="jsr166ecompile"
1403 <          description="Builds library jar from compiled sources">
1404 <
1286 >  <target name="jsr166ejar" depends="jsr166ecompile">
1287      <jar destfile="${jsr166e.jar}" index="true">
1288        <fileset dir="${build.jsr166e.classes.dir}"/>
1289        <manifest>
# Line 1409 | Line 1291
1291          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1292        </manifest>
1293      </jar>
1412
1294    </target>
1295  
1296 <
1416 <  <target name="jsr166edocs"
1417 <          description="Builds javadocs to build dir">
1418 <
1296 >  <target name="jsr166edocs">
1297      <delete dir="${jsr166edocs.dir}"/>
1298      <mkdir dir="${jsr166edocs.dir}"/>
1299  
# Line 1429 | Line 1307
1307               failonerror = "true">
1308        <arg line="-Xdocrootparent ${java.docroot.url}"/>
1309        <arg value="-XDignore.symbol.file=true"/>
1432
1310      </javadoc>
1311    </target>
1312  
1313 <
1437 <  <target name="jsr166e-tck-one-java-version"
1438 <          depends="jsr166ejar">
1439 <
1313 >  <target name="jsr166e-tck-one-java-version" depends="jsr166ejar">
1314      <echo message="Testing with jdk${build.jsr166e.java.version} ..."/>
1441
1315      <run-tck-tests
1316        tck.src.dir="${test.src.dir}/tck-jsr166e"
1317        target="${build.jsr166e.java.version}"
# Line 1446 | Line 1319
1319        classes="${jsr166e.jar}"/>
1320    </target>
1321  
1322 <  <target name="jsr166e-tck"
1450 <          description="Runs tck tests for jsr166e for multiple java versions">
1322 >  <target name="jsr166e-tck">
1323  
1324   <!--     <antcall target="clean"/> -->
1325   <!--     <antcall target="jsr166e-tck-one-java-version"> -->
# Line 1468 | Line 1340
1340      </antcall>
1341    </target>
1342  
1343 +  <target name="jsr166e-test" depends="jsr166e-tck"/>
1344  
1345 <  <target name="jsr166e-test"
1473 <          depends="jsr166e-tck"
1474 <          description="Runs all tests for jsr166e">
1475 <  </target>
1476 <
1477 <  <target name="jsr166edist"
1478 <          depends="jsr166edist-jar, jsr166edist-docs"
1479 <          description="Puts all distributable products in single hierarchy"/>
1480 <
1345 >  <target name="jsr166edist" depends="jsr166edist-jar, jsr166edist-docs"/>
1346  
1347 <  <target name="jsr166eclean"
1483 <          description="Removes all jsr166e build products">
1347 >  <target name="jsr166eclean">
1348      <delete dir="${build.jsr166e.dir}"/>
1349    </target>
1350  
1487
1351    <target name="jsr166edist-jar"
1352            depends="jsr166eclean, jsr166ejar">
1353      <copy file="${jsr166e.jar}" todir="${dist.dir}"/>
1354    </target>
1355  
1356 <  <target name="jsr166edist-docs"
1494 <          depends="jsr166eclean, jsr166edocs">
1356 >  <target name="jsr166edist-docs" depends="jsr166eclean, jsr166edocs">
1357      <mirror-dir src="${jsr166edocs.dir}" dst="${dist.jsr166edocs.dir}"/>
1358    </target>
1359  
# Line 1511 | Line 1373
1373      </antcall>
1374    </target>
1375  
1376 +
1377 + <!-- ==============================================================
1378 +  Experimental errorprone support - http://errorprone.info
1379 + =================================================================== -->
1380 +  <property name="errorprone.jar" location="${lib.dir}/error_prone_ant-2.0.21.jar"/>
1381 +  <target name="errorprone"
1382 +          depends="clean, configure-compiler"
1383 +          description="Run errorprone over jsr166 source code (experimental)">
1384 +
1385 +    <local name="destdir"/>
1386 +    <property name="destdir" value="${build.classes.dir}/java.base"/>
1387 +    <mkdir dir="${destdir}"/>
1388 +
1389 +    <javac srcdir="${src.dir}"
1390 +           destdir="${destdir}"
1391 +           debug="${build.debug}"
1392 +           debuglevel="${build.debuglevel}"
1393 +           deprecation="${build.deprecation}"
1394 +           classpath=""
1395 +           includeAntRuntime="false"
1396 +           includeJavaRuntime="false"
1397 +           encoding="ASCII"
1398 +           executable="${build.main.javac}"
1399 +           fork="true">
1400 +
1401 +      <include name="**/*.java"/>
1402 +      <compilerarg line="-processorpath ${errorprone.jar}"/>
1403 +      <compilerarg value="-Xplugin:ErrorProne
1404 +                          -Xep:IdentityBinaryExpression:WARN
1405 +                          -Xep:MissingOverride:OFF
1406 +                          -Xep:MixedArrayDimensions:WARN
1407 +                          -Xep:RemoveUnusedImports:ERROR
1408 +                          -Xep:ClassName:ERROR
1409 +                          -Xep:MultipleTopLevelClasses:ERROR
1410 +                          -Xep:EmptyIf:ERROR
1411 +                          -Xep:LongLiteralLowerCaseSuffix:ERROR
1412 +                          -Xep:RedundantThrows:ERROR
1413 +                          -Xep:MethodCanBeStatic:WARN"/>
1414 +      <compilerarg value="--patch-module=java.base=${src.dir}"/>
1415 +      <compilerarg value="-Xprefer:source"/>
1416 +      <compilerarg value="-XDignore.symbol.file=true"/>
1417 +      <compilerarg value="-Xlint:all"/>
1418 +      <compilerarg value="-Xdoclint:all/protected,reference/private"/>
1419 +      <compilerarg line="-Xmaxerrs 3000 -Xmaxwarns 3000"/>
1420 +      <compilerarg line="${build.args}"/>
1421 +    </javac>
1422 +
1423 +    <jar destfile="${product.jar}">
1424 +      <fileset dir="${destdir}"/>
1425 +    </jar>
1426 +
1427 +    <run-tck-tests
1428 +      target="${build.main.java.version}"
1429 +      workdir="${build.dir}"
1430 +      classes="${product.jar}">
1431 +      <javac-elements>
1432 +        <compilerarg line="-processorpath ${errorprone.jar}"/>
1433 +        <compilerarg value="-Xplugin:ErrorProne
1434 +                            -Xep:IdentityBinaryExpression:WARN
1435 +                            -Xep:BoxedPrimitiveConstructor:OFF
1436 +                            -Xep:HashtableContains:OFF
1437 +                            -Xep:ModifyingCollectionWithItself:OFF
1438 +                            -Xep:MissingOverride:OFF
1439 +                            -Xep:MixedArrayDimensions:WARN
1440 +                            -Xep:RemoveUnusedImports:ERROR
1441 +                            -Xep:ClassName:ERROR
1442 +                            -Xep:MultipleTopLevelClasses:ERROR
1443 +                            -Xep:EmptyIf:ERROR
1444 +                            -Xep:LongLiteralLowerCaseSuffix:ERROR
1445 +                            -Xep:RedundantThrows:ERROR
1446 +                            -Xep:MethodCanBeStatic:WARN"/>
1447 +        <compilerarg line="-Xmaxerrs 3000 -Xmaxwarns 3000"/>
1448 +      </javac-elements>
1449 +    </run-tck-tests>
1450 +  </target>
1451 +
1452 +
1453   <!-- ==============================================================
1454    Running guava tests against jsr166 code
1455   =================================================================== -->
# Line 1563 | Line 1502
1502      <get src="http://repo2.maven.org/maven2/com/google/guava/guava-testlib/${guava.version}/guava-testlib-${guava.version}-tests.jar"
1503           dest="${guava.dir}/guava-testlib-tests.jar" usetimestamp="true"/>
1504      <junit printsummary="true" showoutput="true" haltonfailure="true"
1505 <           jvm="${java9}" fork="true">
1506 <      <jvmarg line="-ea -esa --patch-module java.base=${product.jar}"/>
1505 >           jvm="${build.main.java}" fork="true">
1506 >      <jvmarg line="-ea -esa --patch-module=java.base=${product.jar}"/>
1507        <formatter type="brief"/>
1508        <classpath>
1509          <pathelement location="${guava.dir}/guava-testlib-tests.jar"/>

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines