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.259 by jsr166, Mon Dec 18 21:07:18 2017 UTC vs.
Revision 1.279 by jsr166, Mon Oct 1 03:04:48 2018 UTC

# Line 1 | Line 1
1   <project name="jsr166" default="usage"
2 <  xmlns:if="ant:if" xmlns:unless="ant:unless"
2 >  xmlns:if="ant:if"
3 >  xmlns:unless="ant:unless"
4    xmlns:ivy="antlib:org.apache.ivy.ant">
5  
6    <description>
# Line 21 | Line 22
22    $HOME/jdk/jdk8
23    $HOME/jdk/jdk9
24    $HOME/jdk/jdk10
25 +  $HOME/jdk/jdk11
26 +  $HOME/jdk/jdk12
27    where each of the above is a JDK or a symlink to same, and
28    $HOME/jdk/src/jdk8
29    $HOME/jdk/src/jdk9
30    $HOME/jdk/src/jdk10
31 +  $HOME/jdk/src/jdk11
32 +  $HOME/jdk/src/jdk12
33    where each of the above is a complete JDK source tree
34    (e.g. mercurial forest) or a symlink to same.
35  
# Line 101 | Line 106
106      <property name="jdk@{v}.src.dir" location="${jdk@{v}.src.home}/jdk/src/share/classes"
107        unless:set="have.java.base"/>
108      <local name="modules"/>
109 <    <available property="modules" file="${jdk@{v}.home}/jmods" type="dir"/>
109 >    <available property="modules" file="${jdk@{v}.home}/lib/modules" type="file"/>
110      <local name="boot.jar.dir"/>
111      <property name="boot.jar.dir"   location="${jdk@{v}.home}/jre/lib" unless:set="modules"/>
112      <path id="bootclasspath@{v}" unless:set="modules">
# Line 132 | Line 137
137    <defjdklocations v="8"/>
138    <defjdklocations v="9"/>
139    <defjdklocations v="10"/>
140 +  <defjdklocations v="11"/>
141 +  <defjdklocations v="12"/>
142  
143    <!-- Source locations -->
144    <property name="src.dir"              location="${basedir}/src/main"/>
# Line 142 | Line 149
149    <property name="jtreg8.src.dir"       location="${test.src.dir}/jtreg-jdk8"/>
150    <property name="jtreg9.src.dir"       location="${test.src.dir}/jtreg"/>
151    <property name="jtreg10.src.dir"      location="${test.src.dir}/jtreg"/>
152 +  <property name="jtreg11.src.dir"      location="${test.src.dir}/jtreg"/>
153 +  <property name="jtreg12.src.dir"      location="${test.src.dir}/jtreg"/>
154    <property name="jtreg.src.dir"        location="${jtreg9.src.dir}"/>
155    <property name="lib.dir"              location="${basedir}/lib"/>
156    <property name="dist.dir"             location="${basedir}/dist"/>
# Line 187 | Line 196
196    <property name="java7.docroot.url"  value="https://docs.oracle.com/javase/7/docs"/>
197    <property name="java8.docroot.url"  value="https://docs.oracle.com/javase/8/docs"/>
198    <property name="java9.docroot.url"  value="https://docs.oracle.com/javase/9/docs"/>
199 <  <!-- The location of jdk9 early access docs (RIP) -->
199 >  <property name="java10.docroot.url" value="https://docs.oracle.com/javase/10/docs"/>
200 >  <property name="java11.docroot.url" value="https://docs.oracle.com/en/java/javase/11/docs"/>
201 >  <!-- The location of jdk early access docs (RIP) -->
202    <!-- <property name="java9.docroot.url" value="http://download.java.net/java/jdk9/docs"/> -->
203 +  <!-- <property name="java10.docroot.url" value="http://download.java.net/java/jdk10/docs"/> -->
204 +  <!-- <property name="java11.docroot.url" value="http://download.java.net/java/jdk11/docs"/> -->
205 +  <property name="java12.docroot.url" value="https://download.java.net/java/jdk12/docs"/>
206    <!-- Default jdk doc location (latest stable release seems best) -->
207 <  <property name="java10.docroot.url" value="http://download.java.net/java/jdk10/docs"/>
208 <  <property name="java.docroot.url"   value="${java9.docroot.url}"/>
207 >  <!-- But pin to jdk 10 until fix for -->
208 >  <!-- 8211194: javadoc -link doesn't take module path into consideration -->
209 >  <property name="java.docroot.url"   value="${java10.docroot.url}"/>
210  
211    <!-- Canonical location of jdk API docs, to use with javadoc link attribute -->
212    <property name="java5.api.url"      value="${java5.docroot.url}/api/"/>
# Line 200 | Line 215
215    <property name="java8.api.url"      value="${java8.docroot.url}/api/"/>
216    <property name="java9.api.url"      value="${java9.docroot.url}/api/"/>
217    <property name="java10.api.url"     value="${java10.docroot.url}/api/"/>
218 +  <property name="java11.api.url"     value="${java11.docroot.url}/api/"/>
219 +  <property name="java12.api.url"     value="${java12.docroot.url}/api/"/>
220    <property name="java.api.url"       value="${java.docroot.url}/api/"/>
221  
222    <!-- Define the "jtreg" task -->
# Line 232 | Line 249
249  
250      <local name="modules"/>
251      <condition property="modules">
252 <      <available file="${jdk@{compile-target}.home}/jmods" type="dir"/>
252 >      <available file="${jdk@{compile-target}.home}/lib/modules" type="file"/>
253      </condition>
254  
255      <local name="use-doclint"/>
# Line 299 | Line 316
316    </macrodef>
317  
318    <!-- Define jtreg test sets for different jdk versions -->
319 <  <fileset dir="${jtreg10.src.dir}">
320 <    <patternset id="jdk10.jtreg.tests">
321 <      <include name="**/*.java"/>
322 <    </patternset>
323 <  </fileset>
324 <
325 <  <fileset dir="${jtreg9.src.dir}">
326 <    <patternset id="jdk9.jtreg.tests">
327 <      <include name="**/*.java"/>
328 <    </patternset>
329 <  </fileset>
330 <
331 <  <fileset dir="${jtreg8.src.dir}">
315 <    <patternset id="jdk8.jtreg.tests">
316 <      <include name="**/*.java"/>
317 <    </patternset>
318 <  </fileset>
319 >  <!-- ant -Djtreg.test.pattern="**/ConcurrentHashMap/" -->
320 >  <!-- ant -Djtreg.test.pattern="**/ToArray.java" -->
321 >  <property name="jtreg.test.pattern" value="**/*.java"/>
322 >  <macrodef name="defjtregtests">
323 >    <attribute name="v"/>
324 >    <sequential>
325 >      <fileset dir="${jtreg@{v}.src.dir}">
326 >        <patternset id="jdk@{v}.jtreg.tests">
327 >          <include name="${jtreg.test.pattern}"/>
328 >        </patternset>
329 >      </fileset>
330 >    </sequential>
331 >  </macrodef>
332  
333 <  <fileset dir="${jtreg7.src.dir}">
334 <    <patternset id="jdk7.jtreg.tests">
335 <      <include name="**/*.java"/>
336 <    </patternset>
337 <  </fileset>
333 >  <defjtregtests v="12"/>
334 >  <defjtregtests v="11"/>
335 >  <defjtregtests v="10"/>
336 >  <defjtregtests v="9"/>
337 >  <defjtregtests v="8"/>
338 >  <defjtregtests v="7"/>
339  
340    <!-- ant -Djtreg.flags=-timeoutFactor:4 -->
341    <property name="jtreg.flags" value=""/>
# Line 342 | Line 356
356  
357      <local name="modules"/>
358      <condition property="modules">
359 <      <available file="${jdk@{target}.home}/jmods" type="dir"/>
359 >      <available file="${jdk@{target}.home}/lib/modules" type="file"/>
360      </condition>
361  
362      <delete dir="@{workdir}/JTwork"   quiet="true"/>
# Line 377 | Line 391
391  
392    <!-- Main targets -->
393  
394 <  <property name="build.main.java.version" value="9"/>
394 >  <property name="build.main.java.version" value="11"/>
395    <!-- Workaround "no nested properties in ant" -->
396    <macrodef name="define-build-main-properties">
397      <attribute name="v"/>
398      <sequential>
399        <property name="build.main.java"    value="${java@{v}}"/>
400        <property name="build.main.javac"   value="${javac@{v}}"/>
401 <      <property name="build.main.javadoc" value="${javadoc@{v}}"/>
401 >      <!-- Force javadoc version to be at least 10,
402 >           so we can use override-methods=summary -->
403 >      <condition property="build.main.javadoc"
404 >                 value="${javadoc11}"
405 >                 else="${javadoc@{v}}">
406 >        <equals arg1="@{v}" arg2="9"/>
407 >      </condition>
408      </sequential>
409    </macrodef>
410    <define-build-main-properties v="${build.main.java.version}"/>
# Line 463 | Line 483
483   <!-- TODO: <arg line="- -module-source-path ${jdk9.home}/src.zip"/> -->
484      <javadoc destdir="${docs.dir}"
485               packagenames="none"
486 <             link="${java9.api.url}"
486 >             link="${java10.api.url}"
487               overview="${src.dir}/intro.html"
488               access="${build.javadoc.access}"
489               sourcepath="${src.dir}"
490               classpath=""
491 <             source="9"
491 >             source="11"
492               executable="${build.main.javadoc}">
493        <fileset dir="${src.dir}" defaultexcludes="yes">
494          <include name="**/*.java"/>
495        </fileset>
496 <      <arg line="-Xdocrootparent ${java9.docroot.url}"/>
496 >      <arg line="-Xdocrootparent ${java10.docroot.url}"/>
497        <arg line="-Xmaxerrs 1000 -Xmaxwarns 1000"/>
498        <arg value="-XDignore.symbol.file=true"/>
499        <arg value="-html5"/>
500        <arg value="--patch-module=java.base=${src.dir}"/>
501 <      <arg value="-tag"/>
502 <      <arg value="${javadoc.jls.option}"/>
503 < <!-- @apiNote currently unused -->
504 < <!--       <arg value="-tag"/> -->
505 < <!--       <arg value="apiNote:a:API Note:"/> -->
486 <      <arg value="-tag"/>
487 <      <arg value="implSpec:a:Implementation Requirements:"/>
488 <      <arg value="-tag"/>
489 <      <arg value="implNote:a:Implementation Note:"/>
501 >      <arg value="--override-methods=summary"/>
502 >      <arg value="-tag"/> <arg value="${javadoc.jls.option}"/>
503 >      <arg value="-tag"/> <arg value="implSpec:a:Implementation Requirements:"/>
504 >      <arg value="-tag"/> <arg value="implNote:a:Implementation Note:"/>
505 >      <arg value="-tag"/> <arg value="apiNote:a:API Note:"/>
506   <!-- tags added in jdk9: currently unused -->
507 < <!--       <arg value="-tag"/> -->
508 < <!--       <arg value="revised:X"/> -->
493 < <!--       <arg value="-tag"/> -->
494 < <!--       <arg value="spec:X"/> -->
507 > <!--  <arg value="-tag"/> <arg value="revised:X"/> -->
508 > <!--  <arg value="-tag"/> <arg value="spec:X"/> -->
509      </javadoc>
510    </target>
511  
# Line 603 | Line 617
617  
618   <!--   </target> -->
619  
620 <  <target name="test910"
620 >  <target name="test9101112"
621            description="Runs tck and jtreg tests for src/main for multiple java versions">
622  
623      <antcall target="clean"/>
624      <antcall target="test">
625        <param name="build.main.java.version" value="9"/>
626 +      <param name="build.main.java" value="${java9}"/>
627 +      <param name="build.main.javac" value="${javac9}"/>
628      </antcall>
629  
630      <antcall target="clean"/>
631      <antcall target="test">
632        <param name="build.main.java.version" value="10"/>
633 +      <param name="build.main.java" value="${java10}"/>
634 +      <param name="build.main.javac" value="${javac10}"/>
635 +    </antcall>
636 +
637 +    <antcall target="clean"/>
638 +    <antcall target="test">
639 +      <param name="build.main.java.version" value="11"/>
640 +      <param name="build.main.java" value="${java11}"/>
641 +      <param name="build.main.javac" value="${javac11}"/>
642 +    </antcall>
643 +
644 +    <antcall target="clean"/>
645 +    <antcall target="test">
646 +      <param name="build.main.java.version" value="12"/>
647 +      <param name="build.main.java" value="${java12}"/>
648 +      <param name="build.main.javac" value="${javac12}"/>
649 +    </antcall>
650 +    <antcall target="docs">
651 +      <param name="build.main.java.version" value="12"/>
652 +      <param name="build.main.java" value="${java12}"/>
653 +      <param name="build.main.javac" value="${javac12}"/>
654 +      <param name="build.main.javadoc" value="${javadoc12}"/>
655      </antcall>
656  
657      <!-- Clean up to avoid obscure wrong class file version bugs -->
# Line 828 | Line 866
866        </fileset>
867        <arg line="-Xdocrootparent ${java8.docroot.url}"/>
868        <arg value="-XDignore.symbol.file=true"/>
869 <      <arg value="-tag"/>
870 <      <arg value="${javadoc.jls.option}"/>
871 < <!-- @apiNote currently unused -->
872 < <!--       <arg value="-tag"/> -->
873 < <!--       <arg value="apiNote:a:&lt;em&gt;API Note:&lt;/em&gt;"/> -->
836 <      <arg value="-tag"/>
837 <      <arg value="implSpec:a:&lt;em&gt;Implementation Requirements:&lt;/em&gt;"/>
838 <      <arg value="-tag"/>
839 <      <arg value="implNote:a:&lt;em&gt;Implementation Note:&lt;/em&gt;"/>
869 >      <arg value="-tag"/> <arg value="${javadoc.jls.option}"/>
870 >      <arg value="-tag"/> <arg value="implSpec:a:&lt;em&gt;Implementation Requirements:&lt;/em&gt;"/>
871 >      <arg value="-tag"/> <arg value="implNote:a:&lt;em&gt;Implementation Note:&lt;/em&gt;"/>
872 > <!-- @apiNote tag currently unused -->
873 > <!--  <arg value="-tag"/> <arg value="apiNote:a:&lt;em&gt;API Note:&lt;/em&gt;"/> -->
874      </javadoc>
875    </target>
876  
# Line 1366 | Line 1400
1400  
1401   <!-- Find buglets that can be detected by static build tools -->
1402  
1403 <  <target name="lint">
1404 <    <antcall target="dists">
1405 <      <param name="build.javadoc.access" value="public"/>
1406 <    </antcall>
1407 <  </target>
1403 > <!--   <target name="lint"> -->
1404 > <!--     <antcall target="dists"> -->
1405 > <!--       <param name="build.javadoc.access" value="protected"/> -->
1406 > <!--     </antcall> -->
1407 > <!--   </target> -->
1408  
1409   <!-- Generates all doclint warnings, even for private methods (rarely useful) -->
1410 <  <target name="lint-private">
1410 >  <target name="doclint-private">
1411      <antcall target="dist">
1412        <param name="build.javadoc.access" value="private"/>
1413      </antcall>
# Line 1381 | Line 1415
1415  
1416  
1417   <!-- ==============================================================
1418 <  Experimental errorprone support - http://errorprone.info
1418 >  Experimental errorprone support - https://errorprone.info
1419   =================================================================== -->
1420 <  <property name="errorprone.jar" location="${lib.dir}/error_prone_ant-2.1.2.jar"/>
1420 >  <property name="errorprone.jar" location="${lib.dir}/error_prone_ant-2.3.1.jar"/>
1421 >  <property name="errorprone.jsr166.user.flags" value=""/>
1422 >  <property name="errorprone.jsr166.flags"
1423 >            value="-Xep:HashtableContains:OFF
1424 >                   -Xep:JdkObsolete:OFF
1425 >                   -Xep:MissingOverride:OFF
1426 >                   -Xep:MissingFail:OFF
1427 >                   -Xep:MixedArrayDimensions:ERROR
1428 >                   -Xep:RemoveUnusedImports:ERROR
1429 >                   -Xep:EmptyIf:ERROR
1430 >                   -Xep:MultipleTopLevelClasses:ERROR
1431 >                   -Xep:ClassName:ERROR
1432 >                   -Xep:LongLiteralLowerCaseSuffix:ERROR
1433 >                   -Xep:RedundantThrows:ERROR
1434 >                   -Xep:IdentityBinaryExpression:WARN
1435 >                   -Xep:MethodCanBeStatic:WARN
1436 >                   ${errorprone.jsr166.user.flags}"/>
1437 >  <!-- -Xep:WildcardImport:ERROR -->
1438 >  <property name="errorprone.jsr166.test.flags"
1439 >            value="-Xep:StringSplitter:OFF
1440 >                   -Xep:BoxedPrimitiveConstructor:OFF
1441 >                   -Xep:ModifyingCollectionWithItself:OFF"/>
1442 >  <!-- ant -emacs errorprone |& grep -EA1 '(warning|error):|warnings' -->
1443    <target name="errorprone"
1444            depends="clean, configure-compiler"
1445            description="Run errorprone over jsr166 source code (experimental)">
# Line 1405 | Line 1461
1461             fork="true">
1462  
1463        <include name="**/*.java"/>
1464 +      <!-- Needed to silence -Xep:FutureReturnValueIgnored -->
1465 +      <compilerarg value="-J--illegal-access=permit"/>
1466 +      <compilerarg value="-XDcompilePolicy=simple"/>
1467        <compilerarg line="-processorpath ${errorprone.jar}"/>
1468        <compilerarg value="-Xplugin:ErrorProne
1469 <                          -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"/>
1469 >                          ${errorprone.jsr166.flags}"/>
1470        <compilerarg value="--patch-module=java.base=${src.dir}"/>
1471        <compilerarg value="-Xprefer:source"/>
1472        <compilerarg value="-XDignore.symbol.file=true"/>
# Line 1435 | Line 1485
1485        workdir="${build.dir}"
1486        classes="${product.jar}">
1487        <javac-elements>
1488 +        <!-- Needed to silence -Xep:FutureReturnValueIgnored -->
1489 +        <compilerarg value="-J--illegal-access=permit"/>
1490 +        <compilerarg value="-XDcompilePolicy=simple"/>
1491          <compilerarg line="-processorpath ${errorprone.jar}"/>
1492          <compilerarg value="-Xplugin:ErrorProne
1493 <                            -Xep:IdentityBinaryExpression:WARN
1494 <                            -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"/>
1493 >                            ${errorprone.jsr166.flags}
1494 >                            ${errorprone.jsr166.test.flags}"/>
1495          <compilerarg line="-Xmaxerrs 3000 -Xmaxwarns 3000"/>
1496        </javac-elements>
1497      </run-tck-tests>
1498    </target>
1499  
1500 <  <!-- ant errorprone-jtreg |& grep -EA1 '(warning|error):' -->
1500 >  <!-- ant -emacs errorprone-jtreg |& grep -EA1 '(warning|error):' -->
1501 >  <!-- -XDcompilePolicy=simple or byfile avoids confusing UnusedImports -->
1502    <target name="errorprone-jtreg"
1503            depends="jar"
1504            description="Run errorprone over jtreg tests (experimental)">
# Line 1468 | Line 1509
1509         classes="${product.jar}"
1510         verbose="all">
1511        <jtreg-elements>
1512 +        <arg value="-javacoption:-XDcompilePolicy=simple"/>
1513          <arg value="-javacoption:-processorpath"/>
1514          <arg value="-javacoption:${errorprone.jar}"/>
1515          <arg value="-javacoption:-Xplugin:ErrorProne
1516 <                            -Xep:IdentityBinaryExpression:WARN
1517 <                            -Xep:BoxedPrimitiveConstructor:OFF
1518 <                            -Xep:HashtableContains:OFF
1519 <                            -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"/>
1516 >                            ${errorprone.jsr166.flags}
1517 >                            ${errorprone.jsr166.test.flags}
1518 >                            -Xep:MultipleTopLevelClasses:WARN
1519 >                            -Xep:NonAtomicVolatileUpdate:OFF"/>
1520        </jtreg-elements>
1521      </run-jtreg-tests>
1522    </target>

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines