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.126 by jsr166, Wed Jan 23 06:46:27 2013 UTC vs.
Revision 1.137 by jsr166, Wed Feb 6 19:55:06 2013 UTC

# Line 22 | Line 22
22    $HOME/jdk/src/jdk8
23    where each of the above is a complete JDK source tree
24    (e.g. mercurial forest) or a symlink to same.
25 + As of 2013-02, the very latest lambda 8 jdk is needed for jdk8.
26   ------------------------------------------------------------------------------
27    </description>
28  
29 <  <target name="usage" description="Advises user to run with -projecthelp">
30 <    <echo>Run "ant -projecthelp" for full usage information.</echo>
29 >  <target name="usage" description="Display main targets by running 'ant -projecthelp'">
30 >    <java classname="org.apache.tools.ant.Main">
31 >      <arg value="-projecthelp" />
32 >    </java>
33    </target>
34  
35  
# Line 39 | Line 42
42    <property name="build.debug"          value="true"/>
43    <property name="build.debuglevel"     value="source,lines,vars"/>
44    <property name="build.deprecation"    value="false"/>
45 +  <property name="build.javadoc.access" value="protected"/>
46  
47    <!-- Build locations -->
48    <property name="build.dir"                   location="build"/>
# Line 118 | Line 122
122    <property name="extra166ysrc.dir"     location="${topsrc.dir}/extra166y"/>
123  
124    <!-- Javadoc locations -->
125 <  <property name="javadocs.dir"          location="${build.dir}/javadocs"/>
126 <  <property name="4jdk7javadocs.dir"     location="${build.4jdk7.dir}/javadocs"/>
127 <  <property name="jsr166xjavadocs.dir"   location="${build.jsr166x.dir}/javadocs"/>
128 <  <property name="jsr166yjavadocs.dir"   location="${build.jsr166y.dir}/javadocs"/>
129 <  <property name="jsr166ejavadocs.dir"   location="${build.jsr166e.dir}/javadocs"/>
130 <  <property name="extra166yjavadocs.dir" location="${build.extra166y.dir}/javadocs"/>
131 <
132 <  <property name="dist.javadocs.dir"          location="${dist.dir}/docs"/>
133 <  <property name="dist.4jdk7javadocs.dir"     location="${dist.dir}/jsr166-4jdk7docs"/>
134 <  <property name="dist.jsr166xjavadocs.dir"   location="${dist.dir}/jsr166xdocs"/>
135 <  <property name="dist.jsr166yjavadocs.dir"   location="${dist.dir}/jsr166ydocs"/>
136 <  <property name="dist.jsr166ejavadocs.dir"   location="${dist.dir}/jsr166edocs"/>
137 <  <property name="dist.extra166yjavadocs.dir" location="${dist.dir}/extra166ydocs"/>
125 >  <property name="docs.dir"          location="${build.dir}/docs"/>
126 >  <property name="4jdk7docs.dir"     location="${build.4jdk7.dir}/docs"/>
127 >  <property name="jsr166xdocs.dir"   location="${build.jsr166x.dir}/docs"/>
128 >  <property name="jsr166ydocs.dir"   location="${build.jsr166y.dir}/docs"/>
129 >  <property name="jsr166edocs.dir"   location="${build.jsr166e.dir}/docs"/>
130 >  <property name="extra166ydocs.dir" location="${build.extra166y.dir}/docs"/>
131 >
132 >  <property name="dist.docs.dir"          location="${dist.dir}/docs"/>
133 >  <property name="dist.4jdk7docs.dir"     location="${dist.dir}/jsr166-4jdk7docs"/>
134 >  <property name="dist.jsr166xdocs.dir"   location="${dist.dir}/jsr166xdocs"/>
135 >  <property name="dist.jsr166ydocs.dir"   location="${dist.dir}/jsr166ydocs"/>
136 >  <property name="dist.jsr166edocs.dir"   location="${dist.dir}/jsr166edocs"/>
137 >  <property name="dist.extra166ydocs.dir" location="${dist.dir}/extra166ydocs"/>
138  
139    <!-- Jar locations -->
140    <property name="product.jar"      location="${build.dir}/jsr166.jar"/>
# Line 171 | Line 175
175      <attribute name="workdir"/>
176      <attribute name="classes"/>
177      <attribute name="jvmflags" default=""/>
178 +    <element name="javac-elements" optional="true"/>
179      <sequential>
180  
181      <mkdir dir="@{workdir}/tck-classes"/>
# Line 192 | Line 197
197        <compilerarg value="-XDignore.symbol.file=true"/>
198        <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
199        <compilerarg line="${build.args}"/>
200 +      <javac-elements/>
201  
202      </javac>
203  
# Line 210 | Line 216
216      </sequential>
217    </macrodef>
218  
219 +  <macrodef name="run-jtreg-tests">
220 +    <attribute name="jtreg.src.dir" default="${jtreg.src.dir}"/>
221 +    <attribute name="source" default="7"/>
222 +    <attribute name="target"/>
223 +    <attribute name="workdir"/>
224 +    <attribute name="classes"/>
225 +    <attribute name="jtregflags" default=""/>
226 +    <sequential>
227 +    <delete dir="@{workdir}/JTwork"   quiet="true"/>
228 +    <delete dir="@{workdir}/JTreport" quiet="true"/>
229 +    <mkdir dir="@{workdir}/JTwork/scratch"/>
230 +    <mkdir dir="@{workdir}/JTreport"/>
231 +    <jtreg dir="@{jtreg.src.dir}"
232 +           jdk="${jdk@{target}.home}"
233 +           workDir="@{workdir}/JTwork"
234 +           reportDir="@{workdir}/JTreport">
235 +
236 +      <arg value="-Xbootclasspath/p:@{classes}"/>
237 +      <arg value="-agentvm"/>
238 +      <arg value="-v:nopass,fail"/>
239 +      <arg value="-vmoptions:-esa -ea"/>
240 +      <arg value="-automatic"/>
241 +      <arg value="-k:!ignore"/>
242 +      <arg line="@{jtregflags}"/>
243 +    </jtreg>
244 +    </sequential>
245 +  </macrodef>
246 +
247    <!-- ALoops classpath -->
248    <path id="loops.classpath">
249      <pathelement location="${build.loops.dir}"/>
# Line 243 | Line 277
277             fork="true">
278  
279        <include name="**/*.java"/>
280 +      <compilerarg value="-Xprefer:source"/>
281        <compilerarg value="-XDignore.symbol.file=true"/>
282        <compilerarg value="-Xlint:all"/>
283        <compilerarg line="${build.args}"/>
# Line 269 | Line 304
304    <target name="docs"
305            description="Builds javadocs for src/main to dist dir">
306  
307 <    <delete dir="${javadocs.dir}"/>
308 <    <mkdir dir="${javadocs.dir}"/>
307 >    <delete dir="${docs.dir}"/>
308 >    <mkdir dir="${docs.dir}"/>
309  
310      <!-- the packagenames="none" hack below prevents scanning the -->
311      <!-- sourcepath for packages -->
312  
313 <    <javadoc destdir="${javadocs.dir}"
313 >    <javadoc destdir="${docs.dir}"
314               packagenames="none"
315               link="${jdkapi8docs.url}"
316               overview="${src.dir}/intro.html"
317 +             access="${build.javadoc.access}"
318               sourcepath="${src.dir}:${jdk8src.dir}"
319               classpath=""
320               executable="${javadoc8}">
# Line 341 | Line 377
377  
378    <target name="dist-docs"
379            depends="clean, docs">
380 <    <mirror-dir src="${javadocs.dir}" dst="${dist.javadocs.dir}"/>
380 >    <mirror-dir src="${docs.dir}" dst="${dist.docs.dir}"/>
381    </target>
382  
383  
# Line 408 | Line 444
444  
445    </target>
446  
447 +  <target name="test-tck"
448 +          depends="jar"
449 +          description="Runs tck tests for main directly">
450 +
451 +    <run-tck-tests
452 +      target="8"
453 +      workdir="${build.dir}"
454 +      classes="${product.jar}"/>
455 +  </target>
456 +
457 +  <target name="test-jtreg"
458 +          depends="jar"
459 +          description="Runs jtreg tests for main using the jtreg ant task">
460 +    <run-jtreg-tests
461 +       target="8"
462 +       workdir="${build.dir}"
463 +       classes="${product.jar}"/>
464 +  </target>
465 +
466 +  <target name="test-ng"
467 +          depends="test-tck, test-jtreg"
468 +          description="Runs tck and jtreg tests for main">
469 +  </target>
470  
471    <target name="run-tests"
472            depends="compile-tests">
# Line 574 | Line 633
633             fork="true">
634  
635        <include name="**/*.java"/>
636 +      <compilerarg value="-Xprefer:source"/>
637        <compilerarg value="-XDignore.symbol.file=true"/>
638        <compilerarg value="-Xlint:all"/>
639        <compilerarg line="${build.args}"/>
# Line 582 | Line 642
642    </target>
643  
644  
645 <  <target name="4jdk7-jar"
645 >  <target name="4jdk7jar"
646            depends="4jdk7compile"
647            description="Builds library jar from compiled sources">
648  
# Line 594 | Line 654
654  
655  
656    <target name="4jdk7-test-tck"
657 <          depends="4jdk7-jar"
657 >          depends="4jdk7jar"
658            description="Runs tck tests for jsr166-4jdk7 directly">
659  
660      <run-tck-tests
661        target="7"
662        workdir="${build.4jdk7.dir}"
663 <      classes="${4jdk7product.jar}"/>
663 >      classes="${4jdk7product.jar}">
664 >      <javac-elements>
665 >        <!-- JDK8+ test classes -->
666 >        <exclude name="*8Test.java"/>
667 >        <exclude name="CompletableFutureTest.java"/>
668 >        <exclude name="StampedLockTest.java"/>
669 >      </javac-elements>
670 >    </run-tck-tests>
671    </target>
672  
673  
# Line 633 | Line 700
700    </target>
701  
702    <target name="4jdk7-test-jtreg"
703 <          depends="4jdk7compile"
703 >          depends="4jdk7jar"
704            description="Runs jtreg tests for jsr166-4jdk7 using the jtreg ant task">
705 <    <delete dir="${build.4jdk7.dir}/JTwork"   quiet="true"/>
706 <    <delete dir="${build.4jdk7.dir}/JTreport" quiet="true"/>
707 <    <mkdir dir="${build.4jdk7.dir}/JTwork/scratch"/>
708 <    <mkdir dir="${build.4jdk7.dir}/JTreport"/>
642 <    <jtreg dir="${jtreg.src.dir}"
643 <           jdk="${jdk7.home}"
644 <           workDir="${build.4jdk7.dir}/JTwork"
645 <           reportDir="${build.4jdk7.dir}/JTreport">
646 <
647 <      <arg value="-Xbootclasspath/p:${4jdk7product.jar}"/>
648 <      <arg value="-agentvm"/>
649 <      <arg value="-v:nopass,fail"/>
650 <      <arg value="-vmoptions:-esa -ea"/>
651 <      <arg value="-automatic"/>
652 <      <arg value="-k:!ignore"/>
653 <    </jtreg>
705 >    <run-jtreg-tests
706 >       target="7"
707 >       workdir="${build.4jdk7.dir}"
708 >       classes="${4jdk7product.jar}"/>
709    </target>
710  
711  
# Line 663 | Line 718
718    <target name="4jdk7docs"
719            description="Builds javadocs for src/jdk7 to dist dir">
720  
721 <    <delete dir="${4jdk7javadocs.dir}"/>
722 <    <mkdir dir="${4jdk7javadocs.dir}"/>
721 >    <delete dir="${4jdk7docs.dir}"/>
722 >    <mkdir dir="${4jdk7docs.dir}"/>
723  
724 <    <javadoc destdir="${4jdk7javadocs.dir}"
724 >    <javadoc destdir="${4jdk7docs.dir}"
725               packagenames="none"
726               link="${jdkapi7docs.url}"
727               overview="${4jdk7src.dir}/intro.html"
728 +             access="${build.javadoc.access}"
729               sourcepath="${4jdk7src.dir}:${jdk7src.dir}"
730               classpath=""
731               executable="${javadoc7}">
# Line 700 | Line 756
756    </target>
757  
758    <target name="4jdk7dist-jar"
759 <          depends="4jdk7clean, 4jdk7-jar">
759 >          depends="4jdk7clean, 4jdk7jar">
760      <copy file="${4jdk7product.jar}" todir="${dist.dir}"/>
761    </target>
762  
763  
764    <target name="4jdk7dist-docs"
765            depends="4jdk7clean, 4jdk7docs">
766 <    <mirror-dir src="${4jdk7javadocs.dir}" dst="${dist.4jdk7javadocs.dir}"/>
766 >    <mirror-dir src="${4jdk7docs.dir}" dst="${dist.4jdk7docs.dir}"/>
767    </target>
768  
769  
# Line 741 | Line 797
797    </target>
798  
799  
800 <  <target name="jsr166x-jar"
800 >  <target name="jsr166xjar"
801            depends="jsr166xcompile"
802            description="Builds library jar from compiled sources">
803  
# Line 755 | Line 811
811    <target name="jsr166xdocs"
812            description="Builds javadocs to dist dir">
813  
814 <    <delete dir="${jsr166xjavadocs.dir}"/>
815 <    <mkdir dir="${jsr166xjavadocs.dir}"/>
814 >    <delete dir="${jsr166xdocs.dir}"/>
815 >    <mkdir dir="${jsr166xdocs.dir}"/>
816  
817 <    <javadoc destdir="${jsr166xjavadocs.dir}"
817 >    <javadoc destdir="${jsr166xdocs.dir}"
818               packagenames="jsr166x.*"
819               link="${jdkapidocs.url}"
820 +             access="${build.javadoc.access}"
821               sourcepath="${topsrc.dir}:${jdk6src.dir}"
822               bootclasspath="${bootclasspath6}"
823               source="5"
# Line 791 | Line 848
848  
849  
850    <target name="jsr166xdist-jar"
851 <          depends="jsr166xclean, jsr166x-jar">
851 >          depends="jsr166xclean, jsr166xjar">
852      <copy file="${jsr166x.jar}" todir="${dist.dir}"/>
853    </target>
854  
855    <target name="jsr166xdist-docs"
856            depends="jsr166xclean, jsr166xdocs">
857 <    <mirror-dir src="${jsr166xjavadocs.dir}" dst="${dist.jsr166xjavadocs.dir}"/>
857 >    <mirror-dir src="${jsr166xdocs.dir}" dst="${dist.jsr166xdocs.dir}"/>
858    </target>
859  
860    <!-- jsr166y -->
# Line 831 | Line 888
888    </target>
889  
890  
891 <  <target name="jsr166y-jar"
891 >  <target name="jsr166yjar"
892            depends="jsr166ycompile"
893            description="Builds library jar from compiled sources">
894  
# Line 845 | Line 902
902    <target name="jsr166ydocs"
903            description="Builds javadocs to dist dir">
904  
905 <    <delete dir="${jsr166yjavadocs.dir}"/>
906 <    <mkdir dir="${jsr166yjavadocs.dir}"/>
905 >    <delete dir="${jsr166ydocs.dir}"/>
906 >    <mkdir dir="${jsr166ydocs.dir}"/>
907  
908 <    <javadoc destdir="${jsr166yjavadocs.dir}"
908 >    <javadoc destdir="${jsr166ydocs.dir}"
909               packagenames="jsr166y.*"
910               link="${jdkapidocs.url}"
911 +             access="${build.javadoc.access}"
912               sourcepath="${topsrc.dir}:${jdk6src.dir}"
913               bootclasspath="${bootclasspath6}"
914               source="6"
# Line 880 | Line 938
938    </target>
939  
940    <target name="jsr166ydist-jar"
941 <          depends="jsr166yclean, jsr166y-jar">
941 >          depends="jsr166yclean, jsr166yjar">
942      <copy file="${jsr166y.jar}" todir="${dist.dir}"/>
943    </target>
944  
945    <target name="jsr166ydist-docs"
946            depends="jsr166yclean, jsr166ydocs">
947 <    <mirror-dir src="${jsr166yjavadocs.dir}" dst="${dist.jsr166yjavadocs.dir}"/>
947 >    <mirror-dir src="${jsr166ydocs.dir}" dst="${dist.jsr166ydocs.dir}"/>
948    </target>
949  
950  
# Line 894 | Line 952
952  
953  
954    <target name="extra166ycompile"
955 <          depends="configure-compiler, jsr166y-jar"
955 >          depends="configure-compiler, jsr166yjar"
956            description="Compiles extra166y sources">
957  
958      <mkdir dir="${build.extra166y.classes.dir}"/>
# Line 921 | Line 979
979    </target>
980  
981  
982 <  <target name="extra166y-jar"
982 >  <target name="extra166yjar"
983            depends="extra166ycompile"
984            description="Builds library jar from compiled sources">
985  
# Line 935 | Line 993
993    <target name="extra166ydocs"
994            description="Builds javadocs to build dir">
995  
996 <    <delete dir="${extra166yjavadocs.dir}"/>
997 <    <mkdir dir="${extra166yjavadocs.dir}"/>
996 >    <delete dir="${extra166ydocs.dir}"/>
997 >    <mkdir dir="${extra166ydocs.dir}"/>
998  
999 <    <javadoc destdir="${extra166yjavadocs.dir}"
999 >    <javadoc destdir="${extra166ydocs.dir}"
1000               packagenames="extra166y.*"
1001               link="${jdkapidocs.url}"
1002 +             access="${build.javadoc.access}"
1003               sourcepath="${topsrc.dir}:${jdk6src.dir}"
1004               bootclasspath="${bootclasspath6}"
1005               source="6"
# Line 970 | Line 1029
1029    </target>
1030  
1031    <target name="extra166ydist-jar"
1032 <          depends="extra166yclean, extra166y-jar">
1032 >          depends="extra166yclean, extra166yjar">
1033      <copy file="${extra166y.jar}" todir="${dist.dir}"/>
1034    </target>
1035  
1036    <target name="extra166ydist-docs"
1037            depends="extra166yclean, extra166ydocs">
1038 <    <mirror-dir src="${extra166yjavadocs.dir}" dst="${dist.extra166yjavadocs.dir}"/>
1038 >    <mirror-dir src="${extra166ydocs.dir}" dst="${dist.extra166ydocs.dir}"/>
1039    </target>
1040  
1041    <!-- jsr166e -->
# Line 1008 | Line 1067
1067    </target>
1068  
1069  
1070 <  <target name="jsr166e-jar"
1070 >  <target name="jsr166ejar"
1071            depends="jsr166ecompile"
1072            description="Builds library jar from compiled sources">
1073  
# Line 1022 | Line 1081
1081    <target name="jsr166edocs"
1082            description="Builds javadocs to build dir">
1083  
1084 <    <delete dir="${jsr166ejavadocs.dir}"/>
1085 <    <mkdir dir="${jsr166ejavadocs.dir}"/>
1084 >    <delete dir="${jsr166edocs.dir}"/>
1085 >    <mkdir dir="${jsr166edocs.dir}"/>
1086  
1087 <    <javadoc destdir="${jsr166ejavadocs.dir}"
1087 >    <javadoc destdir="${jsr166edocs.dir}"
1088               packagenames="jsr166e.*"
1089               link="${jdkapidocs.url}"
1090 +             access="${build.javadoc.access}"
1091               sourcepath="${topsrc.dir}:${jdk7src.dir}"
1092               source="7"
1093               executable="${javadoc7}">
# Line 1038 | Line 1098
1098  
1099  
1100    <target name="jsr166e-test-tck"
1101 <          depends="jsr166e-jar"
1101 >          depends="jsr166ejar"
1102            description="Runs tck tests for jsr166e">
1103  
1104      <run-tck-tests
# Line 1067 | Line 1127
1127    </target>
1128  
1129    <target name="jsr166edist-jar"
1130 <          depends="jsr166eclean, jsr166e-jar">
1130 >          depends="jsr166eclean, jsr166ejar">
1131      <copy file="${jsr166e.jar}" todir="${dist.dir}"/>
1132    </target>
1133  
1134    <target name="jsr166edist-docs"
1135            depends="jsr166eclean, jsr166edocs">
1136 <    <mirror-dir src="${jsr166ejavadocs.dir}" dst="${dist.jsr166ejavadocs.dir}"/>
1136 >    <mirror-dir src="${jsr166edocs.dir}" dst="${dist.jsr166edocs.dir}"/>
1137 >  </target>
1138 >
1139 >
1140 > <!-- Find buglets that can be detected by static build tools -->
1141 >
1142 >  <target name="lint">
1143 >    <antcall target="dists">
1144 >      <param name="build.javadoc.access" value="private"/>
1145 >    </antcall>
1146    </target>
1147  
1148 +
1149   </project>

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines