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.189 by jsr166, Thu Nov 5 15:02:34 2015 UTC vs.
Revision 1.200 by jsr166, Sat Mar 26 06:22:49 2016 UTC

# Line 27 | Line 27
27    (e.g. mercurial forest) or a symlink to same.
28  
29    Alternatively, define ant variables thus:
30 <  ant -Djdk$N.home=...
30 >  ant -Djdk$N.home=... -Djdk$N.src.home=...
31    for $N in 6 7 8 9 ...
32  
33    As of 2015-09, there is incomplete hacky support for jigsaw
34    Build for jigsaw using something like:
35 <  ant -Djdk9.home="$HOME/jdk/jigsaw" -Djdk9.src.dir="$HOME/jdk/src/jigsaw" clean test dist
35 >  ant -Djdk9.home="$HOME/jdk/jigsaw" -Djdk9.src.home="$HOME/jdk/src/jigsaw" clean test dist
36    "docs" target is still broken.
37   ------------------------------------------------------------------------------
38    </description>
# Line 69 | Line 69
69    <property name="build.4jdk7.tck.classes.dir" location="${build.4jdk7.dir}/tck-classes"/>
70    <property name="build.4jdk7.docs.dir"        location="${build.4jdk7.dir}/docs"/>
71  
72 +  <property name="build.4jdk8.dir"             location="${build.dir}/jsr166-4jdk8"/>
73 +  <property name="build.4jdk8.classes.dir"     location="${build.4jdk8.dir}/classes"/>
74 +  <property name="build.4jdk8.tck.classes.dir" location="${build.4jdk8.dir}/tck-classes"/>
75 +  <property name="build.4jdk8.docs.dir"        location="${build.4jdk8.dir}/docs"/>
76 +
77    <property name="build.jsr166x.dir"           location="${build.dir}/jsr166x"/>
78    <property name="build.jsr166y.dir"           location="${build.dir}/jsr166y"/>
79    <property name="build.jsr166e.dir"           location="${build.dir}/jsr166e"/>
# Line 85 | Line 90
90    <macrodef name="defjdklocations">
91      <attribute name="v"/>
92      <sequential>
93 <    <property name="jdk@{v}.home"   location="${jdks.home}/jdk@{v}"/>
94 <    <property name="java@{v}"       location="${jdk@{v}.home}/bin/java"/>
95 <    <property name="javac@{v}"      location="${jdk@{v}.home}/bin/javac"/>
96 <    <property name="javadoc@{v}"    location="${jdk@{v}.home}/bin/javadoc"/>
93 >    <property name="jdk@{v}.home"     location="${jdks.home}/jdk@{v}"/>
94 >    <property name="java@{v}"         location="${jdk@{v}.home}/bin/java"/>
95 >    <property name="javac@{v}"        location="${jdk@{v}.home}/bin/javac"/>
96 >    <property name="javadoc@{v}"      location="${jdk@{v}.home}/bin/javadoc"/>
97 >    <property name="jdk@{v}.src.home" location="${jdks.home}/src/jdk@{v}"/>
98      <local name="have.java.base"/>
99      <available property="have.java.base"
100 <      file="${jdks.home}/src/jdk@{v}/jdk/src/java.base/share/classes" type="dir"/>
101 <    <property name="jdk@{v}src.dir" location="${jdks.home}/src/jdk@{v}/jdk/src/java.base/share/classes"
100 >      file="${jdk@{v}.src.home}/jdk/src/java.base/share/classes" type="dir"/>
101 >    <property name="jdk@{v}.src.dir" location="${jdk@{v}.src.home}/jdk/src/java.base/share/classes"
102        if:set="have.java.base"/>
103 <    <property name="jdk@{v}src.dir" location="${jdks.home}/src/jdk@{v}/jdk/src/share/classes"
103 >    <property name="jdk@{v}.src.dir" location="${jdk@{v}.src.home}/jdk/src/share/classes"
104        unless:set="have.java.base"/>
105      <local name="modules"/>
106      <available property="modules" file="${jdk@{v}.home}/jmods" type="dir"/>
# Line 134 | Line 140
140    <property name="loops.src.dir"        location="${basedir}/src/loops"/>
141    <property name="tck.src.dir"          location="${test.src.dir}/tck"/>
142    <property name="jtreg7.src.dir"       location="${test.src.dir}/jtreg-jdk7"/>
143 <  <property name="jtreg8.src.dir"       location="${test.src.dir}/jtreg"/>
143 >  <property name="jtreg8.src.dir"       location="${test.src.dir}/jtreg-jdk8"/>
144    <property name="jtreg9.src.dir"       location="${test.src.dir}/jtreg"/>
145    <property name="jtreg.src.dir"        location="${jtreg9.src.dir}"/>
146    <property name="lib.dir"              location="${basedir}/lib"/>
147    <property name="dist.dir"             location="${basedir}/dist"/>
148    <property name="topsrc.dir"           location="${basedir}/src"/>
149    <property name="4jdk7src.dir"         location="${topsrc.dir}/jdk7"/>
150 +  <property name="4jdk8src.dir"         location="${topsrc.dir}/jdk8"/>
151    <property name="jsr166xsrc.dir"       location="${topsrc.dir}/jsr166x"/>
152    <property name="jsr166ysrc.dir"       location="${topsrc.dir}/jsr166y"/>
153    <property name="jsr166esrc.dir"       location="${topsrc.dir}/jsr166e"/>
# Line 149 | Line 156
156    <!-- Javadoc locations -->
157    <property name="docs.dir"          location="${build.dir}/docs"/>
158    <property name="4jdk7docs.dir"     location="${build.4jdk7.dir}/docs"/>
159 +  <property name="4jdk8docs.dir"     location="${build.4jdk8.dir}/docs"/>
160    <property name="jsr166xdocs.dir"   location="${build.jsr166x.dir}/docs"/>
161    <property name="jsr166ydocs.dir"   location="${build.jsr166y.dir}/docs"/>
162    <property name="jsr166edocs.dir"   location="${build.jsr166e.dir}/docs"/>
# Line 156 | Line 164
164  
165    <property name="dist.docs.dir"          location="${dist.dir}/docs"/>
166    <property name="dist.4jdk7docs.dir"     location="${dist.dir}/jsr166-4jdk7docs"/>
167 +  <property name="dist.4jdk8docs.dir"     location="${dist.dir}/jsr166-4jdk8docs"/>
168    <property name="dist.jsr166xdocs.dir"   location="${dist.dir}/jsr166xdocs"/>
169    <property name="dist.jsr166ydocs.dir"   location="${dist.dir}/jsr166ydocs"/>
170    <property name="dist.jsr166edocs.dir"   location="${dist.dir}/jsr166edocs"/>
# Line 164 | Line 173
173    <!-- Jar locations -->
174    <property name="product.jar"      location="${build.dir}/jsr166.jar"/>
175    <property name="4jdk7product.jar" location="${build.4jdk7.dir}/jsr166-4jdk7.jar"/>
176 +  <property name="4jdk8product.jar" location="${build.4jdk8.dir}/jsr166-4jdk8.jar"/>
177    <property name="jsr166x.jar"      location="${build.jsr166x.dir}/jsr166x.jar"/>
178    <property name="jsr166y.jar"      location="${build.jsr166y.dir}/jsr166y.jar"/>
179    <property name="jsr166e.jar"      location="${build.jsr166e.dir}/jsr166e.jar"/>
# Line 175 | Line 185
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 2014-07 -->
188 >  <!-- The expected canonical location does not yet exist as of 2016-03 -->
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/jdk9/docs"/>
191    <!-- Default jdk doc location (latest stable release seems best) -->
# Line 238 | Line 248
248        <compilerarg value="-XDignore.symbol.file=true"/>
249        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation,-try"/>
250        <compilerarg value="-Xbootclasspath/p:@{classes}" unless:set="modules"/>
251 <      <compilerarg value="-Xoverride:${build.classes.dir}" if:set="modules"/>
251 >      <compilerarg value="-Xpatch:${build.classes.dir}" if:set="modules"/>
252        <compilerarg line="${build.args}"/>
253        <javac-elements/>
254  
# Line 249 | Line 259
259            jvm="${java@{target}}"
260            fork="true">
261          <jvmarg value="-Xbootclasspath/p:@{classes}" unless:set="modules"/>
262 <        <jvmarg value="-Xoverride:${build.classes.dir}" if:set="modules"/>
262 >        <jvmarg value="-Xpatch:${build.classes.dir}" if:set="modules"/>
263          <jvmarg line="@{jvmflags}"/>
264  
265          <!-- ant -Djava.util.concurrent.ForkJoinPool.common.parallelism=1 tck -->
266          <syspropertyset id="system-properties-used-by-tck">
267            <propertyref prefix="java.util.concurrent.ForkJoinPool"/>
268            <propertyref prefix="jsr166."/>
269 +          <propertyref name="test.timeout.factor"/>
270          </syspropertyset>
271  
272          <classpath>
# Line 289 | Line 300
300      </patternset>
301    </fileset>
302  
303 +  <!-- ant -Djtreg.flags=-timeoutFactor:4 -->
304 +  <property name="jtreg.flags" value=""/>
305 +
306    <macrodef name="run-jtreg-tests">
307      <!-- ant -Djtreg9.src.dir=src/test/jtreg/util/concurrent/CompletableFuture jtreg -->
308      <attribute name="source" default="7"/>
# Line 310 | Line 324
324      <delete dir="@{workdir}/JTwork"   quiet="true"/>
325      <delete dir="@{workdir}/JTreport" quiet="true"/>
326      <mkdir dir="@{workdir}/JTwork/scratch"/>
327 <    <mkdir dir="@{workdir}/JTreport"/>
327 >    <!-- workaround for https://bugs.openjdk.java.net/browse/CODETOOLS-7901571 -->
328 >    <mkdir dir="@{workdir}/JTreport/html"/>
329 >    <mkdir dir="@{workdir}/JTreport/text"/>
330      <jtreg dir="${jtreg@{target}.src.dir}"
331             jdk="${jdk@{target}.home}"
332             workDir="@{workdir}/JTwork"
333             reportDir="@{workdir}/JTreport">
334        <patternset refid="jdk@{target}.jtreg.tests"/>
335        <arg value="-Xbootclasspath/p:@{classes}" unless:set="modules"/>
336 <      <arg value="-Xoverride:${build.classes.dir}" if:set="modules"/>
336 >      <arg value="-Xpatch:${build.classes.dir}" if:set="modules"/>
337        <arg value="-agentvm"/>
338        <arg value="-verbose:${jtreg.verbose}"/>
339        <arg value="-vmoptions:-esa -ea"/>
340        <arg value="-automatic"/>
341        <arg value="-k:!ignore"/>
342        <arg line="@{jtregflags}"/>
343 +      <arg line="${jtreg.flags}"/>
344      </jtreg>
345      </sequential>
346    </macrodef>
# Line 343 | Line 360
360    <property name="build.main.javac" value="${javac9}"/>
361  
362    <target name="dists"
363 <          depends="dist, 4jdk7dist, jsr166edist, jsr166ydist, extra166ydist, jsr166xdist"
363 >          depends="dist, 4jdk8dist, 4jdk7dist, jsr166edist, jsr166ydist, extra166ydist, jsr166xdist"
364            description="Builds all public jars and docs"/>
365  
366    <target name="compile"
# Line 386 | Line 403
403        <compilerarg line="${build.args}"/>
404  
405      </javac>
406 +
407 +    <!-- We need jdk9's Contended annotation, but at compile time only -->
408 +    <delete file="${destdir}/jdk/internal/vm/annotation/Contended.class"/>
409    </target>
410  
411  
# Line 417 | Line 437
437               link="${java9.api.url}"
438               overview="${src.dir}/intro.html"
439               access="${build.javadoc.access}"
440 <             sourcepath="${src.dir}:${jdk9src.dir}"
440 >             sourcepath="${src.dir}:${jdk9.src.dir}"
441               classpath=""
442               executable="${javadoc9}">
443        <fileset dir="${src.dir}" defaultexcludes="yes">
# Line 435 | Line 455
455        <arg value="implSpec:a:&lt;em&gt;Implementation Requirements:&lt;/em&gt;"/>
456        <arg value="-tag"/>
457        <arg value="implNote:a:&lt;em&gt;Implementation Note:&lt;/em&gt;"/>
458 + <!-- tags added in jdk9 -->
459 +      <arg value="-tag"/>
460 +      <arg value="revised:X"/>
461 +      <arg value="-tag"/>
462 +      <arg value="spec:X"/>
463      </javadoc>
464    </target>
465  
# Line 596 | Line 621
621         debuglevel="${build.debuglevel}"
622        deprecation="${build.deprecation}"
623             source="${build.sourcelevel}"
624 +           target="${build.sourcelevel}"
625               fork="true">
626  
627        <compilerarg line="${build.args}"/>
# Line 637 | Line 663
663    </target>
664  
665  
666 +  <!-- jsr166 4jdk8 -->
667 +
668 +  <target name="4jdk8compile"
669 +          depends="configure-compiler"
670 +          description="Compiles src/jdk8 sources, targeting jdk8">
671 +
672 +    <mkdir dir="${build.4jdk8.classes.dir}"/>
673 +
674 +    <javac srcdir="${4jdk8src.dir}"
675 +           destdir="${build.4jdk8.classes.dir}"
676 +           debug="${build.debug}"
677 +           debuglevel="${build.debuglevel}"
678 +           deprecation="${build.deprecation}"
679 +           source="8"
680 +           target="8"
681 +           classpath=""
682 +           bootclasspath="${bootclasspath8}"
683 +           includeAntRuntime="false"
684 +           includeJavaRuntime="false"
685 +           executable="${javac8}"
686 +           fork="true">
687 +
688 +      <include name="**/*.java"/>
689 +      <compilerarg value="-Xprefer:source"/>
690 +      <compilerarg value="-XDignore.symbol.file=true"/>
691 +      <compilerarg value="-Xlint:all"/>
692 +      <compilerarg value="-Werror"/>
693 +      <compilerarg line="${build.args}"/>
694 +
695 +    </javac>
696 +  </target>
697 +
698 +  <target name="4jdk8doclint"
699 +          depends="configure-compiler"
700 +          description="Finds doclint warnings">
701 +
702 +    <mkdir dir="${build.4jdk8.classes.dir}"/>
703 +
704 +    <javac srcdir="${4jdk8src.dir}"
705 +           destdir="${build.4jdk8.classes.dir}"
706 +           debug="${build.debug}"
707 +           debuglevel="${build.debuglevel}"
708 +           deprecation="${build.deprecation}"
709 +           source="8"
710 +           target="8"
711 +           classpath=""
712 +           bootclasspath="${bootclasspath8}"
713 +           includeAntRuntime="false"
714 +           includeJavaRuntime="false"
715 +           executable="${javac8}"
716 +           fork="true">
717 +
718 +      <include name="**/*.java"/>
719 +      <compilerarg value="-Xprefer:source"/>
720 +      <compilerarg value="-XDignore.symbol.file=true"/>
721 +      <compilerarg value="-Xlint:all"/>
722 +      <compilerarg value="-Xdoclint:all/protected"/>
723 +      <compilerarg line="${build.args}"/>
724 +
725 +    </javac>
726 +  </target>
727 +
728 +
729 +  <target name="4jdk8jar"
730 +          depends="4jdk8compile"
731 +          description="Builds library jar from compiled sources">
732 +
733 +    <jar destfile="${4jdk8product.jar}">
734 +      <fileset dir="${build.4jdk8.classes.dir}"/>
735 +      <manifest>
736 +        <attribute name="Built-By" value="${user.name}"/>
737 +        <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
738 +      </manifest>
739 +    </jar>
740 +
741 +  </target>
742 +
743 +
744 +  <target name="4jdk8-tck"
745 +          depends="4jdk8jar"
746 +          description="Runs tck tests for jsr166-4jdk8 directly">
747 +
748 +    <run-tck-tests
749 +      target="8"
750 +      workdir="${build.4jdk8.dir}"
751 +      classes="${4jdk8product.jar}">
752 +      <javac-elements>
753 +        <!-- JDK9+ test classes -->
754 +        <exclude name="*9Test.java"/>
755 +        <exclude name="*10Test.java"/>
756 +      </javac-elements>
757 +    </run-tck-tests>
758 +  </target>
759 +
760 +
761 +  <target name="4jdk8-jtreg"
762 +          depends="4jdk8jar"
763 +          description="Runs jtreg tests for jsr166-4jdk8 using the jtreg ant task">
764 +    <run-jtreg-tests
765 +       target="8"
766 +       workdir="${build.4jdk8.dir}"
767 +       classes="${4jdk8product.jar}"/>
768 +  </target>
769 +
770 +
771 +  <target name="4jdk8-test"
772 +          depends="4jdk8-tck, 4jdk8-jtreg"
773 +          description="Runs tck and jtreg tests for jsr166-4jdk8">
774 +  </target>
775 +
776 +
777 +  <target name="4jdk8docs"
778 +          description="Builds javadocs for src/jdk8 to dist dir">
779 +
780 +    <delete dir="${4jdk8docs.dir}"/>
781 +    <mkdir dir="${4jdk8docs.dir}"/>
782 +
783 +    <javadoc destdir="${4jdk8docs.dir}"
784 +             packagenames="none"
785 +             link="${java8.api.url}"
786 +             overview="${4jdk8src.dir}/intro.html"
787 +             access="${build.javadoc.access}"
788 +             sourcepath="${4jdk8src.dir}:${jdk8.src.dir}"
789 +             classpath=""
790 +             executable="${javadoc8}">
791 +      <fileset dir="${4jdk8src.dir}" defaultexcludes="yes">
792 +        <include name="**/*.java"/>
793 +      </fileset>
794 +      <arg line="-Xdocrootparent ${java8.docroot.url}"/>
795 +      <arg value="-XDignore.symbol.file=true"/>
796 +      <arg value="-tag"/>
797 +      <arg value="${javadoc.jls.option}"/>
798 +      <arg value="-tag"/>
799 +      <arg value="apiNote:a:&lt;em&gt;API Note:&lt;/em&gt;"/>
800 +      <arg value="-tag"/>
801 +      <arg value="implSpec:a:&lt;em&gt;Implementation Requirements:&lt;/em&gt;"/>
802 +      <arg value="-tag"/>
803 +      <arg value="implNote:a:&lt;em&gt;Implementation Note:&lt;/em&gt;"/>
804 +    </javadoc>
805 +  </target>
806 +
807 +
808 +  <target name="4jdk8dist"
809 +          depends="4jdk8dist-jar, 4jdk8dist-docs"
810 +          description="Puts all distributable products in single hierarchy"/>
811 +
812 +
813 +  <target name="4jdk8clean"
814 +          description="Removes all 4jdk8 build products">
815 +
816 +    <delete dir="${build.4jdk8.dir}"/>
817 +
818 +  </target>
819 +
820 +
821 +  <target name="4jdk8dist-jar"
822 +          depends="4jdk8clean, 4jdk8jar">
823 +    <copy file="${4jdk8product.jar}" todir="${dist.dir}"/>
824 +  </target>
825 +
826 +
827 +  <target name="4jdk8dist-docs"
828 +          depends="4jdk8clean, 4jdk8docs">
829 +    <mirror-dir src="${4jdk8docs.dir}" dst="${dist.4jdk8docs.dir}"/>
830 +  </target>
831 +
832 +
833 +
834    <!-- jsr166 4jdk7 -->
835  
836    <target name="4jdk7compile"
# Line 651 | Line 845
845             debuglevel="${build.debuglevel}"
846             deprecation="${build.deprecation}"
847             source="6"
848 +           target="6"
849             classpath=""
850             bootclasspath="${bootclasspath6}"
851             includeAntRuntime="false"
# Line 680 | Line 875
875             debuglevel="${build.debuglevel}"
876             deprecation="${build.deprecation}"
877             source="6"
878 +           target="6"
879             classpath=""
880 <           bootclasspath="${bootclasspath7}"
880 >           bootclasspath="${bootclasspath6}"
881             includeAntRuntime="false"
882             includeJavaRuntime="false"
883             executable="${javac8}"
# Line 794 | Line 990
990               link="${java7.api.url}"
991               overview="${4jdk7src.dir}/intro.html"
992               access="${build.javadoc.access}"
993 <             sourcepath="${4jdk7src.dir}:${jdk7src.dir}"
993 >             sourcepath="${4jdk7src.dir}:${jdk7.src.dir}"
994               classpath=""
995               executable="${javadoc7}">
996        <fileset dir="${4jdk7src.dir}" defaultexcludes="yes">
# Line 847 | Line 1043
1043             classpath=""
1044             bootclasspath="${bootclasspath6}"
1045             source="5"
1046 +           target="5"
1047             includeAntRuntime="false"
1048             includeJavaRuntime="false"
1049             executable="${javac7}"
# Line 887 | Line 1084
1084               packagenames="jsr166x.*"
1085               link="${java.api.url}"
1086               access="${build.javadoc.access}"
1087 <             sourcepath="${topsrc.dir}:${jdk6src.dir}"
1087 >             sourcepath="${topsrc.dir}:${jdk6.src.dir}"
1088               bootclasspath="${bootclasspath6}"
1089               source="5"
1090               executable="${javadoc7}">
# Line 979 | Line 1176
1176               packagenames="jsr166y.*"
1177               link="${java.api.url}"
1178               access="${build.javadoc.access}"
1179 <             sourcepath="${topsrc.dir}:${jdk6src.dir}"
1179 >             sourcepath="${topsrc.dir}:${jdk6.src.dir}"
1180               bootclasspath="${bootclasspath6}"
1181               source="6"
1182               executable="${javadoc7}">
# Line 1031 | Line 1228
1228             bootclasspath="@{jsr166y.jar}:${bootclasspath6}"
1229             classpath=""
1230             source="6"
1231 +           target="6"
1232             includeAntRuntime="false"
1233             includeJavaRuntime="false"
1234             executable="${javac7}"
# Line 1071 | Line 1269
1269               packagenames="extra166y.*"
1270               link="${java.api.url}"
1271               access="${build.javadoc.access}"
1272 <             sourcepath="${topsrc.dir}:${jdk6src.dir}"
1272 >             sourcepath="${topsrc.dir}:${jdk6.src.dir}"
1273               bootclasspath="${bootclasspath6}"
1274               source="6"
1275               executable="${javadoc7}">
# Line 1122 | Line 1320
1320             debuglevel="${build.debuglevel}"
1321             deprecation="${build.deprecation}"
1322             source="${build.jsr166e.java.version}"
1323 +           target="${build.jsr166e.java.version}"
1324             classpath=""
1325             includeAntRuntime="false"
1326             includeJavaRuntime="false"
# Line 1148 | Line 1347
1347             debuglevel="${build.debuglevel}"
1348             deprecation="${build.deprecation}"
1349             source="${build.jsr166e.java.version}"
1350 +           target="${build.jsr166e.java.version}"
1351             classpath=""
1352 <           bootclasspath="${bootclasspath7}"
1352 >           bootclasspath="${bootclasspath6}"
1353             includeAntRuntime="false"
1354             includeJavaRuntime="false"
1355             executable="${javac8}"
# Line 1190 | Line 1390
1390               packagenames="jsr166e.*"
1391               link="${java.api.url}"
1392               access="${build.javadoc.access}"
1393 <             sourcepath="${topsrc.dir}:${jdk6src.dir}"
1393 >             sourcepath="${topsrc.dir}:${jdk6.src.dir}"
1394               source="${build.jsr166e.java.version}"
1395               executable="${javadoc7}">
1396        <arg line="-Xdocrootparent ${java.docroot.url}"/>

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines