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.81 by jsr166, Sun Aug 2 00:11:59 2009 UTC vs.
Revision 1.118 by jsr166, Mon Jan 21 01:05:01 2013 UTC

# Line 8 | Line 8
8  
9    User-specific settings are read from user.properties.
10    See user.properties.sample for an explanation of some useful settings.
11 +
12 +  The repository contains all dependencies except for ant and the JDK
13 +  itself.  Because the JDK version matters and because different
14 +  targets require different JDKs, we assume that users have created a
15 +  hierarchy containing:
16 +  $HOME/jdk/jdk6
17 +  $HOME/jdk/jdk7
18 +  $HOME/jdk/jdk8
19 +  where each of the above is a JDK or a symlink to same, and
20 +  $HOME/jdk/src/jdk6
21 +  $HOME/jdk/src/jdk7
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   ------------------------------------------------------------------------------
26    </description>
27  
# Line 21 | Line 35
35  
36  
37    <!-- Compilation options -->
38 <  <property name="build.sourcelevel"    value="1.6"/>
38 >  <property name="build.sourcelevel"    value="6"/>
39    <property name="build.debug"          value="true"/>
40    <property name="build.debuglevel"     value="source,lines,vars"/>
41    <property name="build.deprecation"    value="false"/>
# Line 31 | Line 45
45    <property name="build.classes.dir"           location="${build.dir}/classes"/>
46    <property name="build.testcases.dir"         location="${build.dir}/testcases"/>
47    <property name="build.loops.dir"             location="${build.dir}/loops"/>
34  <property name="build.lib.dir"               location="${build.dir}/lib"/>
35  <property name="build.javadocs.dir"          location="${build.dir}/javadocs"/>
48    <property name="build.reports.dir"           location="${build.dir}/reports"/>
37  <property name="build.jsr166x.dir"           location="${build.dir}/jsr166x"/>
38  <property name="build.jsr166xlib.dir"        location="${build.dir}/jsr166xlib"/>
39  <property name="build.jsr166xjavadocs.dir"   location="${build.dir}/jsr166xjavadocs"/>
49  
50 <  <property name="build.jsr166y.dir"           location="${build.dir}/jsr166y"/>
51 <  <property name="build.jsr166ylib.dir"        location="${build.dir}/jsr166ylib"/>
52 <  <property name="build.jsr166yjavadocs.dir"   location="${build.dir}/jsr166yjavadocs"/>
50 >  <property name="build.4jdk7.dir"             location="${build.dir}/jsr166-4jdk7"/>
51 >  <property name="build.4jdk7.classes.dir"     location="${build.4jdk7.dir}/classes"/>
52 >  <property name="build.4jdk7.tck.classes.dir" location="${build.4jdk7.dir}/tck-classes"/>
53 >  <property name="build.4jdk7.docs.dir"        location="${build.4jdk7.dir}/docs"/>
54  
55 +  <property name="build.jsr166x.dir"           location="${build.dir}/jsr166x"/>
56 +  <property name="build.jsr166y.dir"           location="${build.dir}/jsr166y"/>
57 +  <property name="build.jsr166e.dir"           location="${build.dir}/jsr166e"/>
58    <property name="build.extra166y.dir"         location="${build.dir}/extra166y"/>
59 <  <property name="build.extra166ylib.dir"      location="${build.dir}/extra166ylib"/>
60 <  <property name="build.extra166yjavadocs.dir" location="${build.dir}/extra166yjavadocs"/>
59 >
60 >  <property name="build.jsr166x.classes.dir"    location="${build.jsr166x.dir}/classes"/>
61 >  <property name="build.jsr166y.classes.dir"    location="${build.jsr166y.dir}/classes"/>
62 >  <property name="build.jsr166e.classes.dir"    location="${build.jsr166e.dir}/classes"/>
63 >  <property name="build.extra166y.classes.dir"  location="${build.extra166y.dir}/classes"/>
64 >
65 >  <!-- JDK locations -->
66 >  <property name="jdks.home"  location="${user.home}/jdk"/>
67 >
68 >  <macrodef name="defjdklocations">
69 >    <attribute name="v"/>
70 >    <sequential>
71 >    <property name="jdk@{v}.home"   location="${jdks.home}/jdk@{v}"/>
72 >    <property name="java@{v}"       location="${jdk@{v}.home}/bin/java"/>
73 >    <property name="javac@{v}"      location="${jdk@{v}.home}/bin/javac"/>
74 >    <property name="javadoc@{v}"    location="${jdk@{v}.home}/bin/javadoc"/>
75 >    <property name="jdk@{v}src.dir" location="${jdks.home}/src/jdk@{v}/jdk/src/share/classes"/>
76 >    <local name="boot.jar.dir"/>
77 >    <property name="boot.jar.dir"   location="${jdk@{v}.home}/jre/lib"/>
78 >    <path id="bootclasspath@{v}">
79 >      <pathelement path="${boot.jar.dir}/resources.jar"/>
80 >      <pathelement path="${boot.jar.dir}/rt.jar"/>
81 >      <pathelement path="${boot.jar.dir}/jsse.jar"/>
82 >      <pathelement path="${boot.jar.dir}/jce.jar"/>
83 >      <pathelement path="${boot.jar.dir}/charsets.jar"/>
84 >    </path>
85 >    <property name="bootclasspath@{v}" value="${toString:bootclasspath@{v}}"/>
86 >    </sequential>
87 >  </macrodef>
88 >
89 >  <defjdklocations v="6"/>
90 >  <defjdklocations v="7"/>
91 >  <defjdklocations v="8"/>
92  
93    <!-- Source locations -->
94    <property name="src.dir"              location="${basedir}/src/main"/>
# Line 55 | Line 99
99    <property name="lib.dir"              location="${basedir}/lib"/>
100    <property name="dist.dir"             location="${basedir}/dist"/>
101    <property name="topsrc.dir"           location="${basedir}/src"/>
102 <  <property name="jsr166xsrc.dir"       location="${basedir}/src/jsr166x"/>
103 <  <property name="jsr166ysrc.dir"       location="${basedir}/src/jsr166y"/>
104 <  <property name="extra166ysrc.dir"     location="${basedir}/src/extra166y"/>
105 <  <property name="jdksrc.dir"           location="/home/dl/1.6.0/j2se/martin/j2se/src/share/classes"/>
102 >  <property name="4jdk7src.dir"         location="${topsrc.dir}/jdk7"/>
103 >  <property name="jsr166xsrc.dir"       location="${topsrc.dir}/jsr166x"/>
104 >  <property name="jsr166ysrc.dir"       location="${topsrc.dir}/jsr166y"/>
105 >  <property name="jsr166esrc.dir"       location="${topsrc.dir}/jsr166e"/>
106 >  <property name="extra166ysrc.dir"     location="${topsrc.dir}/extra166y"/>
107 >
108    <!-- Distribution locations -->
109 <  <property name="dist.javadocs.dir"           location="${dist.dir}/docs"/>
110 <  <property name="dist.jsr166xjavadocs.dir"    location="${dist.dir}/jsr166xdocs"/>
111 <  <property name="dist.jsr166yjavadocs.dir"    location="${dist.dir}/jsr166ydocs"/>
112 <  <property name="dist.extra166yjavadocs.dir"  location="${dist.dir}/extra166ydocs"/>
109 >  <property name="dist.javadocs.dir"          location="${dist.dir}/jsr166.docs"/>
110 >  <property name="dist.4jdk7.docs.dir"        location="${dist.dir}/jsr166-4jdk7.docs"/>
111 >  <property name="dist.jsr166xjavadocs.dir"   location="${dist.dir}/jsr166x.docs"/>
112 >  <property name="dist.jsr166yjavadocs.dir"   location="${dist.dir}/jsr166y.docs"/>
113 >  <property name="dist.jsr166ejavadocs.dir"   location="${dist.dir}/jsr166e.docs"/>
114 >  <property name="dist.extra166yjavadocs.dir" location="${dist.dir}/extra166y.docs"/>
115  
116    <!-- Jar locations -->
117 <  <property name="product.jar"          location="${build.lib.dir}/jsr166.jar"/>
118 <  <property name="jsr166xproduct.jar"   location="${build.jsr166xlib.dir}/jsr166x.jar"/>
119 <  <property name="jsr166yproduct.jar"   location="${build.jsr166ylib.dir}/jsr166y.jar"/>
120 <  <property name="extra166yproduct.jar" location="${build.extra166ylib.dir}/extra166y.jar"/>
121 <  <property name="junit.jar"            location="${lib.dir}/junit.jar"/>
122 <
123 <  <!-- Bootclasspath argument -->
124 <  <property name="bootclasspath.args"   value="-Xbootclasspath/p:${product.jar}"/>
117 >  <property name="product.jar"      location="${build.dir}/jsr166.jar"/>
118 >  <property name="4jdk7product.jar" location="${build.4jdk7.dir}/jsr166-4jdk7.jar"/>
119 >  <property name="jsr166x.jar"      location="${build.jsr166x.dir}/jsr166x.jar"/>
120 >  <property name="jsr166y.jar"      location="${build.jsr166y.dir}/jsr166y.jar"/>
121 >  <property name="jsr166e.jar"      location="${build.jsr166e.dir}/jsr166e.jar"/>
122 >  <property name="extra166y.jar"    location="${build.extra166y.dir}/extra166y.jar"/>
123 >  <property name="junit.jar"        location="${lib.dir}/junit.jar"/>
124 >
125 >  <!-- Canonical location of jdk API docs, to use with javadoc link attribute -->
126 >  <property name="jdkapi5docs.url"      value="http://docs.oracle.com/javase/1.5.0/docs/api/"/>
127 >  <property name="jdkapi6docs.url"      value="http://docs.oracle.com/javase/6/docs/api/"/>
128 >  <property name="jdkapi7docs.url"      value="http://docs.oracle.com/javase/7/docs/api/"/>
129 >
130 >  <property name="jdkapi8docs.url"      value="http://download.java.net/jdk8/docs/api/"/>
131 >  <!-- The below does not yet exist as of 2012-11 -->
132 >  <!-- <property name="jdkapi8docs.url" value="http://docs.oracle.com/javase/8/docs/api/"/> -->
133 >
134 >  <!-- Default jdk api doc location (latest stable release seems best) -->
135 >  <property name="jdkapidocs.url"       value="${jdkapi7docs.url}"/>
136 >
137 >  <!-- Define the "jtreg" task -->
138 >  <!-- See the docs in "jtreg -onlineHelp" -->
139 >  <taskdef name="jtreg" classname="com.sun.javatest.regtest.Main$$Ant"
140 >           classpath="${lib.dir}/jtreg.jar" />
141  
142    <!-- Test classpath -->
143    <path id="test.classpath">
# Line 81 | Line 145
145      <pathelement location="${junit.jar}"/>
146    </path>
147  
148 +  <macrodef name="run-tck-tests">
149 +    <attribute name="target"/>
150 +    <attribute name="workdir"/>
151 +    <attribute name="product.jar" default="${product.jar}"/>
152 +    <attribute name="jvmflags" default=""/>
153 +    <sequential>
154 +
155 +    <mkdir dir="@{workdir}/tck-classes"/>
156 +
157 +    <javac srcdir="${tck.src.dir}"
158 +           destdir="@{workdir}/tck-classes"
159 +           debug="${build.debug}"
160 +           debuglevel="${build.debuglevel}"
161 +           deprecation="${build.deprecation}"
162 +           source="6"
163 +           classpath="${junit.jar}"
164 +           includeAntRuntime="false"
165 +           includeJavaRuntime="false"
166 +           executable="${javac@{target}}"
167 +           fork="true">
168 +
169 +      <include name="**/*.java"/>
170 +      <bootclasspath path="@{product.jar}"/>
171 +      <bootclasspath path="${bootclasspath6}"/>
172 +      <compilerarg value="-XDignore.symbol.file=true"/>
173 +      <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
174 +      <compilerarg line="${build.args}"/>
175 +
176 +    </javac>
177 +
178 +    <java classname="JSR166TestCase"
179 +          failonerror="true"
180 +          jvm="${java@{target}}"
181 +          fork="true">
182 +        <jvmarg value="-Xbootclasspath/p:@{product.jar}"/>
183 +        <jvmarg line="@{jvmflags}"/>
184 +        <classpath>
185 +          <pathelement location="${junit.jar}"/>
186 +          <pathelement location="@{workdir}/tck-classes"/>
187 +        </classpath>
188 +    </java>
189 +
190 +    </sequential>
191 +  </macrodef>
192 +
193    <!-- ALoops classpath -->
194    <path id="loops.classpath">
195      <pathelement location="${build.loops.dir}"/>
196    </path>
197  
198 +  <!-- Support @jls tag, used in jdk8+ javadoc -->
199 +  <!-- TODO: How do we get &trade to work? -->
200 +  <!-- TODO: Why isn't @jls a "standard" tag? -->
201 +  <!--   property name="javadoc.jls.cite" value="The Java&trade; Language Specification" -->
202 +  <property name="javadoc.jls.cite" value="The Java Language Specification"/>
203 +  <property name="javadoc.jls.option" value="jls:a:See &lt;cite&gt;${javadoc.jls.cite}&lt;/cite&gt;:"/>
204  
205    <!-- Main targets -->
206  
207    <target name="dists"
208 <          depends="dist, jsr166xdist, jsr166ydist, extra166ydist"
208 >          depends="dist, 4jdk7dist, jsr166edist, jsr166ydist, extra166ydist, jsr166xdist"
209            description="Builds all public jars and docs"/>
210  
211    <target name="compile"
212 <          depends="init, configure-compiler"
213 <          description="Compiles main sources to build folder">
212 >          depends="configure-compiler"
213 >          description="Compiles src/main sources to build dir">
214  
215      <mkdir dir="${build.classes.dir}"/>
216  
217      <javac srcdir="${src.dir}"
218 <          destdir="${build.classes.dir}"
219 <            debug="${build.debug}"
220 <       debuglevel="${build.debuglevel}"
221 <      deprecation="${build.deprecation}"
222 <           source="${build.sourcelevel}"
223 <             fork="true">
218 >           destdir="${build.classes.dir}"
219 >           debug="${build.debug}"
220 >           debuglevel="${build.debuglevel}"
221 >           deprecation="${build.deprecation}"
222 >           classpath=""
223 >           includeAntRuntime="false"
224 >           includeJavaRuntime="false"
225 >           executable="${javac8}"
226 >           fork="true">
227  
228        <include name="**/*.java"/>
229 <      <compilerarg value="-XDignore.symbol.file"/>
230 <
113 < <!--
114 <      <exclude name="java/lang/**"/>
229 >      <compilerarg value="-XDignore.symbol.file=true"/>
230 >      <compilerarg value="-Xlint:all"/>
231        <compilerarg line="${build.args}"/>
116      <compilerarg line="-Xlint -Xmaxwarns 1000"/>
117 -->
232  
233      </javac>
120
234    </target>
235  
236  
124
237    <target name="jar"
238            depends="compile"
239            description="Builds library jar from compiled sources">
240  
129    <mkdir dir="${build.lib.dir}"/>
130
241      <jar destfile="${product.jar}">
242        <fileset dir="${build.classes.dir}"/>
243      </jar>
134
244    </target>
245  
246  
138
247    <target name="test"
248 <          depends="init, configure-tests, report-tests"
248 >          depends="configure-tests, report-tests"
249            description="Runs all tests (requires JUnit 3.8.1 in ${ant.home}/lib)" />
250  
251  
144
252    <target name="docs"
253 <          description="Builds javadocs with custom tags to build folder">
253 >          description="Builds javadocs for src/main to dist dir">
254  
255 <    <delete dir="${build.javadocs.dir}"/>
256 <    <mkdir dir="${build.javadocs.dir}"/>
150 <
151 <    <javadoc destdir="${build.javadocs.dir}"
152 <                link="http://java.sun.com/javase/6/docs/api/"
153 <            overview="${src.dir}/intro.html"
154 <            sourcepath="${src.dir}:${jdksrc.dir}"
155 <    >          
255 >    <delete dir="${dist.javadocs.dir}"/>
256 >    <mkdir dir="${dist.javadocs.dir}"/>
257  
258 <      <packageset dir="${src.dir}"/>
258 >    <!-- the packagenames="none" hack below prevents scanning the -->
259 >    <!-- sourcepath for packages -->
260  
261 +    <javadoc destdir="${dist.javadocs.dir}"
262 +             packagenames="none"
263 +             link="${jdkapi8docs.url}"
264 +             overview="${src.dir}/intro.html"
265 +             classpath=""
266 +             executable="${javadoc8}">
267 +      <sourcepath path="${src.dir}"/>
268 +      <sourcepath path="${jdk8src.dir}"/>
269 +      <arg value="-XDignore.symbol.file=true"/>
270 +      <arg value="-tag"/>
271 +      <arg value="${javadoc.jls.option}"/>
272 +      <fileset dir="${src.dir}" defaultexcludes="yes">
273 +        <include name="**/*.java"/>
274 +      </fileset>
275      </javadoc>
160
276    </target>
277  
278  
164
279    <target name="dist"
280 <          depends="init, dist-clean, dist-jar, dist-docs"
280 >          depends="dist-clean, dist-jar, docs"
281            description="Puts all distributable products in single hierarchy"/>
282  
283  
# Line 182 | Line 296
296        <exclude name="**/SyntaxTest.java"/>
297        <exclude name="**/SuperfluousAbstract.java"/>
298      </jar>
185
299    </target>
300  
301  
189
302    <target name="clean"
303            description="Removes all build products">
304  
305      <delete dir="${build.dir}"/>
194    <delete dir="${build.classes.dir}"/>
195    <delete dir="${build.lib.dir}"/>
306  
307    </target>
308  
309  
200
310    <target name="dist-clean"
311            description="Removes all build and distribution products">
312  
# Line 206 | Line 315
315    </target>
316  
317  
209
210  <target name="dist-docs"
211          description="Builds javadocs without custom tags to dist folder">
212
213    <delete dir="${dist.javadocs.dir}"/>
214    <mkdir dir="${dist.javadocs.dir}"/>
215
216    <javadoc destdir="${dist.javadocs.dir}"
217            link="http://java.sun.com/javase/6/docs/api/"
218            overview="${src.dir}/intro.html"
219
220            sourcepath="${src.dir}:${jdksrc.dir}"
221     >
222 <!--
223      <packageset dir="${src.dir}" defaultexcludes="yes">
224      <include name="java/util/concurrent"/>
225      <include name="java/util/concurrent/atomic"/>
226      <include name="java/util/concurrent/locks"/>
227      </packageset>
228 -->
229      <fileset dir="${topsrc.dir}" defaultexcludes="yes">
230      <include name="main/java/util/concurrent/*.java"/>
231      <include name="main/java/util/concurrent/atomic/*.java"/>
232      <include name="main/java/util/concurrent/locks/*.java"/>
233      <include name="main/java/util/*.java"/>
234 <!--
235      <include name="main/java/util/concurrent/*.html"/>
236      <include name="main/java/util/concurrent/atomic/*.html"/>
237      <include name="main/java/util/concurrent/locks/*.html"/>
238      <include name="main/java/util/*.html"/>
239 -->
240 <!--      <include name="jsr166x/*.java"/> -->
241      </fileset>
242    </javadoc>
243
244  </target>
245
246
247
318    <!-- Internal targets -->
319  
320  
251  <target name="init">
252
253    <!-- Version is kept in a separate file -->
254    <loadfile property="version" srcFile="version.properties"/>
255    <echo>Building JSR-166 version ${version}</echo>
256    <echo>java.home is ${java.home}</echo>
257
258  </target>
259
260
321    <target name="dist-jar"
322            depends="clean, jar">
323  
# Line 272 | Line 332
332      <mkdir dir="${build.testcases.dir}"/>
333  
334      <javac srcdir="${tck.src.dir}"
335 <          destdir="${build.testcases.dir}"
336 <            debug="${build.debug}"
337 <       debuglevel="${build.debuglevel}"
338 <      deprecation="${build.deprecation}"
339 <           source="${build.sourcelevel}"
340 <             fork="true">
335 >           destdir="${build.testcases.dir}"
336 >           debug="${build.debug}"
337 >           debuglevel="${build.debuglevel}"
338 >           deprecation="${build.deprecation}"
339 >           source="6"
340 >           classpath="${junit.jar}"
341 >           includeAntRuntime="false"
342 >           includeJavaRuntime="false"
343 >           executable="${javac8}"
344 >           fork="true">
345  
346 <      <compilerarg value="${bootclasspath.args}"/>
346 >      <include name="**/*.java"/>
347 >      <bootclasspath path="@{product.jar}"/>
348 >      <bootclasspath path="${bootclasspath6}"/>
349 >      <compilerarg value="-XDignore.symbol.file=true"/>
350 >      <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
351        <compilerarg line="${build.args}"/>
352  
285      <classpath refid="test.classpath"/>
286
353      </javac>
354  
355      <javac srcdir="${test.src.dir}"
356 <          destdir="${build.testcases.dir}"
357 <            debug="${build.debug}"
358 <       debuglevel="${build.debuglevel}"
359 <      deprecation="${build.deprecation}"
360 <           source="${build.sourcelevel}"
361 <             fork="true">
362 <
363 <      <include name="jsr166/test/**"/>
364 <
365 <      <compilerarg value="${bootclasspath.args}"/>
356 >           destdir="${build.testcases.dir}"
357 >           debug="${build.debug}"
358 >           debuglevel="${build.debuglevel}"
359 >           deprecation="${build.deprecation}"
360 >           source="6"
361 >           classpath=""
362 >           includeAntRuntime="false"
363 >           includeJavaRuntime="false"
364 >           executable="${javac8}"
365 >           fork="true">
366 >
367 >      <include name="jsr166/test/**/*.java"/>
368 >      <bootclasspath path="${product.jar}"/>
369 >      <bootclasspath path="${bootclasspath6}"/>
370 >      <compilerarg value="-XDignore.symbol.file=true"/>
371 >      <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
372        <compilerarg line="${build.args}"/>
373  
302      <classpath refid="test.classpath"/>
303
374      </javac>
375  
376   <!--
# Line 312 | Line 382
382             source="${build.sourcelevel}"
383               fork="true">
384  
385 <      <compilerarg value="${bootclasspath.args}"/>
385 >      <compilerarg value="-Xbootclasspath/p:${product.jar}"/>
386 >      <compilerarg value="-XDignore.symbol.file=true"/>
387        <compilerarg line="${build.args}"/>
388  
318      <classpath refid="test.classpath"/>
319
389      </javac>
390   -->
391  
# Line 336 | Line 405
405            errorProperty="junit.failed"
406          failureProperty="junit.failed"
407                      dir="${build.reports.dir}"
408 +                    jvm="${java8}"
409                     fork="true">
410  
411 <      <jvmarg value="${bootclasspath.args}"/>
411 >      <jvmarg value="-Xbootclasspath/p:${product.jar}"/>
412        <jvmarg value="-server"/>
413        <jvmarg value="-showversion"/>
414  
# Line 439 | Line 509
509    <!-- Various demos and test programs -->
510  
511  
512 <  <target name="loops" depends="init, configure-compiler"
512 >  <target name="loops" depends="configure-compiler"
513            description="Benchmark from Doug Lea's AQS paper">
514  
515      <mkdir dir="${build.loops.dir}"/>
# Line 454 | Line 524
524  
525        <compilerarg line="${build.args}"/>
526        <classpath refid="loops.classpath"/>
527 +      <compilerarg value="-XDignore.symbol.file=true"/>
528  
529      </javac>
530  
# Line 464 | Line 535
535    </target>
536  
537  
538 <  <!-- jsr166x -->
468 <
469 <
470 <  <target name="jsr166xcompile"
471 <          depends="init, configure-compiler"
472 <          description="Compiles jsr166x sources">
538 >  <!-- jsr166 4jdk7 -->
539  
540 <    <mkdir dir="${build.jsr166x.dir}"/>
541 <
542 <    <javac srcdir="${jsr166xsrc.dir}"
543 <          destdir="${build.jsr166x.dir}"
544 <            debug="${build.debug}"
545 <       debuglevel="${build.debuglevel}"
546 <      deprecation="${build.deprecation}"
547 <           source="${build.sourcelevel}"
548 <             fork="true">
540 >  <target name="4jdk7compile"
541 >          depends="configure-compiler"
542 >          description="Compiles src/jdk7 sources, targeting jdk7">
543 >
544 >    <mkdir dir="${build.4jdk7.classes.dir}"/>
545 >
546 >    <javac srcdir="${4jdk7src.dir}"
547 >           destdir="${build.4jdk7.classes.dir}"
548 >           debug="${build.debug}"
549 >           debuglevel="${build.debuglevel}"
550 >           deprecation="${build.deprecation}"
551 >           source="6"
552 >           classpath=""
553 >           includeAntRuntime="false"
554 >           includeJavaRuntime="false"
555 >           executable="${javac7}"
556 >           fork="true">
557  
558        <include name="**/*.java"/>
559 +      <bootclasspath path="${bootclasspath6}"/>
560 +      <compilerarg value="-XDignore.symbol.file=true"/>
561 +      <compilerarg value="-Xlint:all"/>
562        <compilerarg line="${build.args}"/>
563  
564      </javac>
488
565    </target>
566  
567  
568 <
569 <  <target name="jsr166xjar"
494 <          depends="jsr166xcompile"
568 >  <target name="4jdk7-jar"
569 >          depends="4jdk7compile"
570            description="Builds library jar from compiled sources">
571  
572 <    <mkdir dir="${build.jsr166xlib.dir}"/>
573 <
499 <    <jar destfile="${jsr166xproduct.jar}">
500 <      <fileset dir="${build.jsr166x.dir}"/>
572 >    <jar destfile="${4jdk7product.jar}">
573 >      <fileset dir="${build.4jdk7.classes.dir}"/>
574      </jar>
575  
576    </target>
577  
578  
579 +  <target name="4jdk7-test-tck"
580 +          depends="4jdk7-jar"
581 +          description="Runs tck tests for jsr166-4jdk7 directly">
582  
583 <  <target name="jsr166xdocs"
584 <          description="Builds javadocs with custom tags to build folder">
583 >    <run-tck-tests
584 >      target="7"
585 >      workdir="${build.4jdk7.dir}"
586 >      product.jar="${4jdk7product.jar}"/>
587 >  </target>
588  
510    <delete dir="${build.jsr166xjavadocs.dir}"/>
511    <mkdir dir="${build.jsr166xjavadocs.dir}"/>
589  
590 <    <javadoc destdir="${build.jsr166xjavadocs.dir}"
591 <             link="http://java.sun.com/javase/6/docs/api/"
592 <            sourcepath="${topsrc.dir}:${jdksrc.dir}"
516 <    >
517 <      <packageset dir="${topsrc.dir}" defaultexcludes="yes">
518 <      <include name="jsr166x"/>
519 <      </packageset>
590 >  <target name="4jdk7-test-tck-junit"
591 >          depends="4jdk7compile"
592 >          description="Runs tck tests for jsr166-4jdk7 via junit task (experimental)">
593  
594 +    <junit printsummary="true"
595 +           showoutput="true"
596 +           errorProperty="junit.failed"
597 +           failureProperty="junit.failed"
598 +           includeantruntime="true"
599 +           jvm="${java7}"
600 +           fork="true">
601  
602 <    </javadoc>
602 >      <jvmarg value="-Xbootclasspath/p:${4jdk7product.jar}"/>
603 >      <jvmarg value="-server"/>
604 >
605 >      <classpath>
606 >        <pathelement location="${junit.jar}"/>
607 >        <pathelement location="${build.4jdk7.tck.classes.dir}"/>
608 >      </classpath>
609 >
610 >      <formatter type="brief"/>
611 >
612 >      <test name="JSR166TestCase" haltonfailure="no">
613 >      </test>
614 >
615 >    </junit>
616 >  </target>
617  
618 +  <target name="4jdk7-test-jtreg"
619 +          depends="4jdk7compile"
620 +          description="Runs jtreg tests for jsr166-4jdk7 using the jtreg ant task">
621 +    <delete dir="${build.4jdk7.dir}/JTwork"   quiet="true"/>
622 +    <delete dir="${build.4jdk7.dir}/JTreport" quiet="true"/>
623 +    <mkdir dir="${build.4jdk7.dir}/JTwork/scratch"/>
624 +    <mkdir dir="${build.4jdk7.dir}/JTreport"/>
625 +    <jtreg dir="${jtreg.src.dir}"
626 +           jdk="${jdk7.home}"
627 +           workDir="${build.4jdk7.dir}/JTwork"
628 +           reportDir="${build.4jdk7.dir}/JTreport">
629 +
630 +      <arg value="-Xbootclasspath/p:${4jdk7product.jar}"/>
631 +      <arg value="-agentvm"/>
632 +      <arg value="-v:nopass,fail"/>
633 +      <arg value="-vmoptions:-esa -ea"/>
634 +      <arg value="-automatic"/>
635 +      <arg value="-k:!ignore"/>
636 +    </jtreg>
637    </target>
638  
639  
640 <  <target name="jsr166xdist"
641 <          depends="jsr166xdist-clean, jsr166xdist-jar, jsr166xdist-docs"
640 >  <target name="4jdk7-test"
641 >          depends="4jdk7-test-tck, 4jdk7-test-jtreg"
642 >          description="Runs tck and jtreg tests for jsr166-4jdk7">
643 >  </target>
644 >
645 >
646 >  <target name="4jdk7docs"
647 >          description="Builds javadocs for src/jdk7 to dist dir">
648 >
649 >    <delete dir="${dist.4jdk7.docs.dir}"/>
650 >    <mkdir dir="${dist.4jdk7.docs.dir}"/>
651 >
652 >    <javadoc destdir="${dist.4jdk7.docs.dir}"
653 >             packagenames="none"
654 >             link="${jdkapi7docs.url}"
655 >             overview="${4jdk7src.dir}/intro.html"
656 >             classpath=""
657 >             executable="${javadoc7}">
658 >      <sourcepath path="${4jdk7src.dir}"/>
659 >      <sourcepath path="${jdk7src.dir}"/>
660 >      <arg value="-XDignore.symbol.file=true"/>
661 >      <fileset dir="${4jdk7src.dir}" defaultexcludes="yes">
662 >        <include name="**/*.java"/>
663 >      </fileset>
664 >    </javadoc>
665 >  </target>
666 >
667 >
668 >  <target name="4jdk7dist"
669 >          depends="4jdk7dist-clean, 4jdk7dist-jar, 4jdk7docs"
670            description="Puts all distributable products in single hierarchy"/>
671  
672  
673 +  <target name="4jdk7clean"
674 +          description="Removes all 4jdk7 build products">
675  
676 <  <target name="jsr166xclean"
534 <          description="Removes all build products">
676 >    <delete dir="${build.4jdk7.dir}"/>
677  
678 <    <delete dir="${build.jsr166x.dir}"/>
679 <    <delete dir="${build.jsr166xlib.dir}"/>
678 >  </target>
679 >
680 >
681 >  <target name="4jdk7dist-clean"
682 >          description="Removes all build and distribution products">
683  
684    </target>
685  
686 +  <target name="4jdk7dist-jar"
687 +          depends="4jdk7clean, 4jdk7-jar">
688  
689 +    <copy file="${4jdk7product.jar}" todir="${dist.dir}"/>
690  
691 <  <target name="jsr166xdist-clean"
692 <          description="Removes all build and distribution products">
691 >  </target>
692 >
693 >
694 >  <!-- jsr166x -->
695 >
696 >  <target name="jsr166xcompile"
697 >          depends="configure-compiler"
698 >          description="Compiles jsr166x sources to build dir">
699 >
700 >    <mkdir dir="${build.jsr166x.classes.dir}"/>
701 >
702 >    <javac srcdir="${topsrc.dir}"
703 >           destdir="${build.jsr166x.classes.dir}"
704 >           debug="${build.debug}"
705 >           debuglevel="${build.debuglevel}"
706 >           deprecation="${build.deprecation}"
707 >           classpath=""
708 >           source="5"
709 >           includeAntRuntime="false"
710 >           includeJavaRuntime="false"
711 >           executable="${javac7}"
712 >           fork="true">
713 >
714 >      <include name="jsr166x/**/*.java"/>
715 >      <bootclasspath path="${bootclasspath6}"/>
716 >      <compilerarg value="-XDignore.symbol.file=true"/>
717 >      <compilerarg value="-Xlint:all,-unchecked,-rawtypes"/>
718 >      <compilerarg line="${build.args}"/>
719  
720 +    </javac>
721    </target>
722  
723  
724 +  <target name="jsr166x-jar"
725 +          depends="jsr166xcompile"
726 +          description="Builds library jar from compiled sources">
727 +
728 +    <jar destfile="${jsr166x.jar}">
729 +      <fileset dir="${build.jsr166x.classes.dir}"/>
730 +    </jar>
731 +
732 +  </target>
733 +
734  
735 <  <target name="jsr166xdist-docs"
736 <          description="Builds javadocs without custom tags to dist folder">
735 >  <target name="jsr166xdocs"
736 >          description="Builds javadocs to dist dir">
737  
738      <delete dir="${dist.jsr166xjavadocs.dir}"/>
739      <mkdir dir="${dist.jsr166xjavadocs.dir}"/>
740  
741      <javadoc destdir="${dist.jsr166xjavadocs.dir}"
742 <                link="http://java.sun.com/javase/6/docs/api/"
743 <              source="${build.sourcelevel}">
744 <
745 <      <packageset dir="${topsrc.dir}" defaultexcludes="yes">
746 <      <include name="jsr166x"/>
747 <      </packageset>
742 >             packagenames="jsr166x.*"
743 >             link="${jdkapidocs.url}"
744 >             source="5"
745 >             executable="${javadoc7}">
746 >      <sourcepath path="${topsrc.dir}"/>
747 >      <sourcepath path="${jdk6src.dir}"/>
748 >      <bootclasspath path="${bootclasspath6}"/>
749 >      <arg value="-XDignore.symbol.file=true"/>
750  
751      </javadoc>
752 +  </target>
753 +
754 +
755 +  <target name="jsr166xdist"
756 +          depends="jsr166xdist-clean, jsr166xdist-jar, jsr166xdocs"
757 +          description="Puts all distributable products in single hierarchy"/>
758 +
759 +
760 +  <target name="jsr166xclean"
761 +          description="Removes all jsr166x build products">
762 +
763 +    <delete dir="${build.jsr166x.dir}"/>
764  
765    </target>
766  
767 +
768 +  <target name="jsr166xdist-clean"
769 +          description="Removes all build and distribution products">
770 +
771 +  </target>
772 +
773 +
774    <target name="jsr166xdist-jar"
775 <          depends="jsr166xclean, jsr166xjar">
775 >          depends="jsr166xclean, jsr166x-jar">
776  
777 <    <copy file="${jsr166xproduct.jar}" todir="${dist.dir}"/>
777 >    <copy file="${jsr166x.jar}" todir="${dist.dir}"/>
778  
779    </target>
780  
# Line 576 | Line 782
782  
783  
784    <target name="jsr166ycompile"
785 <          depends="init, configure-compiler"
785 >          depends="configure-compiler"
786            description="Compiles jsr166y sources">
787  
788 <    <mkdir dir="${build.jsr166y.dir}"/>
583 <
584 <    <javac srcdir="${jsr166ysrc.dir}"
585 <          destdir="${build.jsr166y.dir}"
586 <            debug="${build.debug}"
587 <       debuglevel="${build.debuglevel}"
588 <      deprecation="${build.deprecation}"
589 <           source="${build.sourcelevel}"
590 <             fork="true">
788 >    <mkdir dir="${build.jsr166y.classes.dir}"/>
789  
790 <      <include name="**/*.java"/>
790 >    <javac srcdir="${topsrc.dir}"
791 >           destdir="${build.jsr166y.classes.dir}"
792 >           debug="${build.debug}"
793 >           debuglevel="${build.debuglevel}"
794 >           deprecation="${build.deprecation}"
795 >           source="6"
796 >           classpath=""
797 >           includeAntRuntime="false"
798 >           includeJavaRuntime="false"
799 >           executable="${javac7}"
800 >           fork="true">
801 >
802 >      <include name="jsr166y/**/*.java"/>
803 >      <bootclasspath path="${bootclasspath6}"/>
804 >      <compilerarg value="-XDignore.symbol.file=true"/>
805 >      <compilerarg value="-Xlint:all"/>
806        <compilerarg line="${build.args}"/>
594      <compilerarg value="${bootclasspath.args}"/>
595
596 <!--       <compilerarg line="-Xlint -Xmaxwarns 1000"/> -->
807  
808      </javac>
599
809    </target>
810  
811  
812 <
604 <  <target name="jsr166yjar"
812 >  <target name="jsr166y-jar"
813            depends="jsr166ycompile"
814            description="Builds library jar from compiled sources">
815  
816 <    <mkdir dir="${build.jsr166ylib.dir}"/>
817 <
610 <    <jar destfile="${jsr166yproduct.jar}" index="true">
611 <      <fileset dir="${build.jsr166y.dir}"/>
816 >    <jar destfile="${jsr166y.jar}" index="true">
817 >      <fileset dir="${build.jsr166y.classes.dir}"/>
818      </jar>
819  
820    </target>
821  
822  
617
823    <target name="jsr166ydocs"
824 <          description="Builds javadocs with custom tags to build folder">
620 <
621 <    <delete dir="${build.jsr166yjavadocs.dir}"/>
622 <    <mkdir dir="${build.jsr166yjavadocs.dir}"/>
824 >          description="Builds javadocs to dist dir">
825  
826 <    <javadoc destdir="${build.jsr166yjavadocs.dir}"
827 <                link="http://java.sun.com/javase/6/docs/api/"
626 <            sourcepath="${topsrc.dir}:${jdksrc.dir}"
627 <    >
628 <      <packageset dir="${topsrc.dir}" defaultexcludes="no">
629 <      <include name="jsr166y"/>
630 <      </packageset>
826 >    <delete dir="${dist.jsr166yjavadocs.dir}"/>
827 >    <mkdir dir="${dist.jsr166yjavadocs.dir}"/>
828  
829 +    <javadoc destdir="${dist.jsr166yjavadocs.dir}"
830 +             packagenames="jsr166y.*"
831 +             link="${jdkapidocs.url}"
832 +             source="6"
833 +             executable="${javadoc7}">
834 +      <sourcepath path="${topsrc.dir}"/>
835 +      <sourcepath path="${jdk6src.dir}"/>
836 +      <bootclasspath path="${bootclasspath6}"/>
837 +      <arg value="-XDignore.symbol.file=true"/>
838  
839      </javadoc>
634
840    </target>
841  
842  
843    <target name="jsr166ydist"
844 <          depends="jsr166ydist-clean, jsr166ydist-jar, jsr166ydist-docs"
844 >          depends="jsr166ydist-clean, jsr166ydist-jar, jsr166ydocs"
845            description="Puts all distributable products in single hierarchy"/>
846  
847  
643
848    <target name="jsr166yclean"
849 <          description="Removes all build products">
849 >          description="Removes all jsr166y build products">
850  
851      <delete dir="${build.jsr166y.dir}"/>
648    <delete dir="${build.jsr166ylib.dir}"/>
852  
853    </target>
854  
855  
653
856    <target name="jsr166ydist-clean"
857            description="Removes all build and distribution products">
858  
859    </target>
860  
659  <target name="jsr166ydist-docs"
660          description="Builds javadocs without custom tags to dist folder">
661
662    <delete dir="${dist.jsr166yjavadocs.dir}"/>
663    <mkdir dir="${dist.jsr166yjavadocs.dir}"/>
664
665    <javadoc destdir="${dist.jsr166yjavadocs.dir}"
666                link="http://java.sun.com/javase/6/docs/api/"
667              source="${build.sourcelevel}"
668            sourcepath="${topsrc.dir}:${jdksrc.dir}"
669            >          
670      <fileset dir="${topsrc.dir}" defaultexcludes="yes">
671      <include name="jsr166y/*.java"/>
672            </fileset>
673    </javadoc>
674
675  </target>
676
861    <target name="jsr166ydist-jar"
862 <          depends="jsr166yclean, jsr166yjar">
862 >          depends="jsr166yclean, jsr166y-jar">
863  
864 <    <copy file="${jsr166yproduct.jar}" todir="${dist.dir}"/>
864 >    <copy file="${jsr166y.jar}" todir="${dist.dir}"/>
865  
866    </target>
867  
868 +
869    <!-- extra166y -->
870  
871  
872    <target name="extra166ycompile"
873 <          depends="init, configure-compiler, jsr166ycompile"
873 >          depends="configure-compiler, jsr166y-jar"
874            description="Compiles extra166y sources">
875  
876 <    <mkdir dir="${build.extra166y.dir}"/>
692 <
693 <    <javac srcdir="${extra166ysrc.dir}"
694 <          destdir="${build.extra166y.dir}"
695 <            debug="${build.debug}"
696 <            classpath="${jsr166yproduct.jar}"
697 <       debuglevel="${build.debuglevel}"
698 <      deprecation="${build.deprecation}"
699 <           source="${build.sourcelevel}"
700 <             fork="true">
876 >    <mkdir dir="${build.extra166y.classes.dir}"/>
877  
878 <      <include name="**/*.java"/>
878 >    <javac srcdir="${topsrc.dir}"
879 >           destdir="${build.extra166y.classes.dir}"
880 >           debug="${build.debug}"
881 >           debuglevel="${build.debuglevel}"
882 >           deprecation="${build.deprecation}"
883 >           classpath=""
884 >           source="6"
885 >           includeAntRuntime="false"
886 >           includeJavaRuntime="false"
887 >           executable="${javac7}"
888 >           fork="true">
889 >
890 >      <include name="extra166y/**/*.java"/>
891 >      <bootclasspath path="${jsr166y.jar}"/>
892 >      <bootclasspath path="${bootclasspath6}"/>
893 >      <compilerarg value="-XDignore.symbol.file=true"/>
894 >      <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial"/>
895        <compilerarg line="${build.args}"/>
704      <compilerarg value="${bootclasspath.args}"/>
705
706 <!--       <compilerarg line="-Xlint -Xmaxwarns 1000"/> -->
896  
897      </javac>
709
898    </target>
899  
900  
901 <
714 <  <target name="extra166yjar"
901 >  <target name="extra166y-jar"
902            depends="extra166ycompile"
903            description="Builds library jar from compiled sources">
904  
905 <    <mkdir dir="${build.extra166ylib.dir}"/>
906 <
720 <    <jar destfile="${extra166yproduct.jar}" index="true">
721 <      <fileset dir="${build.extra166y.dir}"/>
905 >    <jar destfile="${extra166y.jar}" index="true">
906 >      <fileset dir="${build.extra166y.classes.dir}"/>
907      </jar>
908  
909    </target>
910  
911  
727
912    <target name="extra166ydocs"
913 <          description="Builds javadocs with custom tags to build folder">
730 <
731 <    <delete dir="${build.extra166yjavadocs.dir}"/>
732 <    <mkdir dir="${build.extra166yjavadocs.dir}"/>
913 >          description="Builds javadocs to build dir">
914  
915 <    <javadoc destdir="${build.extra166yjavadocs.dir}"
916 <                link="http://java.sun.com/javase/6/docs/api/"
736 <            sourcepath="${topsrc.dir}:${jdksrc.dir}"
737 <    >
738 <      <packageset dir="${topsrc.dir}" defaultexcludes="no">
739 <      <include name="extra166y"/>
740 <      </packageset>
915 >    <delete dir="${dist.extra166yjavadocs.dir}"/>
916 >    <mkdir dir="${dist.extra166yjavadocs.dir}"/>
917  
918 +    <javadoc destdir="${dist.extra166yjavadocs.dir}"
919 +             packagenames="extra166y.*"
920 +             link="${jdkapidocs.url}"
921 +             source="6"
922 +             executable="${javadoc7}">
923 +      <sourcepath path="${topsrc.dir}"/>
924 +      <sourcepath path="${jdk6src.dir}"/>
925 +      <bootclasspath path="${bootclasspath6}"/>
926 +      <arg value="-XDignore.symbol.file=true"/>
927  
928      </javadoc>
744
929    </target>
930  
931  
932    <target name="extra166ydist"
933 <          depends="extra166ydist-clean, extra166ydist-jar, extra166ydist-docs"
933 >          depends="extra166ydist-clean, extra166ydist-jar, extra166ydocs"
934            description="Puts all distributable products in single hierarchy"/>
935  
936  
753
937    <target name="extra166yclean"
938 <          description="Removes all build products">
938 >          description="Removes all extra166y build products">
939  
940      <delete dir="${build.extra166y.dir}"/>
758    <delete dir="${build.extra166ylib.dir}"/>
941  
942    </target>
943  
944  
763
945    <target name="extra166ydist-clean"
946            description="Removes all build and distribution products">
947  
948    </target>
949  
950 <  <target name="extra166ydist-docs"
951 <          description="Builds javadocs without custom tags to dist folder">
950 >  <target name="extra166ydist-jar"
951 >          depends="extra166yclean, extra166y-jar">
952  
953 <    <delete dir="${dist.extra166yjavadocs.dir}"/>
954 <    <mkdir dir="${dist.extra166yjavadocs.dir}"/>
953 >    <copy file="${extra166y.jar}" todir="${dist.dir}"/>
954 >
955 >  </target>
956 >
957 >  <!-- jsr166e -->
958 >
959 >  <target name="jsr166ecompile"
960 >          depends="configure-compiler"
961 >          description="Compiles jsr166e sources">
962 >
963 >    <mkdir dir="${build.jsr166e.classes.dir}"/>
964 >
965 >    <javac srcdir="${topsrc.dir}"
966 >           destdir="${build.jsr166e.classes.dir}"
967 >           debug="${build.debug}"
968 >           debuglevel="${build.debuglevel}"
969 >           deprecation="${build.deprecation}"
970 >           source="7"
971 >           classpath=""
972 >           includeAntRuntime="false"
973 >           includeJavaRuntime="false"
974 >           executable="${javac7}"
975 >           fork="true">
976 >
977 >      <include name="jsr166e/**/*.java"/>
978 >      <compilerarg value="-XDignore.symbol.file=true"/>
979 >      <compilerarg value="-Xlint:all"/>
980 >      <compilerarg line="${build.args}"/>
981 >
982 >    </javac>
983 >  </target>
984 >
985 >
986 >  <target name="jsr166e-jar"
987 >          depends="jsr166ecompile"
988 >          description="Builds library jar from compiled sources">
989 >
990 >    <jar destfile="${jsr166e.jar}" index="true">
991 >      <fileset dir="${build.jsr166e.classes.dir}"/>
992 >    </jar>
993 >
994 >  </target>
995 >
996 >
997 >  <target name="jsr166edocs"
998 >          description="Builds javadocs to build dir">
999 >
1000 >    <delete dir="${dist.jsr166ejavadocs.dir}"/>
1001 >    <mkdir dir="${dist.jsr166ejavadocs.dir}"/>
1002 >
1003 >    <javadoc destdir="${dist.jsr166ejavadocs.dir}"
1004 >             packagenames="jsr166e.*"
1005 >             link="${jdkapidocs.url}"
1006 >             source="7"
1007 >             executable="${javadoc7}">
1008 >      <sourcepath path="${topsrc.dir}"/>
1009 >      <sourcepath path="${jdk7src.dir}"/>
1010 >      <arg value="-XDignore.symbol.file=true"/>
1011  
775    <javadoc destdir="${dist.extra166yjavadocs.dir}"
776                link="http://java.sun.com/javase/6/docs/api/"
777              source="${build.sourcelevel}"
778            sourcepath="${topsrc.dir}:${jdksrc.dir}"
779            >
780      <fileset dir="${topsrc.dir}" defaultexcludes="yes">
781      <include name="extra166y/*.java"/>
782            </fileset>
1012      </javadoc>
1013 +  </target>
1014 +
1015 +
1016 +  <target name="jsr166edist"
1017 +          depends="jsr166edist-clean, jsr166edist-jar, jsr166edocs"
1018 +          description="Puts all distributable products in single hierarchy"/>
1019 +
1020 +
1021 +  <target name="jsr166eclean"
1022 +          description="Removes all jsr166e build products">
1023 +
1024 +    <delete dir="${build.jsr166e.dir}"/>
1025  
1026    </target>
1027  
787  <target name="extra166ydist-jar"
788          depends="extra166yclean, extra166yjar">
1028  
1029 <    <copy file="${extra166yproduct.jar}" todir="${dist.dir}"/>
1029 >  <target name="jsr166edist-clean"
1030 >          description="Removes all build and distribution products">
1031 >
1032 >  </target>
1033 >
1034 >  <target name="jsr166edist-jar"
1035 >          depends="jsr166eclean, jsr166e-jar">
1036 >
1037 >    <copy file="${jsr166e.jar}" todir="${dist.dir}"/>
1038  
1039    </target>
1040  

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines