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.234 by jsr166, Sat Feb 18 18:33:42 2017 UTC vs.
Revision 1.259 by jsr166, Mon Dec 18 21:07:18 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 >  <!-- Switched to https: in 2017-10 - JDK-8190312 -->
185 >  <property name="java5.docroot.url"  value="https://docs.oracle.com/javase/1.5.0/docs"/>
186 >  <property name="java6.docroot.url"  value="https://docs.oracle.com/javase/6/docs"/>
187 >  <property name="java7.docroot.url"  value="https://docs.oracle.com/javase/7/docs"/>
188 >  <property name="java8.docroot.url"  value="https://docs.oracle.com/javase/8/docs"/>
189 >  <property name="java9.docroot.url"  value="https://docs.oracle.com/javase/9/docs"/>
190 >  <!-- The location of jdk9 early access docs (RIP) -->
191 >  <!-- <property name="java9.docroot.url" value="http://download.java.net/java/jdk9/docs"/> -->
192    <!-- Default jdk doc location (latest stable release seems best) -->
193 <  <property name="java.docroot.url"       value="${java8.docroot.url}"/>
193 >  <property name="java10.docroot.url" value="http://download.java.net/java/jdk10/docs"/>
194 >  <property name="java.docroot.url"   value="${java9.docroot.url}"/>
195  
196    <!-- Canonical location of jdk API docs, to use with javadoc link attribute -->
197    <property name="java5.api.url"      value="${java5.docroot.url}/api/"/>
# Line 199 | Line 199
199    <property name="java7.api.url"      value="${java7.docroot.url}/api/"/>
200    <property name="java8.api.url"      value="${java8.docroot.url}/api/"/>
201    <property name="java9.api.url"      value="${java9.docroot.url}/api/"/>
202 +  <property name="java10.api.url"     value="${java10.docroot.url}/api/"/>
203    <property name="java.api.url"       value="${java.docroot.url}/api/"/>
204  
205    <!-- Define the "jtreg" task -->
# Line 234 | Line 235
235        <available file="${jdk@{compile-target}.home}/jmods" type="dir"/>
236      </condition>
237  
238 +    <local name="use-doclint"/>
239 +    <condition property="use-doclint">
240 +      <not> <equals arg1="@{target}" arg2="7"/> </not>
241 +    </condition>
242 +
243      <mkdir dir="@{workdir}/tck-classes"/>
244  
245      <javac srcdir="@{tck.src.dir}"
# Line 253 | Line 259
259        <include name="*.java"/>
260        <compilerarg value="-XDignore.symbol.file=true"/>
261        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation,-try"/>
262 +      <compilerarg value="-Xdoclint:reference/private" if:set="use-doclint"/>
263        <compilerarg value="-Xbootclasspath/p:@{classes}" unless:set="modules"/>
264        <compilerarg value="--patch-module=java.base=@{classes}" if:set="modules"/>
265        <compilerarg line="${build.args}"/>
# Line 292 | Line 299
299    </macrodef>
300  
301    <!-- Define jtreg test sets for different jdk versions -->
302 +  <fileset dir="${jtreg10.src.dir}">
303 +    <patternset id="jdk10.jtreg.tests">
304 +      <include name="**/*.java"/>
305 +    </patternset>
306 +  </fileset>
307 +
308    <fileset dir="${jtreg9.src.dir}">
309      <patternset id="jdk9.jtreg.tests">
310        <include name="**/*.java"/>
# Line 315 | Line 328
328  
329    <macrodef name="run-jtreg-tests">
330      <!-- ant -Djtreg9.src.dir=src/test/jtreg/util/concurrent/CompletableFuture jtreg -->
318    <attribute name="source" default="7"/>
331      <attribute name="target"/>
332      <attribute name="workdir"/>
333      <attribute name="classes"/>
334 +    <attribute name="verbose" default="${jtreg.verbose}"/>
335      <attribute name="jtregflags" default=""/>
336 +    <element name="jtreg-elements" optional="true"/>
337  
338      <sequential>
339  
# Line 337 | Line 351
351             workDir="@{workdir}/JTwork">
352        <patternset refid="jdk@{target}.jtreg.tests"/>
353        <arg value="-Xbootclasspath/p:@{classes}" unless:set="modules"/>
354 <      <arg value="-javacoptions:--patch-module java.base=@{classes}" if:set="modules"/>
355 <      <arg value="-vmoptions:--patch-module java.base=@{classes}" if:set="modules"/>
354 >      <arg value="-javacoptions:--patch-module=java.base=@{classes}" if:set="modules"/>
355 >      <arg value="-vmoptions:--patch-module=java.base=@{classes}" if:set="modules"/>
356        <arg value="-agentvm"/>
357        <arg value="-noreport"/>
358 <      <arg value="-verbose:${jtreg.verbose}"/>
358 >      <arg value="-verbose:@{verbose}"/>
359        <arg value="-vmoptions:-esa -ea"/>
360        <arg value="-automatic"/>
361        <arg value="-k:!ignore"/>
362        <arg line="@{jtregflags}"/>
363        <arg line="${jtreg.flags}"/>
364 +      <jtreg-elements/>
365      </jtreg>
366      </sequential>
367    </macrodef>
# Line 363 | Line 378
378    <!-- Main targets -->
379  
380    <property name="build.main.java.version" value="9"/>
381 <  <property name="build.main.javac" value="${javac9}"/>
381 >  <!-- Workaround "no nested properties in ant" -->
382 >  <macrodef name="define-build-main-properties">
383 >    <attribute name="v"/>
384 >    <sequential>
385 >      <property name="build.main.java"    value="${java@{v}}"/>
386 >      <property name="build.main.javac"   value="${javac@{v}}"/>
387 >      <property name="build.main.javadoc" value="${javadoc@{v}}"/>
388 >    </sequential>
389 >  </macrodef>
390 >  <define-build-main-properties v="${build.main.java.version}"/>
391  
392    <target name="dists"
393 <          depends="dist, 4jdk8dist, 4jdk7dist, jsr166edist, jsr166ydist, extra166ydist, jsr166xdist"
393 >          depends="dist, 4jdk8dist"
394            description="Builds all public jars and docs"/>
395 +          <!--
396 +              depends="dist, 4jdk8dist, 4jdk7dist, jsr166edist, jsr166ydist, extra166ydist, jsr166xdist"
397 +          -->
398  
399    <target name="compile"
400            depends="configure-compiler"
401            description="Compiles src/main sources to build dir">
402  
376    <local name="modules"/>
377    <condition property="modules">
378      <and>
379        <available file="${jdk9.home}/jmods" type="dir"/>
380        <equals arg1="9" arg2="${build.main.java.version}"/>
381      </and>
382    </condition>
383
403      <local name="destdir"/>
404 <    <property name="destdir" value="${build.classes.dir}/java.base" if:set="modules"/>
386 <    <property name="destdir" value="${build.classes.dir}" unless:set="modules"/>
404 >    <property name="destdir" value="${build.classes.dir}/java.base"/>
405  
406      <mkdir dir="${destdir}"/>
407  
# Line 400 | Line 418
418             fork="true">
419  
420        <include name="**/*.java"/>
421 <      <compilerarg value="--patch-module=java.base=${src.dir}" if:set="modules"/>
421 >      <compilerarg value="--patch-module=java.base=${src.dir}"/>
422        <compilerarg value="-Xprefer:source"/>
423        <compilerarg value="-XDignore.symbol.file=true"/>
424        <compilerarg value="-Xlint:all"/>
425 +      <compilerarg line="--doclint-format html5"/>
426 +      <compilerarg value="-Xdoclint:all/protected,reference/private"/>
427        <compilerarg value="-Werror"/>
408      <compilerarg value="-Xdoclint:all/protected"/>
428        <compilerarg line="-Xmaxerrs 1000 -Xmaxwarns 1000"/>
429        <compilerarg line="${build.args}"/>
430  
# Line 449 | Line 468
468               access="${build.javadoc.access}"
469               sourcepath="${src.dir}"
470               classpath=""
471 <             executable="${javadoc9}">
471 >             source="9"
472 >             executable="${build.main.javadoc}">
473        <fileset dir="${src.dir}" defaultexcludes="yes">
474          <include name="**/*.java"/>
475        </fileset>
476        <arg line="-Xdocrootparent ${java9.docroot.url}"/>
477        <arg line="-Xmaxerrs 1000 -Xmaxwarns 1000"/>
478        <arg value="-XDignore.symbol.file=true"/>
479 +      <arg value="-html5"/>
480        <arg value="--patch-module=java.base=${src.dir}"/>
481        <arg value="-tag"/>
482        <arg value="${javadoc.jls.option}"/>
# Line 504 | Line 525
525  
526    <target name="clean"
527            description="Removes all build products">
507
528      <delete dir="${build.dir}"/>
509
529    </target>
530  
531  
532    <target name="dist-clean"
533            description="Removes all build and distribution products">
515
534      <delete dir="${build.dir}"/>
535      <delete dir="${dist.dir}"/>
518
536    </target>
537  
538  
# Line 536 | Line 553
553      <run-tck-tests
554        target="${build.main.java.version}"
555        workdir="${build.dir}"
556 <      classes="${product.jar}"/>
556 >      classes="${product.jar}">
557 >      <javac-elements>
558 >        <compilerarg value="-Werror"/>
559 >      </javac-elements>
560 >    </run-tck-tests>
561    </target>
562  
563    <target name="tck-parallelism-1"
# Line 571 | Line 592
592  
593    <target name="test"
594            depends="tck, tck-parallelism-1, tck-parallelism-0, jtreg"
595 <          description="Runs tck and jtreg tests for src/main">
575 <  </target>
595 >          description="Runs tck and jtreg tests for src/main"/>
596  
597   <!--   <target name="jtreg8" description="Runs jtreg tests with jdk8"> -->
598  
# Line 583 | Line 603
603  
604   <!--   </target> -->
605  
606 < <!--   <target name="test89" -->
607 < <!--           description="Runs tck and jtreg tests for src/main for multiple java versions"> -->
606 >  <target name="test910"
607 >          description="Runs tck and jtreg tests for src/main for multiple java versions">
608  
609 < <!--     <antcall target="clean"/> -->
610 < <!--     <antcall target="test"> -->
611 < <!--       <param name="build.main.java.version" value="8"/> -->
612 < <!--       <param name="build.main.javac" value="${javac8}"/> -->
593 < <!--     </antcall> -->
609 >    <antcall target="clean"/>
610 >    <antcall target="test">
611 >      <param name="build.main.java.version" value="9"/>
612 >    </antcall>
613  
614 < <!--     <antcall target="clean"/> -->
615 < <!--     <antcall target="test"> -->
616 < <!--       <param name="build.main.java.version" value="9"/> -->
617 < <!--       <param name="build.main.javac" value="${javac9}"/> -->
599 < <!--     </antcall> -->
614 >    <antcall target="clean"/>
615 >    <antcall target="test">
616 >      <param name="build.main.java.version" value="10"/>
617 >    </antcall>
618  
619 < <!--   </target> -->
619 >    <!-- Clean up to avoid obscure wrong class file version bugs -->
620 >    <antcall target="clean"/>
621 >
622 >  </target>
623  
624  
625  
626    <target name="configure-compiler">
627      <fail message="ant version too old">
628 <      <condition>
608 <        <not> <antversion atleast="1.9.1"/> </not>
609 <      </condition>
628 >      <condition> <not> <antversion atleast="1.9.1"/> </not> </condition>
629      </fail>
630  
631      <property name="unchecked.option" value="-Xlint:unchecked"/>
# Line 652 | Line 671
671      <java classname="ALoops" fork="true">
672        <classpath refid="loops.classpath"/>
673      </java>
655
674    </target>
675  
676  
677    <target name="compile-test-loops" depends="jar"
678 <          description="compile all the perf tests in src/test/loops">
678 >          description="Compiles all the perf tests in src/test/loops">
679  
680      <mkdir dir="${build.dir}/test/loops"/>
681  
# Line 669 | Line 687
687             includeAntRuntime="false"
688             includeJavaRuntime="false"
689             encoding="ASCII"
690 <           executable="${javac9}"
690 >           executable="${build.main.javac}"
691             fork="true">
692  
693        <include name="*.java"/>
# Line 677 | Line 695
695        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial"/>
696        <compilerarg value="-Xbootclasspath/p:${product.jar}"/>
697        <compilerarg line="${build.args}"/>
680
698      </javac>
682
699    </target>
700  
701  
# Line 705 | Line 721
721             encoding="ASCII"
722             executable="${javac8}"
723             fork="true">
708
724        <include name="**/*.java"/>
725        <compilerarg value="-Xprefer:source"/>
726        <compilerarg value="-XDignore.symbol.file=true"/>
727        <compilerarg value="-Xlint:all"/>
728        <compilerarg value="-Werror"/>
729        <compilerarg line="${build.args}"/>
715
730      </javac>
731    </target>
732  
# Line 736 | Line 750
750             encoding="ASCII"
751             executable="${javac8}"
752             fork="true">
739
753        <include name="**/*.java"/>
754        <compilerarg value="-Xprefer:source"/>
755        <compilerarg value="-XDignore.symbol.file=true"/>
756        <compilerarg value="-Xlint:all"/>
757 <      <compilerarg value="-Xdoclint:all/protected"/>
757 >      <compilerarg value="-Xdoclint:all/protected,reference/private"/>
758        <compilerarg line="${build.args}"/>
746
759      </javac>
760    </target>
761  
# Line 759 | Line 771
771          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
772        </manifest>
773      </jar>
762
774    </target>
775  
776  
# Line 775 | Line 786
786          <!-- JDK9+ test classes -->
787          <exclude name="*9Test.java"/>
788          <exclude name="*10Test.java"/>
789 +        <compilerarg value="-Werror"/>
790        </javac-elements>
791      </run-tck-tests>
792    </target>
# Line 792 | Line 804
804  
805    <target name="4jdk8-test"
806            depends="4jdk8-tck, 4jdk8-jtreg"
807 <          description="Runs tck and jtreg tests for jsr166-4jdk8">
796 <  </target>
807 >          description="Runs tck and jtreg tests for jsr166-4jdk8"/>
808  
809  
810    <target name="4jdk8docs"
# Line 809 | Line 820
820               access="${build.javadoc.access}"
821               sourcepath="${4jdk8src.dir}:${jdk8.src.dir}"
822               classpath=""
823 +             source="8"
824               executable="${javadoc8}"
825               failonerror = "true">
826        <fileset dir="${4jdk8src.dir}" defaultexcludes="yes">
# Line 836 | Line 848
848  
849    <target name="4jdk8clean"
850            description="Removes all 4jdk8 build products">
839
851      <delete dir="${build.4jdk8.dir}"/>
841
852    </target>
853  
854  
# Line 854 | Line 864
864    </target>
865  
866  
867 +  <!-- jsr166 4jdk7 (no longer maintained) -->
868  
869 <  <!-- jsr166 4jdk7 -->
859 <
860 <  <target name="4jdk7compile"
861 <          depends="configure-compiler"
862 <          description="Compiles src/jdk7 sources, targeting jdk7">
863 <
869 >  <target name="4jdk7compile" depends="configure-compiler">
870      <mkdir dir="${build.4jdk7.classes.dir}"/>
871  
872      <javac srcdir="${4jdk7src.dir}"
# Line 884 | Line 890
890        <compilerarg value="-Xlint:all"/>
891        <compilerarg value="-Werror"/>
892        <compilerarg line="${build.args}"/>
887
893      </javac>
894    </target>
895  
896 <  <target name="4jdk7doclint"
892 <          depends="configure-compiler"
893 <          description="Finds doclint warnings">
894 <
896 >  <target name="4jdk7doclint" depends="configure-compiler">
897      <mkdir dir="${build.4jdk7.classes.dir}"/>
898  
899      <javac srcdir="${4jdk7src.dir}"
# Line 915 | Line 917
917        <compilerarg value="-Xlint:all"/>
918        <compilerarg value="-Xdoclint:all/protected"/>
919        <compilerarg line="${build.args}"/>
918
920      </javac>
921    </target>
922  
923 <
923 <  <target name="4jdk7jar"
924 <          depends="4jdk7compile"
925 <          description="Builds library jar from compiled sources">
926 <
923 >  <target name="4jdk7jar" depends="4jdk7compile">
924      <jar destfile="${4jdk7product.jar}">
925        <fileset dir="${build.4jdk7.classes.dir}"/>
926        <manifest>
# Line 931 | Line 928
928          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
929        </manifest>
930      </jar>
934
931    </target>
932  
933 <
938 <  <target name="4jdk7-tck"
939 <          depends="4jdk7jar"
940 <          description="Runs tck tests for jsr166-4jdk7 directly">
941 <
933 >  <target name="4jdk7-tck" depends="4jdk7jar">
934      <run-tck-tests
935        target="7"
936        workdir="${build.4jdk7.dir}"
# Line 956 | Line 948
948          <exclude name="SplittableRandomTest.java"/>
949          <exclude name="StampedLockTest.java"/>
950          <exclude name="SubmissionPublisherTest.java"/>
951 +        <compilerarg value="-Werror"/>
952        </javac-elements>
953      </run-tck-tests>
954    </target>
955  
963
956    <!-- Runs tck tests for jsr166-4jdk7 via junit task (dead experiment) -->
957 <  <target name="4jdk7-tck-junit"
966 <          depends="4jdk7compile">
957 >  <target name="4jdk7-tck-junit" depends="4jdk7compile">
958  
959      <junit printsummary="true"
960             showoutput="true"
# Line 985 | Line 976
976  
977        <test name="${jsr166.tckTestClass}" haltonfailure="no">
978        </test>
988
979      </junit>
980    </target>
981  
982 <  <target name="4jdk7-jtreg"
993 <          depends="4jdk7jar"
994 <          description="Runs jtreg tests for jsr166-4jdk7 using the jtreg ant task">
982 >  <target name="4jdk7-jtreg" depends="4jdk7jar">
983      <run-jtreg-tests
984         target="7"
985         workdir="${build.4jdk7.dir}"
986         classes="${4jdk7product.jar}"/>
987    </target>
988  
989 +  <target name="4jdk7-test" depends="4jdk7-tck, 4jdk7-jtreg"/>
990  
991 <  <target name="4jdk7-test"
1003 <          depends="4jdk7-tck, 4jdk7-jtreg"
1004 <          description="Runs tck and jtreg tests for jsr166-4jdk7">
1005 <  </target>
1006 <
1007 <
1008 <  <target name="4jdk7docs"
1009 <          description="Builds javadocs for src/jdk7 to dist dir">
1010 <
991 >  <target name="4jdk7docs">
992      <delete dir="${4jdk7docs.dir}"/>
993      <mkdir dir="${4jdk7docs.dir}"/>
994  
# Line 1028 | Line 1009
1009      </javadoc>
1010    </target>
1011  
1012 +  <target name="4jdk7dist" depends="4jdk7dist-jar, 4jdk7dist-docs"/>
1013  
1014 <  <target name="4jdk7dist"
1033 <          depends="4jdk7dist-jar, 4jdk7dist-docs"
1034 <          description="Puts all distributable products in single hierarchy"/>
1035 <
1036 <
1037 <  <target name="4jdk7clean"
1038 <          description="Removes all 4jdk7 build products">
1039 <
1014 >  <target name="4jdk7clean">
1015      <delete dir="${build.4jdk7.dir}"/>
1041
1016    </target>
1017  
1018 <
1045 <  <target name="4jdk7dist-jar"
1046 <          depends="4jdk7clean, 4jdk7jar">
1018 >  <target name="4jdk7dist-jar" depends="4jdk7clean, 4jdk7jar">
1019      <copy file="${4jdk7product.jar}" todir="${dist.dir}"/>
1020    </target>
1021  
1022 <
1051 <  <target name="4jdk7dist-docs"
1052 <          depends="4jdk7clean, 4jdk7docs">
1022 >  <target name="4jdk7dist-docs" depends="4jdk7clean, 4jdk7docs">
1023      <mirror-dir src="${4jdk7docs.dir}" dst="${dist.4jdk7docs.dir}"/>
1024    </target>
1025  
1026  
1027 <  <!-- jsr166x -->
1058 <
1059 <  <target name="jsr166xcompile"
1060 <          depends="configure-compiler"
1061 <          description="Compiles jsr166x sources to build dir">
1027 >  <!-- jsr166x (no longer maintained) -->
1028  
1029 +  <target name="jsr166xcompile" depends="configure-compiler">
1030      <mkdir dir="${build.jsr166x.classes.dir}"/>
1031  
1032      <javac srcdir="${topsrc.dir}"
# Line 1076 | Line 1043
1043             encoding="ASCII"
1044             executable="${javac7}"
1045             fork="true">
1079
1046        <include name="jsr166x/**/*.java"/>
1047        <compilerarg value="-XDignore.symbol.file=true"/>
1048        <compilerarg value="-Xlint:all,-unchecked,-rawtypes"/>
1049        <compilerarg value="-Werror"/>
1050        <compilerarg line="${build.args}"/>
1085
1051      </javac>
1052    </target>
1053  
1054 <
1090 <  <target name="jsr166xjar"
1091 <          depends="jsr166xcompile"
1092 <          description="Builds library jar from compiled sources">
1093 <
1054 >  <target name="jsr166xjar" depends="jsr166xcompile">
1055      <jar destfile="${jsr166x.jar}">
1056        <fileset dir="${build.jsr166x.classes.dir}"/>
1057        <manifest>
# Line 1098 | Line 1059
1059          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1060        </manifest>
1061      </jar>
1101
1062    </target>
1063  
1064 <
1105 <  <target name="jsr166xdocs"
1106 <          description="Builds javadocs to dist dir">
1107 <
1064 >  <target name="jsr166xdocs">
1065      <delete dir="${jsr166xdocs.dir}"/>
1066      <mkdir dir="${jsr166xdocs.dir}"/>
1067  
# Line 1119 | Line 1076
1076               failonerror = "true">
1077        <arg line="-Xdocrootparent ${java.docroot.url}"/>
1078        <arg value="-XDignore.symbol.file=true"/>
1122
1079      </javadoc>
1080    </target>
1081  
1082 +  <target name="jsr166xdist" depends="jsr166xdist-jar, jsr166xdist-docs"/>
1083  
1084 <  <target name="jsr166xdist"
1128 <          depends="jsr166xdist-jar, jsr166xdist-docs"
1129 <          description="Puts all distributable products in single hierarchy"/>
1130 <
1131 <
1132 <  <target name="jsr166xclean"
1133 <          description="Removes all jsr166x build products">
1134 <
1084 >  <target name="jsr166xclean">
1085      <delete dir="${build.jsr166x.dir}"/>
1136
1086    </target>
1087  
1088 <
1140 <  <target name="jsr166xdist-jar"
1141 <          depends="jsr166xclean, jsr166xjar">
1088 >  <target name="jsr166xdist-jar" depends="jsr166xclean, jsr166xjar">
1089      <copy file="${jsr166x.jar}" todir="${dist.dir}"/>
1090    </target>
1091  
1092 <  <target name="jsr166xdist-docs"
1146 <          depends="jsr166xclean, jsr166xdocs">
1092 >  <target name="jsr166xdist-docs" depends="jsr166xclean, jsr166xdocs">
1093      <mirror-dir src="${jsr166xdocs.dir}" dst="${dist.jsr166xdocs.dir}"/>
1094    </target>
1095  
1150  <!-- jsr166y -->
1151
1096  
1097 <  <target name="jsr166ycompile"
1154 <          depends="configure-compiler"
1155 <          description="Compiles jsr166y sources">
1097 >  <!-- jsr166y (no longer maintained) -->
1098  
1099 +  <target name="jsr166ycompile" depends="configure-compiler">
1100      <mkdir dir="${build.jsr166y.classes.dir}"/>
1101  
1102      <javac srcdir="${topsrc.dir}"
# Line 1176 | Line 1119
1119        <compilerarg value="-Xlint:all"/>
1120        <compilerarg value="-Werror"/>
1121        <compilerarg line="${build.args}"/>
1179
1122      </javac>
1123    </target>
1124  
1125 <
1184 <  <target name="jsr166yjar"
1185 <          depends="jsr166ycompile"
1186 <          description="Builds library jar from compiled sources">
1187 <
1125 >  <target name="jsr166yjar" depends="jsr166ycompile">
1126      <jar destfile="${jsr166y.jar}" index="true">
1127        <fileset dir="${build.jsr166y.classes.dir}"/>
1128        <manifest>
# Line 1192 | Line 1130
1130          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1131        </manifest>
1132      </jar>
1195
1133    </target>
1134  
1135 <
1199 <  <target name="jsr166ydocs"
1200 <          description="Builds javadocs to dist dir">
1201 <
1135 >  <target name="jsr166ydocs">
1136      <delete dir="${jsr166ydocs.dir}"/>
1137      <mkdir dir="${jsr166ydocs.dir}"/>
1138  
# Line 1213 | Line 1147
1147               failonerror = "true">
1148        <arg line="-Xdocrootparent ${java.docroot.url}"/>
1149        <arg value="-XDignore.symbol.file=true"/>
1216
1150      </javadoc>
1151    </target>
1152  
1153 +  <target name="jsr166ydist" depends="jsr166ydist-jar, jsr166ydist-docs"/>
1154  
1155 <  <target name="jsr166ydist"
1222 <          depends="jsr166ydist-jar, jsr166ydist-docs"
1223 <          description="Puts all distributable products in single hierarchy"/>
1224 <
1225 <
1226 <  <target name="jsr166yclean"
1227 <          description="Removes all jsr166y build products">
1228 <
1155 >  <target name="jsr166yclean">
1156      <delete dir="${build.jsr166y.dir}"/>
1230
1157    </target>
1158  
1159 <
1234 <  <target name="jsr166ydist-jar"
1235 <          depends="jsr166yclean, jsr166yjar">
1159 >  <target name="jsr166ydist-jar" depends="jsr166yclean, jsr166yjar">
1160      <copy file="${jsr166y.jar}" todir="${dist.dir}"/>
1161    </target>
1162  
1163 <  <target name="jsr166ydist-docs"
1240 <          depends="jsr166yclean, jsr166ydocs">
1163 >  <target name="jsr166ydist-docs" depends="jsr166yclean, jsr166ydocs">
1164      <mirror-dir src="${jsr166ydocs.dir}" dst="${dist.jsr166ydocs.dir}"/>
1165    </target>
1166  
1167  
1168 <  <!-- extra166y -->
1246 <
1247 <
1248 <  <target name="extra166ycompile"
1249 <          depends="configure-compiler, jsr166yjar"
1250 <          description="Compiles extra166y sources">
1168 >  <!-- extra166y (no longer maintained) -->
1169  
1170 +  <target name="extra166ycompile" depends="configure-compiler, jsr166yjar">
1171      <mkdir dir="${build.extra166y.classes.dir}"/>
1172  
1173      <javac srcdir="${topsrc.dir}"
# Line 1271 | Line 1190
1190        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial"/>
1191        <compilerarg value="-Werror"/>
1192        <compilerarg line="${build.args}"/>
1274
1193      </javac>
1194    </target>
1195  
1196 <
1279 <  <target name="extra166yjar"
1280 <          depends="extra166ycompile"
1281 <          description="Builds library jar from compiled sources">
1282 <
1196 >  <target name="extra166yjar" depends="extra166ycompile">
1197      <jar destfile="${extra166y.jar}" index="true">
1198        <fileset dir="${build.extra166y.classes.dir}"/>
1199        <manifest>
# Line 1287 | Line 1201
1201          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1202        </manifest>
1203      </jar>
1290
1204    </target>
1205  
1206 <
1294 <  <target name="extra166ydocs"
1295 <          description="Builds javadocs to build dir">
1296 <
1206 >  <target name="extra166ydocs">
1207      <delete dir="${extra166ydocs.dir}"/>
1208      <mkdir dir="${extra166ydocs.dir}"/>
1209  
# Line 1307 | Line 1217
1217               executable="${javadoc7}">
1218        <arg line="-Xdocrootparent ${java.docroot.url}"/>
1219        <arg value="-XDignore.symbol.file=true"/>
1310
1220      </javadoc>
1221    </target>
1222  
1223 +  <target name="extra166ydist" depends="extra166ydist-jar, extra166ydist-docs"/>
1224  
1225 <  <target name="extra166ydist"
1316 <          depends="extra166ydist-jar, extra166ydist-docs"
1317 <          description="Puts all distributable products in single hierarchy"/>
1318 <
1319 <
1320 <  <target name="extra166yclean"
1321 <          description="Removes all extra166y build products">
1322 <
1225 >  <target name="extra166yclean">
1226      <delete dir="${build.extra166y.dir}"/>
1324
1227    </target>
1228  
1229 <
1328 <  <target name="extra166ydist-jar"
1329 <          depends="extra166yclean, extra166yjar">
1229 >  <target name="extra166ydist-jar" depends="extra166yclean, extra166yjar">
1230      <copy file="${extra166y.jar}" todir="${dist.dir}"/>
1231    </target>
1232  
1233 <  <target name="extra166ydist-docs"
1334 <          depends="extra166yclean, extra166ydocs">
1233 >  <target name="extra166ydist-docs" depends="extra166yclean, extra166ydocs">
1234      <mirror-dir src="${extra166ydocs.dir}" dst="${dist.extra166ydocs.dir}"/>
1235    </target>
1236  
1237 <  <!-- jsr166e -->
1237 >
1238 >  <!-- jsr166e (no longer maintained) -->
1239  
1240    <property name="build.jsr166e.java.version" value="6"/>
1241    <property name="build.jsr166e.javac" value="${javac6}"/>
1242  
1243 <  <target name="jsr166ecompile"
1344 <          depends="configure-compiler"
1345 <          description="Compiles jsr166e sources">
1346 <
1243 >  <target name="jsr166ecompile" depends="configure-compiler">
1244      <mkdir dir="${build.jsr166e.classes.dir}"/>
1245  
1246      <javac srcdir="${topsrc.dir}"
# Line 1364 | Line 1261
1261        <compilerarg value="-Xlint:all"/>
1262        <compilerarg value="-Werror"/>
1263        <compilerarg line="${build.args}"/>
1367
1264      </javac>
1265    </target>
1266  
1371  <!-- jsr166e: find doclint errors -->
1267    <target name="jsr166edoclint">
1373
1268      <mkdir dir="${build.jsr166e.classes.dir}"/>
1269  
1270      <javac srcdir="${topsrc.dir}"
# Line 1392 | Line 1286
1286        <compilerarg value="-Xlint:all"/>
1287        <compilerarg value="-Werror"/>
1288        <compilerarg value="-Xdoclint:all/protected"/>
1395
1289      </javac>
1290    </target>
1291  
1292 <
1400 <  <target name="jsr166ejar"
1401 <          depends="jsr166ecompile"
1402 <          description="Builds library jar from compiled sources">
1403 <
1292 >  <target name="jsr166ejar" depends="jsr166ecompile">
1293      <jar destfile="${jsr166e.jar}" index="true">
1294        <fileset dir="${build.jsr166e.classes.dir}"/>
1295        <manifest>
# Line 1408 | Line 1297
1297          <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1298        </manifest>
1299      </jar>
1411
1300    </target>
1301  
1302 <
1415 <  <target name="jsr166edocs"
1416 <          description="Builds javadocs to build dir">
1417 <
1302 >  <target name="jsr166edocs">
1303      <delete dir="${jsr166edocs.dir}"/>
1304      <mkdir dir="${jsr166edocs.dir}"/>
1305  
# Line 1428 | Line 1313
1313               failonerror = "true">
1314        <arg line="-Xdocrootparent ${java.docroot.url}"/>
1315        <arg value="-XDignore.symbol.file=true"/>
1431
1316      </javadoc>
1317    </target>
1318  
1319 <
1436 <  <target name="jsr166e-tck-one-java-version"
1437 <          depends="jsr166ejar">
1438 <
1319 >  <target name="jsr166e-tck-one-java-version" depends="jsr166ejar">
1320      <echo message="Testing with jdk${build.jsr166e.java.version} ..."/>
1440
1321      <run-tck-tests
1322        tck.src.dir="${test.src.dir}/tck-jsr166e"
1323        target="${build.jsr166e.java.version}"
# Line 1445 | Line 1325
1325        classes="${jsr166e.jar}"/>
1326    </target>
1327  
1328 <  <target name="jsr166e-tck"
1449 <          description="Runs tck tests for jsr166e for multiple java versions">
1328 >  <target name="jsr166e-tck">
1329  
1330   <!--     <antcall target="clean"/> -->
1331   <!--     <antcall target="jsr166e-tck-one-java-version"> -->
# Line 1467 | Line 1346
1346      </antcall>
1347    </target>
1348  
1349 +  <target name="jsr166e-test" depends="jsr166e-tck"/>
1350  
1351 <  <target name="jsr166e-test"
1472 <          depends="jsr166e-tck"
1473 <          description="Runs all tests for jsr166e">
1474 <  </target>
1351 >  <target name="jsr166edist" depends="jsr166edist-jar, jsr166edist-docs"/>
1352  
1353 <  <target name="jsr166edist"
1477 <          depends="jsr166edist-jar, jsr166edist-docs"
1478 <          description="Puts all distributable products in single hierarchy"/>
1479 <
1480 <
1481 <  <target name="jsr166eclean"
1482 <          description="Removes all jsr166e build products">
1353 >  <target name="jsr166eclean">
1354      <delete dir="${build.jsr166e.dir}"/>
1355    </target>
1356  
1486
1357    <target name="jsr166edist-jar"
1358            depends="jsr166eclean, jsr166ejar">
1359      <copy file="${jsr166e.jar}" todir="${dist.dir}"/>
1360    </target>
1361  
1362 <  <target name="jsr166edist-docs"
1493 <          depends="jsr166eclean, jsr166edocs">
1362 >  <target name="jsr166edist-docs" depends="jsr166eclean, jsr166edocs">
1363      <mirror-dir src="${jsr166edocs.dir}" dst="${dist.jsr166edocs.dir}"/>
1364    </target>
1365  
# Line 1510 | Line 1379
1379      </antcall>
1380    </target>
1381  
1382 +
1383 + <!-- ==============================================================
1384 +  Experimental errorprone support - http://errorprone.info
1385 + =================================================================== -->
1386 +  <property name="errorprone.jar" location="${lib.dir}/error_prone_ant-2.1.2.jar"/>
1387 +  <target name="errorprone"
1388 +          depends="clean, configure-compiler"
1389 +          description="Run errorprone over jsr166 source code (experimental)">
1390 +
1391 +    <local name="destdir"/>
1392 +    <property name="destdir" value="${build.classes.dir}/java.base"/>
1393 +    <mkdir dir="${destdir}"/>
1394 +
1395 +    <javac srcdir="${src.dir}"
1396 +           destdir="${destdir}"
1397 +           debug="${build.debug}"
1398 +           debuglevel="${build.debuglevel}"
1399 +           deprecation="${build.deprecation}"
1400 +           classpath=""
1401 +           includeAntRuntime="false"
1402 +           includeJavaRuntime="false"
1403 +           encoding="ASCII"
1404 +           executable="${build.main.javac}"
1405 +           fork="true">
1406 +
1407 +      <include name="**/*.java"/>
1408 +      <compilerarg line="-processorpath ${errorprone.jar}"/>
1409 +      <compilerarg value="-Xplugin:ErrorProne
1410 +                          -Xep:IdentityBinaryExpression:WARN
1411 +                          -Xep:MissingOverride:OFF
1412 +                          -Xep:MixedArrayDimensions:ERROR
1413 +                          -Xep:RemoveUnusedImports:ERROR
1414 +                          -Xep:ClassName:ERROR
1415 +                          -Xep:MultipleTopLevelClasses:ERROR
1416 +                          -Xep:EmptyIf:ERROR
1417 +                          -Xep:LongLiteralLowerCaseSuffix:ERROR
1418 +                          -Xep:RedundantThrows:ERROR
1419 +                          -Xep:MethodCanBeStatic:WARN"/>
1420 +      <compilerarg value="--patch-module=java.base=${src.dir}"/>
1421 +      <compilerarg value="-Xprefer:source"/>
1422 +      <compilerarg value="-XDignore.symbol.file=true"/>
1423 +      <compilerarg value="-Xlint:all"/>
1424 +      <compilerarg value="-Xdoclint:all/protected,reference/private"/>
1425 +      <compilerarg line="-Xmaxerrs 3000 -Xmaxwarns 3000"/>
1426 +      <compilerarg line="${build.args}"/>
1427 +    </javac>
1428 +
1429 +    <jar destfile="${product.jar}">
1430 +      <fileset dir="${destdir}"/>
1431 +    </jar>
1432 +
1433 +    <run-tck-tests
1434 +      target="${build.main.java.version}"
1435 +      workdir="${build.dir}"
1436 +      classes="${product.jar}">
1437 +      <javac-elements>
1438 +        <compilerarg line="-processorpath ${errorprone.jar}"/>
1439 +        <compilerarg value="-Xplugin:ErrorProne
1440 +                            -Xep:IdentityBinaryExpression:WARN
1441 +                            -Xep:BoxedPrimitiveConstructor:OFF
1442 +                            -Xep:HashtableContains:OFF
1443 +                            -Xep:ModifyingCollectionWithItself:OFF
1444 +                            -Xep:MissingOverride:OFF
1445 +                            -Xep:MissingFail:OFF
1446 +                            -Xep:JdkObsolete:OFF
1447 +                            -Xep:MixedArrayDimensions:ERROR
1448 +                            -Xep:RemoveUnusedImports:ERROR
1449 +                            -Xep:ClassName:ERROR
1450 +                            -Xep:MultipleTopLevelClasses:ERROR
1451 +                            -Xep:EmptyIf:ERROR
1452 +                            -Xep:LongLiteralLowerCaseSuffix:ERROR
1453 +                            -Xep:RedundantThrows:ERROR
1454 +                            -Xep:MethodCanBeStatic:WARN"/>
1455 +        <compilerarg line="-Xmaxerrs 3000 -Xmaxwarns 3000"/>
1456 +      </javac-elements>
1457 +    </run-tck-tests>
1458 +  </target>
1459 +
1460 +  <!-- ant errorprone-jtreg |& grep -EA1 '(warning|error):' -->
1461 +  <target name="errorprone-jtreg"
1462 +          depends="jar"
1463 +          description="Run errorprone over jtreg tests (experimental)">
1464 +
1465 +    <run-jtreg-tests
1466 +       target="${build.main.java.version}"
1467 +       workdir="${build.dir}"
1468 +       classes="${product.jar}"
1469 +       verbose="all">
1470 +      <jtreg-elements>
1471 +        <arg value="-javacoption:-processorpath"/>
1472 +        <arg value="-javacoption:${errorprone.jar}"/>
1473 +        <arg value="-javacoption:-Xplugin:ErrorProne
1474 +                            -Xep:IdentityBinaryExpression:WARN
1475 +                            -Xep:BoxedPrimitiveConstructor:OFF
1476 +                            -Xep:HashtableContains:OFF
1477 +                            -Xep:ModifyingCollectionWithItself:OFF
1478 +                            -Xep:MissingOverride:OFF
1479 +                            -Xep:JdkObsolete:OFF
1480 +                            -Xep:NonAtomicVolatileUpdate:OFF
1481 +                            -Xep:MixedArrayDimensions:ERROR
1482 +                            -Xep:RemoveUnusedImports:ERROR
1483 +                            -Xep:ClassName:ERROR
1484 +                            -Xep:MultipleTopLevelClasses:ERROR
1485 +                            -Xep:EmptyIf:ERROR
1486 +                            -Xep:LongLiteralLowerCaseSuffix:ERROR
1487 +                            -Xep:RedundantThrows:ERROR
1488 +                            -Xep:MethodCanBeStatic:WARN"/>
1489 +      </jtreg-elements>
1490 +    </run-jtreg-tests>
1491 +  </target>
1492 +
1493 +
1494   <!-- ==============================================================
1495    Running guava tests against jsr166 code
1496   =================================================================== -->
# Line 1562 | Line 1543
1543      <get src="http://repo2.maven.org/maven2/com/google/guava/guava-testlib/${guava.version}/guava-testlib-${guava.version}-tests.jar"
1544           dest="${guava.dir}/guava-testlib-tests.jar" usetimestamp="true"/>
1545      <junit printsummary="true" showoutput="true" haltonfailure="true"
1546 <           jvm="${java9}" fork="true">
1547 <      <jvmarg line="-ea -esa --patch-module java.base=${product.jar}"/>
1546 >           jvm="${build.main.java}" fork="true">
1547 >      <jvmarg line="-ea -esa --patch-module=java.base=${product.jar}"/>
1548        <formatter type="brief"/>
1549        <classpath>
1550          <pathelement location="${guava.dir}/guava-testlib-tests.jar"/>

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines