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.255 by jsr166, Thu Sep 28 01:17:47 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"/>
331 +    <attribute name="verbose" default="${jtreg.verbose}"/>
332      <attribute name="jtregflags" default=""/>
333 +    <element name="jtreg-elements" optional="true"/>
334  
335      <sequential>
336  
# Line 338 | Line 348
348             workDir="@{workdir}/JTwork">
349        <patternset refid="jdk@{target}.jtreg.tests"/>
350        <arg value="-Xbootclasspath/p:@{classes}" unless:set="modules"/>
351 <      <arg value="-javacoptions:--patch-module java.base=@{classes}" if:set="modules"/>
352 <      <arg value="-vmoptions:--patch-module java.base=@{classes}" if:set="modules"/>
351 >      <arg value="-javacoptions:--patch-module=java.base=@{classes}" if:set="modules"/>
352 >      <arg value="-vmoptions:--patch-module=java.base=@{classes}" if:set="modules"/>
353        <arg value="-agentvm"/>
354        <arg value="-noreport"/>
355 <      <arg value="-verbose:${jtreg.verbose}"/>
355 >      <arg value="-verbose:@{verbose}"/>
356        <arg value="-vmoptions:-esa -ea"/>
357        <arg value="-automatic"/>
358        <arg value="-k:!ignore"/>
359        <arg line="@{jtregflags}"/>
360        <arg line="${jtreg.flags}"/>
361 +      <jtreg-elements/>
362      </jtreg>
363      </sequential>
364    </macrodef>
# Line 364 | Line 375
375    <!-- Main targets -->
376  
377    <property name="build.main.java.version" value="9"/>
378 <  <property name="build.main.javac" value="${javac9}"/>
378 >  <!-- Workaround "no nested properties in ant" -->
379 >  <macrodef name="define-build-main-properties">
380 >    <attribute name="v"/>
381 >    <sequential>
382 >      <property name="build.main.java"    value="${java@{v}}"/>
383 >      <property name="build.main.javac"   value="${javac@{v}}"/>
384 >      <property name="build.main.javadoc" value="${javadoc@{v}}"/>
385 >    </sequential>
386 >  </macrodef>
387 >  <define-build-main-properties v="${build.main.java.version}"/>
388  
389    <target name="dists"
390 <          depends="dist, 4jdk8dist, 4jdk7dist, jsr166edist, jsr166ydist, extra166ydist, jsr166xdist"
390 >          depends="dist, 4jdk8dist"
391            description="Builds all public jars and docs"/>
392 +          <!--
393 +              depends="dist, 4jdk8dist, 4jdk7dist, jsr166edist, jsr166ydist, extra166ydist, jsr166xdist"
394 +          -->
395  
396    <target name="compile"
397            depends="configure-compiler"
398            description="Compiles src/main sources to build dir">
399  
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
400      <local name="destdir"/>
401 <    <property name="destdir" value="${build.classes.dir}/java.base" if:set="modules"/>
387 <    <property name="destdir" value="${build.classes.dir}" unless:set="modules"/>
401 >    <property name="destdir" value="${build.classes.dir}/java.base"/>
402  
403      <mkdir dir="${destdir}"/>
404  
# Line 401 | Line 415
415             fork="true">
416  
417        <include name="**/*.java"/>
418 <      <compilerarg value="--patch-module=java.base=${src.dir}" if:set="modules"/>
418 >      <compilerarg value="--patch-module=java.base=${src.dir}"/>
419        <compilerarg value="-Xprefer:source"/>
420        <compilerarg value="-XDignore.symbol.file=true"/>
421        <compilerarg value="-Xlint:all"/>
422 <      <compilerarg value="-Werror"/>
422 >      <compilerarg line="--doclint-format html5"/>
423        <compilerarg value="-Xdoclint:all/protected,reference/private"/>
424 +      <compilerarg value="-Werror"/>
425        <compilerarg line="-Xmaxerrs 1000 -Xmaxwarns 1000"/>
426        <compilerarg line="${build.args}"/>
427  
# Line 450 | Line 465
465               access="${build.javadoc.access}"
466               sourcepath="${src.dir}"
467               classpath=""
468 <             executable="${javadoc9}">
468 >             source="9"
469 >             executable="${build.main.javadoc}">
470        <fileset dir="${src.dir}" defaultexcludes="yes">
471          <include name="**/*.java"/>
472        </fileset>
473        <arg line="-Xdocrootparent ${java9.docroot.url}"/>
474        <arg line="-Xmaxerrs 1000 -Xmaxwarns 1000"/>
475        <arg value="-XDignore.symbol.file=true"/>
476 +      <arg value="-html5"/>
477        <arg value="--patch-module=java.base=${src.dir}"/>
478        <arg value="-tag"/>
479        <arg value="${javadoc.jls.option}"/>
# Line 505 | Line 522
522  
523    <target name="clean"
524            description="Removes all build products">
508
525      <delete dir="${build.dir}"/>
510
526    </target>
527  
528  
529    <target name="dist-clean"
530            description="Removes all build and distribution products">
516
531      <delete dir="${build.dir}"/>
532      <delete dir="${dist.dir}"/>
519
533    </target>
534  
535  
# Line 576 | Line 589
589  
590    <target name="test"
591            depends="tck, tck-parallelism-1, tck-parallelism-0, jtreg"
592 <          description="Runs tck and jtreg tests for src/main">
580 <  </target>
592 >          description="Runs tck and jtreg tests for src/main"/>
593  
594   <!--   <target name="jtreg8" description="Runs jtreg tests with jdk8"> -->
595  
# Line 588 | Line 600
600  
601   <!--   </target> -->
602  
603 < <!--   <target name="test89" -->
604 < <!--           description="Runs tck and jtreg tests for src/main for multiple java versions"> -->
603 >  <target name="test910"
604 >          description="Runs tck and jtreg tests for src/main for multiple java versions">
605  
606 < <!--     <antcall target="clean"/> -->
607 < <!--     <antcall target="test"> -->
608 < <!--       <param name="build.main.java.version" value="8"/> -->
609 < <!--       <param name="build.main.javac" value="${javac8}"/> -->
598 < <!--     </antcall> -->
606 >    <antcall target="clean"/>
607 >    <antcall target="test">
608 >      <param name="build.main.java.version" value="9"/>
609 >    </antcall>
610  
611 < <!--     <antcall target="clean"/> -->
612 < <!--     <antcall target="test"> -->
613 < <!--       <param name="build.main.java.version" value="9"/> -->
614 < <!--       <param name="build.main.javac" value="${javac9}"/> -->
604 < <!--     </antcall> -->
611 >    <antcall target="clean"/>
612 >    <antcall target="test">
613 >      <param name="build.main.java.version" value="10"/>
614 >    </antcall>
615  
616 < <!--   </target> -->
616 >    <!-- Clean up to avoid obscure wrong class file version bugs -->
617 >    <antcall target="clean"/>
618 >
619 >  </target>
620  
621  
622  
623    <target name="configure-compiler">
624      <fail message="ant version too old">
625 <      <condition>
613 <        <not> <antversion atleast="1.9.1"/> </not>
614 <      </condition>
625 >      <condition> <not> <antversion atleast="1.9.1"/> </not> </condition>
626      </fail>
627  
628      <property name="unchecked.option" value="-Xlint:unchecked"/>
# Line 657 | Line 668
668      <java classname="ALoops" fork="true">
669        <classpath refid="loops.classpath"/>
670      </java>
660
671    </target>
672  
673  
674    <target name="compile-test-loops" depends="jar"
675 <          description="compile all the perf tests in src/test/loops">
675 >          description="Compiles all the perf tests in src/test/loops">
676  
677      <mkdir dir="${build.dir}/test/loops"/>
678  
# Line 674 | Line 684
684             includeAntRuntime="false"
685             includeJavaRuntime="false"
686             encoding="ASCII"
687 <           executable="${javac9}"
687 >           executable="${build.main.javac}"
688             fork="true">
689  
690        <include name="*.java"/>
# Line 682 | Line 692
692        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial"/>
693        <compilerarg value="-Xbootclasspath/p:${product.jar}"/>
694        <compilerarg line="${build.args}"/>
685
695      </javac>
687
696    </target>
697  
698  
# Line 710 | Line 718
718             encoding="ASCII"
719             executable="${javac8}"
720             fork="true">
713
721        <include name="**/*.java"/>
722        <compilerarg value="-Xprefer:source"/>
723        <compilerarg value="-XDignore.symbol.file=true"/>
724        <compilerarg value="-Xlint:all"/>
725        <compilerarg value="-Werror"/>
726        <compilerarg line="${build.args}"/>
720
727      </javac>
728    </target>
729  
# Line 741 | Line 747
747             encoding="ASCII"
748             executable="${javac8}"
749             fork="true">
744
750        <include name="**/*.java"/>
751        <compilerarg value="-Xprefer:source"/>
752        <compilerarg value="-XDignore.symbol.file=true"/>
753        <compilerarg value="-Xlint:all"/>
754        <compilerarg value="-Xdoclint:all/protected,reference/private"/>
755        <compilerarg line="${build.args}"/>
751
756      </javac>
757    </target>
758  
# Line 764 | Line 768
768          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
769        </manifest>
770      </jar>
767
771    </target>
772  
773  
# Line 798 | Line 801
801  
802    <target name="4jdk8-test"
803            depends="4jdk8-tck, 4jdk8-jtreg"
804 <          description="Runs tck and jtreg tests for jsr166-4jdk8">
802 <  </target>
804 >          description="Runs tck and jtreg tests for jsr166-4jdk8"/>
805  
806  
807    <target name="4jdk8docs"
# Line 815 | Line 817
817               access="${build.javadoc.access}"
818               sourcepath="${4jdk8src.dir}:${jdk8.src.dir}"
819               classpath=""
820 +             source="8"
821               executable="${javadoc8}"
822               failonerror = "true">
823        <fileset dir="${4jdk8src.dir}" defaultexcludes="yes">
# Line 842 | Line 845
845  
846    <target name="4jdk8clean"
847            description="Removes all 4jdk8 build products">
845
848      <delete dir="${build.4jdk8.dir}"/>
847
849    </target>
850  
851  
# Line 860 | Line 861
861    </target>
862  
863  
864 +  <!-- jsr166 4jdk7 (no longer maintained) -->
865  
866 <  <!-- jsr166 4jdk7 -->
865 <
866 <  <target name="4jdk7compile"
867 <          depends="configure-compiler"
868 <          description="Compiles src/jdk7 sources, targeting jdk7">
869 <
866 >  <target name="4jdk7compile" depends="configure-compiler">
867      <mkdir dir="${build.4jdk7.classes.dir}"/>
868  
869      <javac srcdir="${4jdk7src.dir}"
# Line 890 | Line 887
887        <compilerarg value="-Xlint:all"/>
888        <compilerarg value="-Werror"/>
889        <compilerarg line="${build.args}"/>
893
890      </javac>
891    </target>
892  
893 <  <target name="4jdk7doclint"
898 <          depends="configure-compiler"
899 <          description="Finds doclint warnings">
900 <
893 >  <target name="4jdk7doclint" depends="configure-compiler">
894      <mkdir dir="${build.4jdk7.classes.dir}"/>
895  
896      <javac srcdir="${4jdk7src.dir}"
# Line 921 | Line 914
914        <compilerarg value="-Xlint:all"/>
915        <compilerarg value="-Xdoclint:all/protected"/>
916        <compilerarg line="${build.args}"/>
924
917      </javac>
918    </target>
919  
920 <
929 <  <target name="4jdk7jar"
930 <          depends="4jdk7compile"
931 <          description="Builds library jar from compiled sources">
932 <
920 >  <target name="4jdk7jar" depends="4jdk7compile">
921      <jar destfile="${4jdk7product.jar}">
922        <fileset dir="${build.4jdk7.classes.dir}"/>
923        <manifest>
# Line 937 | Line 925
925          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
926        </manifest>
927      </jar>
940
928    </target>
929  
930 <
944 <  <target name="4jdk7-tck"
945 <          depends="4jdk7jar"
946 <          description="Runs tck tests for jsr166-4jdk7 directly">
947 <
930 >  <target name="4jdk7-tck" depends="4jdk7jar">
931      <run-tck-tests
932        target="7"
933        workdir="${build.4jdk7.dir}"
# Line 967 | Line 950
950      </run-tck-tests>
951    </target>
952  
970
953    <!-- Runs tck tests for jsr166-4jdk7 via junit task (dead experiment) -->
954 <  <target name="4jdk7-tck-junit"
973 <          depends="4jdk7compile">
954 >  <target name="4jdk7-tck-junit" depends="4jdk7compile">
955  
956      <junit printsummary="true"
957             showoutput="true"
# Line 992 | Line 973
973  
974        <test name="${jsr166.tckTestClass}" haltonfailure="no">
975        </test>
995
976      </junit>
977    </target>
978  
979 <  <target name="4jdk7-jtreg"
1000 <          depends="4jdk7jar"
1001 <          description="Runs jtreg tests for jsr166-4jdk7 using the jtreg ant task">
979 >  <target name="4jdk7-jtreg" depends="4jdk7jar">
980      <run-jtreg-tests
981         target="7"
982         workdir="${build.4jdk7.dir}"
983         classes="${4jdk7product.jar}"/>
984    </target>
985  
986 +  <target name="4jdk7-test" depends="4jdk7-tck, 4jdk7-jtreg"/>
987  
988 <  <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 <
988 >  <target name="4jdk7docs">
989      <delete dir="${4jdk7docs.dir}"/>
990      <mkdir dir="${4jdk7docs.dir}"/>
991  
# Line 1035 | Line 1006
1006      </javadoc>
1007    </target>
1008  
1009 +  <target name="4jdk7dist" depends="4jdk7dist-jar, 4jdk7dist-docs"/>
1010  
1011 <  <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 <
1011 >  <target name="4jdk7clean">
1012      <delete dir="${build.4jdk7.dir}"/>
1048
1013    </target>
1014  
1015 <
1052 <  <target name="4jdk7dist-jar"
1053 <          depends="4jdk7clean, 4jdk7jar">
1015 >  <target name="4jdk7dist-jar" depends="4jdk7clean, 4jdk7jar">
1016      <copy file="${4jdk7product.jar}" todir="${dist.dir}"/>
1017    </target>
1018  
1019 <
1058 <  <target name="4jdk7dist-docs"
1059 <          depends="4jdk7clean, 4jdk7docs">
1019 >  <target name="4jdk7dist-docs" depends="4jdk7clean, 4jdk7docs">
1020      <mirror-dir src="${4jdk7docs.dir}" dst="${dist.4jdk7docs.dir}"/>
1021    </target>
1022  
1023  
1024 <  <!-- jsr166x -->
1065 <
1066 <  <target name="jsr166xcompile"
1067 <          depends="configure-compiler"
1068 <          description="Compiles jsr166x sources to build dir">
1024 >  <!-- jsr166x (no longer maintained) -->
1025  
1026 +  <target name="jsr166xcompile" depends="configure-compiler">
1027      <mkdir dir="${build.jsr166x.classes.dir}"/>
1028  
1029      <javac srcdir="${topsrc.dir}"
# Line 1083 | Line 1040
1040             encoding="ASCII"
1041             executable="${javac7}"
1042             fork="true">
1086
1043        <include name="jsr166x/**/*.java"/>
1044        <compilerarg value="-XDignore.symbol.file=true"/>
1045        <compilerarg value="-Xlint:all,-unchecked,-rawtypes"/>
1046        <compilerarg value="-Werror"/>
1047        <compilerarg line="${build.args}"/>
1092
1048      </javac>
1049    </target>
1050  
1051 <
1097 <  <target name="jsr166xjar"
1098 <          depends="jsr166xcompile"
1099 <          description="Builds library jar from compiled sources">
1100 <
1051 >  <target name="jsr166xjar" depends="jsr166xcompile">
1052      <jar destfile="${jsr166x.jar}">
1053        <fileset dir="${build.jsr166x.classes.dir}"/>
1054        <manifest>
# Line 1105 | Line 1056
1056          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1057        </manifest>
1058      </jar>
1108
1059    </target>
1060  
1061 <
1112 <  <target name="jsr166xdocs"
1113 <          description="Builds javadocs to dist dir">
1114 <
1061 >  <target name="jsr166xdocs">
1062      <delete dir="${jsr166xdocs.dir}"/>
1063      <mkdir dir="${jsr166xdocs.dir}"/>
1064  
# Line 1126 | Line 1073
1073               failonerror = "true">
1074        <arg line="-Xdocrootparent ${java.docroot.url}"/>
1075        <arg value="-XDignore.symbol.file=true"/>
1129
1076      </javadoc>
1077    </target>
1078  
1079 +  <target name="jsr166xdist" depends="jsr166xdist-jar, jsr166xdist-docs"/>
1080  
1081 <  <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 <
1081 >  <target name="jsr166xclean">
1082      <delete dir="${build.jsr166x.dir}"/>
1143
1083    </target>
1084  
1085 <
1147 <  <target name="jsr166xdist-jar"
1148 <          depends="jsr166xclean, jsr166xjar">
1085 >  <target name="jsr166xdist-jar" depends="jsr166xclean, jsr166xjar">
1086      <copy file="${jsr166x.jar}" todir="${dist.dir}"/>
1087    </target>
1088  
1089 <  <target name="jsr166xdist-docs"
1153 <          depends="jsr166xclean, jsr166xdocs">
1089 >  <target name="jsr166xdist-docs" depends="jsr166xclean, jsr166xdocs">
1090      <mirror-dir src="${jsr166xdocs.dir}" dst="${dist.jsr166xdocs.dir}"/>
1091    </target>
1092  
1157  <!-- jsr166y -->
1158
1093  
1094 <  <target name="jsr166ycompile"
1161 <          depends="configure-compiler"
1162 <          description="Compiles jsr166y sources">
1094 >  <!-- jsr166y (no longer maintained) -->
1095  
1096 +  <target name="jsr166ycompile" depends="configure-compiler">
1097      <mkdir dir="${build.jsr166y.classes.dir}"/>
1098  
1099      <javac srcdir="${topsrc.dir}"
# Line 1183 | Line 1116
1116        <compilerarg value="-Xlint:all"/>
1117        <compilerarg value="-Werror"/>
1118        <compilerarg line="${build.args}"/>
1186
1119      </javac>
1120    </target>
1121  
1122 <
1191 <  <target name="jsr166yjar"
1192 <          depends="jsr166ycompile"
1193 <          description="Builds library jar from compiled sources">
1194 <
1122 >  <target name="jsr166yjar" depends="jsr166ycompile">
1123      <jar destfile="${jsr166y.jar}" index="true">
1124        <fileset dir="${build.jsr166y.classes.dir}"/>
1125        <manifest>
# Line 1199 | Line 1127
1127          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1128        </manifest>
1129      </jar>
1202
1130    </target>
1131  
1132 <
1206 <  <target name="jsr166ydocs"
1207 <          description="Builds javadocs to dist dir">
1208 <
1132 >  <target name="jsr166ydocs">
1133      <delete dir="${jsr166ydocs.dir}"/>
1134      <mkdir dir="${jsr166ydocs.dir}"/>
1135  
# Line 1220 | Line 1144
1144               failonerror = "true">
1145        <arg line="-Xdocrootparent ${java.docroot.url}"/>
1146        <arg value="-XDignore.symbol.file=true"/>
1223
1147      </javadoc>
1148    </target>
1149  
1150 +  <target name="jsr166ydist" depends="jsr166ydist-jar, jsr166ydist-docs"/>
1151  
1152 <  <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 <
1152 >  <target name="jsr166yclean">
1153      <delete dir="${build.jsr166y.dir}"/>
1237
1154    </target>
1155  
1156 <
1241 <  <target name="jsr166ydist-jar"
1242 <          depends="jsr166yclean, jsr166yjar">
1156 >  <target name="jsr166ydist-jar" depends="jsr166yclean, jsr166yjar">
1157      <copy file="${jsr166y.jar}" todir="${dist.dir}"/>
1158    </target>
1159  
1160 <  <target name="jsr166ydist-docs"
1247 <          depends="jsr166yclean, jsr166ydocs">
1160 >  <target name="jsr166ydist-docs" depends="jsr166yclean, jsr166ydocs">
1161      <mirror-dir src="${jsr166ydocs.dir}" dst="${dist.jsr166ydocs.dir}"/>
1162    </target>
1163  
1164  
1165 <  <!-- extra166y -->
1253 <
1254 <
1255 <  <target name="extra166ycompile"
1256 <          depends="configure-compiler, jsr166yjar"
1257 <          description="Compiles extra166y sources">
1165 >  <!-- extra166y (no longer maintained) -->
1166  
1167 +  <target name="extra166ycompile" depends="configure-compiler, jsr166yjar">
1168      <mkdir dir="${build.extra166y.classes.dir}"/>
1169  
1170      <javac srcdir="${topsrc.dir}"
# Line 1278 | Line 1187
1187        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial"/>
1188        <compilerarg value="-Werror"/>
1189        <compilerarg line="${build.args}"/>
1281
1190      </javac>
1191    </target>
1192  
1193 <
1286 <  <target name="extra166yjar"
1287 <          depends="extra166ycompile"
1288 <          description="Builds library jar from compiled sources">
1289 <
1193 >  <target name="extra166yjar" depends="extra166ycompile">
1194      <jar destfile="${extra166y.jar}" index="true">
1195        <fileset dir="${build.extra166y.classes.dir}"/>
1196        <manifest>
# Line 1294 | Line 1198
1198          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1199        </manifest>
1200      </jar>
1297
1201    </target>
1202  
1203 <
1301 <  <target name="extra166ydocs"
1302 <          description="Builds javadocs to build dir">
1303 <
1203 >  <target name="extra166ydocs">
1204      <delete dir="${extra166ydocs.dir}"/>
1205      <mkdir dir="${extra166ydocs.dir}"/>
1206  
# Line 1314 | Line 1214
1214               executable="${javadoc7}">
1215        <arg line="-Xdocrootparent ${java.docroot.url}"/>
1216        <arg value="-XDignore.symbol.file=true"/>
1317
1217      </javadoc>
1218    </target>
1219  
1220 +  <target name="extra166ydist" depends="extra166ydist-jar, extra166ydist-docs"/>
1221  
1222 <  <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 <
1222 >  <target name="extra166yclean">
1223      <delete dir="${build.extra166y.dir}"/>
1331
1224    </target>
1225  
1226 <
1335 <  <target name="extra166ydist-jar"
1336 <          depends="extra166yclean, extra166yjar">
1226 >  <target name="extra166ydist-jar" depends="extra166yclean, extra166yjar">
1227      <copy file="${extra166y.jar}" todir="${dist.dir}"/>
1228    </target>
1229  
1230 <  <target name="extra166ydist-docs"
1341 <          depends="extra166yclean, extra166ydocs">
1230 >  <target name="extra166ydist-docs" depends="extra166yclean, extra166ydocs">
1231      <mirror-dir src="${extra166ydocs.dir}" dst="${dist.extra166ydocs.dir}"/>
1232    </target>
1233  
1234 <  <!-- jsr166e -->
1234 >
1235 >  <!-- jsr166e (no longer maintained) -->
1236  
1237    <property name="build.jsr166e.java.version" value="6"/>
1238    <property name="build.jsr166e.javac" value="${javac6}"/>
1239  
1240 <  <target name="jsr166ecompile"
1351 <          depends="configure-compiler"
1352 <          description="Compiles jsr166e sources">
1353 <
1240 >  <target name="jsr166ecompile" depends="configure-compiler">
1241      <mkdir dir="${build.jsr166e.classes.dir}"/>
1242  
1243      <javac srcdir="${topsrc.dir}"
# Line 1371 | Line 1258
1258        <compilerarg value="-Xlint:all"/>
1259        <compilerarg value="-Werror"/>
1260        <compilerarg line="${build.args}"/>
1374
1261      </javac>
1262    </target>
1263  
1378  <!-- jsr166e: find doclint errors -->
1264    <target name="jsr166edoclint">
1380
1265      <mkdir dir="${build.jsr166e.classes.dir}"/>
1266  
1267      <javac srcdir="${topsrc.dir}"
# Line 1399 | Line 1283
1283        <compilerarg value="-Xlint:all"/>
1284        <compilerarg value="-Werror"/>
1285        <compilerarg value="-Xdoclint:all/protected"/>
1402
1286      </javac>
1287    </target>
1288  
1289 <
1407 <  <target name="jsr166ejar"
1408 <          depends="jsr166ecompile"
1409 <          description="Builds library jar from compiled sources">
1410 <
1289 >  <target name="jsr166ejar" depends="jsr166ecompile">
1290      <jar destfile="${jsr166e.jar}" index="true">
1291        <fileset dir="${build.jsr166e.classes.dir}"/>
1292        <manifest>
# Line 1415 | Line 1294
1294          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1295        </manifest>
1296      </jar>
1418
1297    </target>
1298  
1299 <
1422 <  <target name="jsr166edocs"
1423 <          description="Builds javadocs to build dir">
1424 <
1299 >  <target name="jsr166edocs">
1300      <delete dir="${jsr166edocs.dir}"/>
1301      <mkdir dir="${jsr166edocs.dir}"/>
1302  
# Line 1435 | Line 1310
1310               failonerror = "true">
1311        <arg line="-Xdocrootparent ${java.docroot.url}"/>
1312        <arg value="-XDignore.symbol.file=true"/>
1438
1313      </javadoc>
1314    </target>
1315  
1316 <
1443 <  <target name="jsr166e-tck-one-java-version"
1444 <          depends="jsr166ejar">
1445 <
1316 >  <target name="jsr166e-tck-one-java-version" depends="jsr166ejar">
1317      <echo message="Testing with jdk${build.jsr166e.java.version} ..."/>
1447
1318      <run-tck-tests
1319        tck.src.dir="${test.src.dir}/tck-jsr166e"
1320        target="${build.jsr166e.java.version}"
# Line 1452 | Line 1322
1322        classes="${jsr166e.jar}"/>
1323    </target>
1324  
1325 <  <target name="jsr166e-tck"
1456 <          description="Runs tck tests for jsr166e for multiple java versions">
1325 >  <target name="jsr166e-tck">
1326  
1327   <!--     <antcall target="clean"/> -->
1328   <!--     <antcall target="jsr166e-tck-one-java-version"> -->
# Line 1474 | Line 1343
1343      </antcall>
1344    </target>
1345  
1346 +  <target name="jsr166e-test" depends="jsr166e-tck"/>
1347  
1348 <  <target name="jsr166e-test"
1479 <          depends="jsr166e-tck"
1480 <          description="Runs all tests for jsr166e">
1481 <  </target>
1482 <
1483 <  <target name="jsr166edist"
1484 <          depends="jsr166edist-jar, jsr166edist-docs"
1485 <          description="Puts all distributable products in single hierarchy"/>
1348 >  <target name="jsr166edist" depends="jsr166edist-jar, jsr166edist-docs"/>
1349  
1350 <
1488 <  <target name="jsr166eclean"
1489 <          description="Removes all jsr166e build products">
1350 >  <target name="jsr166eclean">
1351      <delete dir="${build.jsr166e.dir}"/>
1352    </target>
1353  
1493
1354    <target name="jsr166edist-jar"
1355            depends="jsr166eclean, jsr166ejar">
1356      <copy file="${jsr166e.jar}" todir="${dist.dir}"/>
1357    </target>
1358  
1359 <  <target name="jsr166edist-docs"
1500 <          depends="jsr166eclean, jsr166edocs">
1359 >  <target name="jsr166edist-docs" depends="jsr166eclean, jsr166edocs">
1360      <mirror-dir src="${jsr166edocs.dir}" dst="${dist.jsr166edocs.dir}"/>
1361    </target>
1362  
# Line 1520 | Line 1379
1379  
1380   <!-- ==============================================================
1381    Experimental errorprone support - http://errorprone.info
1523  You may need to bring your own errorprone jar.
1382   =================================================================== -->
1383 +  <property name="errorprone.jar" location="${lib.dir}/error_prone_ant-2.0.21.jar"/>
1384    <target name="errorprone"
1385            depends="clean, configure-compiler"
1386 <          description="Run errorprone over jsr166 source code">
1386 >          description="Run errorprone over jsr166 source code (experimental)">
1387  
1388      <local name="destdir"/>
1389      <property name="destdir" value="${build.classes.dir}/java.base"/>
# Line 1543 | Line 1402
1402             fork="true">
1403  
1404        <include name="**/*.java"/>
1405 <      <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"/>
1405 >      <compilerarg line="-processorpath ${errorprone.jar}"/>
1406        <compilerarg value="-Xplugin:ErrorProne
1407 <                          -Xep:IdentityBinaryExpression:WARN
1407 >                          -Xep:IdentityBinaryExpression:WARN
1408                            -Xep:MissingOverride:OFF
1409 <                          -Xep:MixedArrayDimensions:WARN
1410 <                          -Xep:RemoveUnusedImports:ERROR
1409 >                          -Xep:MixedArrayDimensions:WARN
1410 >                          -Xep:RemoveUnusedImports:ERROR
1411 >                          -Xep:ClassName:ERROR
1412 >                          -Xep:MultipleTopLevelClasses:ERROR
1413 >                          -Xep:EmptyIf:ERROR
1414 >                          -Xep:LongLiteralLowerCaseSuffix:ERROR
1415 >                          -Xep:RedundantThrows:ERROR
1416                            -Xep:MethodCanBeStatic:WARN"/>
1417        <compilerarg value="--patch-module=java.base=${src.dir}"/>
1418        <compilerarg value="-Xprefer:source"/>
# Line 1577 | Line 1432
1432        workdir="${build.dir}"
1433        classes="${product.jar}">
1434        <javac-elements>
1435 <        <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.api=ALL-UNNAMED"/>
1436 <        <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.util=ALL-UNNAMED"/>
1437 <        <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.tree=ALL-UNNAMED"/>
1438 <        <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.main=ALL-UNNAMED"/>
1439 <        <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.code=ALL-UNNAMED"/>
1440 <        <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.processing=ALL-UNNAMED"/>
1441 <        <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.parser=ALL-UNNAMED"/>
1442 <        <compilerarg value="-J--add-exports=jdk.compiler/com.sun.tools.javac.comp=ALL-UNNAMED"/>
1443 <        <compilerarg value="-J--add-opens=jdk.compiler/com.sun.tools.javac.comp=ALL-UNNAMED"/>
1444 <        <compilerarg line="-processorpath ${lib.dir}/error_prone_ant-2.0.20-SNAPSHOT.jar"/>
1445 <        <compilerarg value="-Xplugin:ErrorProne
1446 <                            -Xep:IdentityBinaryExpression:WARN
1447 <                            -Xep:BoxedPrimitiveConstructor:OFF
1448 <                            -Xep:HashtableContains:OFF
1594 <                            -Xep:ModifyingCollectionWithItself:OFF
1595 <                            -Xep:MissingOverride:OFF
1596 <                            -Xep:MixedArrayDimensions:WARN
1597 <                            -Xep:RemoveUnusedImports:ERROR
1435 >        <compilerarg line="-processorpath ${errorprone.jar}"/>
1436 >        <compilerarg value="-Xplugin:ErrorProne
1437 >                            -Xep:IdentityBinaryExpression:WARN
1438 >                            -Xep:BoxedPrimitiveConstructor:OFF
1439 >                            -Xep:HashtableContains:OFF
1440 >                            -Xep:ModifyingCollectionWithItself:OFF
1441 >                            -Xep:MissingOverride:OFF
1442 >                            -Xep:MixedArrayDimensions:WARN
1443 >                            -Xep:RemoveUnusedImports:ERROR
1444 >                            -Xep:ClassName:ERROR
1445 >                            -Xep:MultipleTopLevelClasses:ERROR
1446 >                            -Xep:EmptyIf:ERROR
1447 >                            -Xep:LongLiteralLowerCaseSuffix:ERROR
1448 >                            -Xep:RedundantThrows:ERROR
1449                              -Xep:MethodCanBeStatic:WARN"/>
1450          <compilerarg line="-Xmaxerrs 3000 -Xmaxwarns 3000"/>
1451        </javac-elements>
1452      </run-tck-tests>
1453    </target>
1454  
1455 +  <!-- ant errorprone-jtreg |& grep -EA1 '(warning|error):' -->
1456 +  <target name="errorprone-jtreg"
1457 +          depends="jar"
1458 +          description="Run errorprone over jtreg tests (experimental)">
1459 +
1460 +    <run-jtreg-tests
1461 +       target="${build.main.java.version}"
1462 +       workdir="${build.dir}"
1463 +       classes="${product.jar}"
1464 +       verbose="all">
1465 +      <jtreg-elements>
1466 +        <arg value="-javacoption:-processorpath"/>
1467 +        <arg value="-javacoption:${errorprone.jar}"/>
1468 +        <arg value="-javacoption:-Xplugin:ErrorProne
1469 +                            -Xep:IdentityBinaryExpression:WARN
1470 +                            -Xep:BoxedPrimitiveConstructor:OFF
1471 +                            -Xep:HashtableContains:OFF
1472 +                            -Xep:ModifyingCollectionWithItself:OFF
1473 +                            -Xep:MissingOverride:OFF
1474 +                            -Xep:MixedArrayDimensions:WARN
1475 +                            -Xep:RemoveUnusedImports:ERROR
1476 +                            -Xep:ClassName:ERROR
1477 +                            -Xep:MultipleTopLevelClasses:ERROR
1478 +                            -Xep:EmptyIf:ERROR
1479 +                            -Xep:LongLiteralLowerCaseSuffix:ERROR
1480 +                            -Xep:RedundantThrows:ERROR
1481 +                            -Xep:MethodCanBeStatic:WARN"/>
1482 +      </jtreg-elements>
1483 +    </run-jtreg-tests>
1484 +  </target>
1485 +
1486  
1487   <!-- ==============================================================
1488    Running guava tests against jsr166 code
# Line 1654 | Line 1536
1536      <get src="http://repo2.maven.org/maven2/com/google/guava/guava-testlib/${guava.version}/guava-testlib-${guava.version}-tests.jar"
1537           dest="${guava.dir}/guava-testlib-tests.jar" usetimestamp="true"/>
1538      <junit printsummary="true" showoutput="true" haltonfailure="true"
1539 <           jvm="${java9}" fork="true">
1540 <      <jvmarg line="-ea -esa --patch-module java.base=${product.jar}"/>
1539 >           jvm="${build.main.java}" fork="true">
1540 >      <jvmarg line="-ea -esa --patch-module=java.base=${product.jar}"/>
1541        <formatter type="brief"/>
1542        <classpath>
1543          <pathelement location="${guava.dir}/guava-testlib-tests.jar"/>

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines