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.100 by jsr166, Sat Jan 19 17:15:44 2013 UTC vs.
Revision 1.138 by jsr166, Fri Mar 22 18:04:56 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 35 | Line 38
38  
39  
40    <!-- Compilation options -->
41 <  <property name="build.sourcelevel"    value="1.6"/>
41 >  <property name="build.sourcelevel"    value="6"/>
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"/>
49    <property name="build.classes.dir"           location="${build.dir}/classes"/>
50    <property name="build.testcases.dir"         location="${build.dir}/testcases"/>
51    <property name="build.loops.dir"             location="${build.dir}/loops"/>
48  <property name="build.lib.dir"               location="${build.dir}/lib"/>
49  <property name="build.javadocs.dir"          location="${build.dir}/javadocs"/>
52    <property name="build.reports.dir"           location="${build.dir}/reports"/>
53  
54 <  <property name="build.4jdk7.dir"              location="${build.dir}/4jdk7"/>
55 <  <property name="build.4jdk7.lib.dir"          location="${build.4jdk7.dir}"/>
56 <  <property name="build.4jdk7.classes.dir"      location="${build.4jdk7.dir}/classes"/>
57 <  <property name="build.4jdk7.tck.classes.dir"  location="${build.4jdk7.dir}/tck/classes"/>
56 <  <property name="build.4jdk7.docs.dir"         location="${build.4jdk7.dir}/docs"/>
54 >  <property name="build.4jdk7.dir"             location="${build.dir}/jsr166-4jdk7"/>
55 >  <property name="build.4jdk7.classes.dir"     location="${build.4jdk7.dir}/classes"/>
56 >  <property name="build.4jdk7.tck.classes.dir" location="${build.4jdk7.dir}/tck-classes"/>
57 >  <property name="build.4jdk7.docs.dir"        location="${build.4jdk7.dir}/docs"/>
58  
59    <property name="build.jsr166x.dir"           location="${build.dir}/jsr166x"/>
59  <property name="build.jsr166xlib.dir"        location="${build.dir}/jsr166xlib"/>
60  <property name="build.jsr166xjavadocs.dir"   location="${build.dir}/jsr166xjavadocs"/>
61
60    <property name="build.jsr166y.dir"           location="${build.dir}/jsr166y"/>
63  <property name="build.jsr166ylib.dir"        location="${build.dir}/jsr166ylib"/>
64  <property name="build.jsr166yjavadocs.dir"   location="${build.dir}/jsr166yjavadocs"/>
65
61    <property name="build.jsr166e.dir"           location="${build.dir}/jsr166e"/>
67  <property name="build.jsr166elib.dir"        location="${build.dir}/jsr166elib"/>
68  <property name="build.jsr166ejavadocs.dir"   location="${build.dir}/jsr166ejavadocs"/>
69
62    <property name="build.extra166y.dir"         location="${build.dir}/extra166y"/>
71  <property name="build.extra166ylib.dir"      location="${build.dir}/extra166ylib"/>
72  <property name="build.extra166yjavadocs.dir" location="${build.dir}/extra166yjavadocs"/>
63  
64 <  <!-- JDK binary locations -->
64 >  <property name="build.jsr166x.classes.dir"   location="${build.jsr166x.dir}/classes"/>
65 >  <property name="build.jsr166y.classes.dir"   location="${build.jsr166y.dir}/classes"/>
66 >  <property name="build.jsr166e.classes.dir"   location="${build.jsr166e.dir}/classes"/>
67 >  <property name="build.extra166y.classes.dir" location="${build.extra166y.dir}/classes"/>
68 >
69 >  <!-- JDK locations -->
70    <property name="jdks.home"  location="${user.home}/jdk"/>
71  
72    <macrodef name="defjdklocations">
# Line 81 | Line 76
76      <property name="java@{v}"       location="${jdk@{v}.home}/bin/java"/>
77      <property name="javac@{v}"      location="${jdk@{v}.home}/bin/javac"/>
78      <property name="javadoc@{v}"    location="${jdk@{v}.home}/bin/javadoc"/>
84    <property name="bootdir@{v}"    location="${jdk@{v}.home}/jre/lib"/>
79      <property name="jdk@{v}src.dir" location="${jdks.home}/src/jdk@{v}/jdk/src/share/classes"/>
80 <    <property name="bootclasspath@{v}"
81 <     value="${bootdir@{v}}/resources.jar:${bootdir@{v}}/rt.jar:${bootdir@{v}}/jsse.jar:${bootdir@{v}}/jce.jar:${bootdir@{v}}/:${bootdir@{v}}/charsets.jar"/>
80 >    <local name="boot.jar.dir"/>
81 >    <property name="boot.jar.dir"   location="${jdk@{v}.home}/jre/lib"/>
82 >    <path id="bootclasspath@{v}">
83 >      <pathelement path="${boot.jar.dir}/resources.jar"/>
84 >      <pathelement path="${boot.jar.dir}/rt.jar"/>
85 >      <pathelement path="${boot.jar.dir}/jsse.jar"/>
86 >      <pathelement path="${boot.jar.dir}/jce.jar"/>
87 >      <pathelement path="${boot.jar.dir}/charsets.jar"/>
88 >    </path>
89 >    <property name="bootclasspath@{v}" value="${toString:bootclasspath@{v}}"/>
90      </sequential>
91    </macrodef>
92  
93 <  <defjdklocations v="6"/>
94 <  <defjdklocations v="7"/>
95 <  <defjdklocations v="8"/>
94 <
95 <  <macrodef name="run-tck-tests">
96 <    <attribute name="jvm"/>
97 <    <attribute name="tck.classes"/>
98 <    <attribute name="product.jar" default="${product.jar}"/>
99 <    <attribute name="jvmflags" default=""/>
93 >  <macrodef name="mirror-dir">
94 >    <attribute name="src"/>
95 >    <attribute name="dst"/>
96      <sequential>
97 <    <java classname="JSR166TestCase"
98 <          jvm="@{jvm}" fork="true">
99 <        <jvmarg value="-Xbootclasspath/p:@{product.jar}"/>
100 <        <jvmarg line="@{jvmflags}"/>
101 <        <classpath>
106 <          <pathelement location="${junit.jar}"/>
107 <          <pathelement location="@{tck.classes}"/>
108 <        </classpath>
109 <    </java>
97 >    <delete dir="@{dst}"/>
98 >    <mkdir dir="@{dst}"/>
99 >    <copy todir="@{dst}" preservelastmodified="true">
100 >      <fileset dir="@{src}"/>
101 >    </copy>
102      </sequential>
103    </macrodef>
104  
105 +  <defjdklocations v="6"/>
106 +  <defjdklocations v="7"/>
107 +  <defjdklocations v="8"/>
108 +
109    <!-- Source locations -->
110    <property name="src.dir"              location="${basedir}/src/main"/>
111    <property name="test.src.dir"         location="${basedir}/src/test"/>
# Line 124 | Line 120
120    <property name="jsr166ysrc.dir"       location="${topsrc.dir}/jsr166y"/>
121    <property name="jsr166esrc.dir"       location="${topsrc.dir}/jsr166e"/>
122    <property name="extra166ysrc.dir"     location="${topsrc.dir}/extra166y"/>
127  <property name="jdksrc.dir"           location="/home/dl/1.6.0/j2se/martin/j2se/src/share/classes"/>
123  
124 <  <!-- Distribution locations -->
125 <  <property name="dist.javadocs.dir"           location="${dist.dir}/docs"/>
126 <  <property name="dist.4jdk7.docs.dir"         location="${dist.dir}/jsr166-4jdk7docs"/>
127 <  <property name="dist.jsr166xjavadocs.dir"    location="${dist.dir}/jsr166xdocs"/>
128 <  <property name="dist.jsr166yjavadocs.dir"    location="${dist.dir}/jsr166ydocs"/>
129 <  <property name="dist.jsr166ejavadocs.dir"    location="${dist.dir}/jsr166edocs"/>
130 <  <property name="dist.extra166yjavadocs.dir"  location="${dist.dir}/extra166ydocs"/>
124 >  <!-- Javadoc locations -->
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.lib.dir}/jsr166.jar"/>
141 <  <property name="4jdk7product.jar"     location="${build.4jdk7.lib.dir}/jsr166-4jdk7.jar"/>
142 <  <property name="jsr166xproduct.jar"   location="${build.jsr166xlib.dir}/jsr166x.jar"/>
143 <  <property name="jsr166yproduct.jar"   location="${build.jsr166ylib.dir}/jsr166y.jar"/>
144 <  <property name="jsr166eproduct.jar"   location="${build.jsr166elib.dir}/jsr166e.jar"/>
145 <  <property name="extra166yproduct.jar" location="${build.extra166ylib.dir}/extra166y.jar"/>
146 <  <property name="junit.jar"            location="${lib.dir}/junit.jar"/>
145 <
146 <  <!-- Bootclasspath argument -->
147 <  <property name="bootclasspath.args"   value="-Xbootclasspath/p:${product.jar}"/>
140 >  <property name="product.jar"      location="${build.dir}/jsr166.jar"/>
141 >  <property name="4jdk7product.jar" location="${build.4jdk7.dir}/jsr166-4jdk7.jar"/>
142 >  <property name="jsr166x.jar"      location="${build.jsr166x.dir}/jsr166x.jar"/>
143 >  <property name="jsr166y.jar"      location="${build.jsr166y.dir}/jsr166y.jar"/>
144 >  <property name="jsr166e.jar"      location="${build.jsr166e.dir}/jsr166e.jar"/>
145 >  <property name="extra166y.jar"    location="${build.extra166y.dir}/extra166y.jar"/>
146 >  <property name="junit.jar"        location="${lib.dir}/junit.jar"/>
147  
148    <!-- Canonical location of jdk API docs, to use with javadoc link attribute -->
149    <property name="jdkapi5docs.url"      value="http://docs.oracle.com/javase/1.5.0/docs/api/"/>
# Line 152 | Line 151
151    <property name="jdkapi7docs.url"      value="http://docs.oracle.com/javase/7/docs/api/"/>
152  
153    <property name="jdkapi8docs.url"      value="http://download.java.net/jdk8/docs/api/"/>
154 <  <!-- The below does not yet exist as of 2012-11 -->
154 >  <!-- The below does not yet exist as of 2013-01 -->
155    <!-- <property name="jdkapi8docs.url" value="http://docs.oracle.com/javase/8/docs/api/"/> -->
156 +
157 +  <!-- Default jdk api doc location (latest stable release seems best) -->
158    <property name="jdkapidocs.url"       value="${jdkapi7docs.url}"/>
159  
160 +  <!-- Define the "jtreg" task -->
161 +  <!-- See the docs in "jtreg -onlineHelp" -->
162 +  <taskdef name="jtreg" classname="com.sun.javatest.regtest.Main$$Ant"
163 +           classpath="${lib.dir}/jtreg.jar" />
164 +
165    <!-- Test classpath -->
166    <path id="test.classpath">
167      <pathelement location="${build.testcases.dir}"/>
168      <pathelement location="${junit.jar}"/>
169    </path>
170  
171 +  <macrodef name="run-tck-tests">
172 +    <attribute name="tck.src.dir" default="${tck.src.dir}"/>
173 +    <attribute name="target"/>
174 +    <attribute name="compile-target" default="@{target}"/>
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"/>
182 +
183 +    <javac srcdir="@{tck.src.dir}"
184 +           destdir="@{workdir}/tck-classes"
185 +           debug="${build.debug}"
186 +           debuglevel="${build.debuglevel}"
187 +           deprecation="${build.deprecation}"
188 +           source="@{compile-target}"
189 +           target="@{compile-target}"
190 +           classpath="${junit.jar}"
191 +           bootclasspath="@{classes}:${bootclasspath@{compile-target}}"
192 +           includeAntRuntime="false"
193 +           includeJavaRuntime="false"
194 +           executable="${javac@{compile-target}}"
195 +           fork="true">
196 +
197 +      <include name="*.java"/>
198 +      <compilerarg value="-XDignore.symbol.file=true"/>
199 +      <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
200 +      <compilerarg line="${build.args}"/>
201 +      <javac-elements/>
202 +
203 +    </javac>
204 +
205 +    <java classname="JSR166TestCase"
206 +          failonerror="true"
207 +          jvm="${java@{target}}"
208 +          fork="true">
209 +        <jvmarg value="-Xbootclasspath/p:@{classes}"/>
210 +        <jvmarg line="@{jvmflags}"/>
211 +        <classpath>
212 +          <pathelement location="${junit.jar}"/>
213 +          <pathelement location="@{workdir}/tck-classes"/>
214 +        </classpath>
215 +    </java>
216 +
217 +    </sequential>
218 +  </macrodef>
219 +
220 +  <macrodef name="run-jtreg-tests">
221 +    <attribute name="jtreg.src.dir" default="${jtreg.src.dir}"/>
222 +    <attribute name="source" default="7"/>
223 +    <attribute name="target"/>
224 +    <attribute name="workdir"/>
225 +    <attribute name="classes"/>
226 +    <attribute name="jtregflags" default=""/>
227 +    <sequential>
228 +    <delete dir="@{workdir}/JTwork"   quiet="true"/>
229 +    <delete dir="@{workdir}/JTreport" quiet="true"/>
230 +    <mkdir dir="@{workdir}/JTwork/scratch"/>
231 +    <mkdir dir="@{workdir}/JTreport"/>
232 +    <jtreg dir="@{jtreg.src.dir}"
233 +           jdk="${jdk@{target}.home}"
234 +           workDir="@{workdir}/JTwork"
235 +           reportDir="@{workdir}/JTreport">
236 +
237 +      <arg value="-Xbootclasspath/p:@{classes}"/>
238 +      <arg value="-agentvm"/>
239 +      <arg value="-v:nopass,fail"/>
240 +      <arg value="-vmoptions:-esa -ea"/>
241 +      <arg value="-automatic"/>
242 +      <arg value="-k:!ignore"/>
243 +      <arg line="@{jtregflags}"/>
244 +    </jtreg>
245 +    </sequential>
246 +  </macrodef>
247 +
248    <!-- ALoops classpath -->
249    <path id="loops.classpath">
250      <pathelement location="${build.loops.dir}"/>
251    </path>
252  
253    <!-- Support @jls tag, used in jdk8+ javadoc -->
254 <  <!-- TODO: How do we get &trade to work? -->
172 <  <!--   property name="javadoc.jls.cite" value="The Java&trade; Language Specification" -->
173 <  <property name="javadoc.jls.cite" value="The Java Language Specification"/>
254 >  <property name="javadoc.jls.cite" value="The Java&amp;trade; Language Specification"/>
255    <property name="javadoc.jls.option" value="jls:a:See &lt;cite&gt;${javadoc.jls.cite}&lt;/cite&gt;:"/>
256  
257    <!-- Main targets -->
258  
259    <target name="dists"
260 <          depends="dist, jsr166xdist, jsr166ydist,jsr166edist,  extra166ydist"
260 >          depends="dist, 4jdk7dist, jsr166edist, jsr166ydist, extra166ydist, jsr166xdist"
261            description="Builds all public jars and docs"/>
262  
263    <target name="compile"
264            depends="configure-compiler"
265 <          description="Compiles src/main sources to build folder">
265 >          description="Compiles src/main sources to build dir">
266  
267      <mkdir dir="${build.classes.dir}"/>
268  
# Line 197 | Line 278
278             fork="true">
279  
280        <include name="**/*.java"/>
281 <      <compilerarg line="${build.args}"/>
281 >      <compilerarg value="-Xprefer:source"/>
282        <compilerarg value="-XDignore.symbol.file=true"/>
283        <compilerarg value="-Xlint:all"/>
203
204 <!--
205      <exclude name="java/lang/**"/>
284        <compilerarg line="${build.args}"/>
207      <compilerarg line="-Xlint -Xmaxwarns 1000"/>
208 -->
285  
286      </javac>
211
287    </target>
288  
289  
215
290    <target name="jar"
291            depends="compile"
292            description="Builds library jar from compiled sources">
293  
220    <mkdir dir="${build.lib.dir}"/>
221
294      <jar destfile="${product.jar}">
295        <fileset dir="${build.classes.dir}"/>
296      </jar>
225
297    </target>
298  
299  
229
300    <target name="test"
301 <          depends="init, configure-tests, report-tests"
301 >          depends="configure-tests, report-tests"
302            description="Runs all tests (requires JUnit 3.8.1 in ${ant.home}/lib)" />
303  
304  
235
305    <target name="docs"
306 <          description="Builds javadocs for src/main">
306 >          description="Builds javadocs for src/main to dist dir">
307  
308 <    <delete dir="${dist.javadocs.dir}"/>
309 <    <mkdir dir="${dist.javadocs.dir}"/>
308 >    <delete dir="${docs.dir}"/>
309 >    <mkdir dir="${docs.dir}"/>
310  
311      <!-- the packagenames="none" hack below prevents scanning the -->
312      <!-- sourcepath for packages -->
313  
314 <    <javadoc destdir="${dist.javadocs.dir}"
314 >    <javadoc destdir="${docs.dir}"
315               packagenames="none"
316               link="${jdkapi8docs.url}"
317               overview="${src.dir}/intro.html"
318 +             access="${build.javadoc.access}"
319               sourcepath="${src.dir}:${jdk8src.dir}"
320               classpath=""
321               executable="${javadoc8}">
252      <arg value="-XDignore.symbol.file=true"/>
253      <arg value="-tag"/>
254      <arg value="${javadoc.jls.option}"/>
322        <fileset dir="${src.dir}" defaultexcludes="yes">
323          <include name="**/*.java"/>
324        </fileset>
325 +      <arg value="-XDignore.symbol.file=true"/>
326 +      <arg value="-tag"/>
327 +      <arg value="${javadoc.jls.option}"/>
328      </javadoc>
259
329    </target>
330  
331  
263
332    <target name="dist"
333 <          depends="init, dist-clean, dist-jar, docs"
333 >          depends="dist-clean, dist-jar, dist-docs"
334            description="Puts all distributable products in single hierarchy"/>
335  
336  
# Line 281 | Line 349
349        <exclude name="**/SyntaxTest.java"/>
350        <exclude name="**/SuperfluousAbstract.java"/>
351      </jar>
284
352    </target>
353  
354  
288
355    <target name="clean"
356            description="Removes all build products">
357  
358      <delete dir="${build.dir}"/>
293    <delete dir="${build.classes.dir}"/>
294    <delete dir="${build.lib.dir}"/>
359  
360    </target>
361  
362  
299
363    <target name="dist-clean"
364            description="Removes all build and distribution products">
365  
# Line 305 | Line 368
368    </target>
369  
370  
308
371    <!-- Internal targets -->
372  
373  
312  <target name="init">
313
314    <!-- Version is kept in a separate file -->
315    <loadfile property="version" srcFile="version.properties"/>
316    <echo>Building JSR-166 version ${version}</echo>
317    <echo>java.home is ${java.home}</echo>
318
319  </target>
320
321
374    <target name="dist-jar"
375            depends="clean, jar">
324
376      <copy file="${product.jar}" todir="${dist.dir}"/>
377 +  </target>
378  
379 +  <target name="dist-docs"
380 +          depends="clean, docs">
381 +    <mirror-dir src="${docs.dir}" dst="${dist.docs.dir}"/>
382    </target>
383  
384  
# Line 333 | Line 388
388      <mkdir dir="${build.testcases.dir}"/>
389  
390      <javac srcdir="${tck.src.dir}"
391 <          destdir="${build.testcases.dir}"
392 <            debug="${build.debug}"
393 <       debuglevel="${build.debuglevel}"
394 <      deprecation="${build.deprecation}"
395 <           source="${build.sourcelevel}"
396 <             fork="true">
391 >           destdir="${build.testcases.dir}"
392 >           debug="${build.debug}"
393 >           debuglevel="${build.debuglevel}"
394 >           deprecation="${build.deprecation}"
395 >           source="6"
396 >           classpath="${junit.jar}"
397 >           bootclasspath="@{product.jar}:${bootclasspath6}"
398 >           includeAntRuntime="false"
399 >           includeJavaRuntime="false"
400 >           executable="${javac8}"
401 >           fork="true">
402  
403 <      <compilerarg value="${bootclasspath.args}"/>
344 <      <compilerarg line="${build.args}"/>
403 >      <include name="**/*.java"/>
404        <compilerarg value="-XDignore.symbol.file=true"/>
405 <
406 <      <classpath refid="test.classpath"/>
405 >      <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
406 >      <compilerarg line="${build.args}"/>
407  
408      </javac>
409  
410      <javac srcdir="${test.src.dir}"
411 <          destdir="${build.testcases.dir}"
412 <            debug="${build.debug}"
413 <       debuglevel="${build.debuglevel}"
414 <      deprecation="${build.deprecation}"
415 <           source="${build.sourcelevel}"
416 <             fork="true">
417 <
418 <      <include name="jsr166/test/**"/>
411 >           destdir="${build.testcases.dir}"
412 >           debug="${build.debug}"
413 >           debuglevel="${build.debuglevel}"
414 >           deprecation="${build.deprecation}"
415 >           source="6"
416 >           classpath=""
417 >           bootclasspath="@{product.jar}:${bootclasspath6}"
418 >           includeAntRuntime="false"
419 >           includeJavaRuntime="false"
420 >           executable="${javac8}"
421 >           fork="true">
422  
423 <      <compilerarg value="${bootclasspath.args}"/>
362 <      <compilerarg line="${build.args}"/>
423 >      <include name="jsr166/test/**/*.java"/>
424        <compilerarg value="-XDignore.symbol.file=true"/>
425 <
426 <      <classpath refid="test.classpath"/>
425 >      <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
426 >      <compilerarg line="${build.args}"/>
427  
428      </javac>
429  
# Line 375 | Line 436
436             source="${build.sourcelevel}"
437               fork="true">
438  
439 <      <compilerarg value="${bootclasspath.args}"/>
379 <      <compilerarg line="${build.args}"/>
439 >      <compilerarg value="-Xbootclasspath/p:${product.jar}"/>
440        <compilerarg value="-XDignore.symbol.file=true"/>
441 <
382 <      <classpath refid="test.classpath"/>
441 >      <compilerarg line="${build.args}"/>
442  
443      </javac>
444   -->
445  
446    </target>
447  
448 +  <target name="test-tck"
449 +          depends="jar"
450 +          description="Runs tck tests for main directly">
451 +
452 +    <run-tck-tests
453 +      target="8"
454 +      workdir="${build.dir}"
455 +      classes="${product.jar}"/>
456 +  </target>
457 +
458 +  <target name="test-jtreg"
459 +          depends="jar"
460 +          description="Runs jtreg tests for main using the jtreg ant task">
461 +    <run-jtreg-tests
462 +       target="8"
463 +       workdir="${build.dir}"
464 +       classes="${product.jar}"/>
465 +  </target>
466 +
467 +  <target name="test-ng"
468 +          depends="test-tck, test-jtreg"
469 +          description="Runs tck and jtreg tests for main">
470 +  </target>
471  
472    <target name="run-tests"
473            depends="compile-tests">
# Line 400 | Line 482
482            errorProperty="junit.failed"
483          failureProperty="junit.failed"
484                      dir="${build.reports.dir}"
485 +                    jvm="${java8}"
486                     fork="true">
487  
488 <      <jvmarg value="${bootclasspath.args}"/>
488 >      <jvmarg value="-Xbootclasspath/p:${product.jar}"/>
489        <jvmarg value="-server"/>
490        <jvmarg value="-showversion"/>
491  
# Line 503 | Line 586
586    <!-- Various demos and test programs -->
587  
588  
589 <  <target name="loops" depends="init, configure-compiler"
589 >  <target name="loops" depends="configure-compiler"
590            description="Benchmark from Doug Lea's AQS paper">
591  
592      <mkdir dir="${build.loops.dir}"/>
# Line 531 | Line 614
614  
615    <!-- jsr166 4jdk7 -->
616  
534
617    <target name="4jdk7compile"
618            depends="configure-compiler"
619            description="Compiles src/jdk7 sources, targeting jdk7">
# Line 543 | Line 625
625             debug="${build.debug}"
626             debuglevel="${build.debuglevel}"
627             deprecation="${build.deprecation}"
628 <           source="1.6"
628 >           source="6"
629             classpath=""
630             bootclasspath="${bootclasspath6}"
631             includeAntRuntime="false"
# Line 552 | Line 634
634             fork="true">
635  
636        <include name="**/*.java"/>
637 <      <compilerarg line="${build.args}"/>
637 >      <compilerarg value="-Xprefer:source"/>
638        <compilerarg value="-XDignore.symbol.file=true"/>
639        <compilerarg value="-Xlint:all"/>
640 +      <compilerarg line="${build.args}"/>
641  
642      </javac>
643 +  </target>
644 +
645  
646 <    <mkdir dir="${build.4jdk7.lib.dir}"/>
646 >  <target name="4jdk7jar"
647 >          depends="4jdk7compile"
648 >          description="Builds library jar from compiled sources">
649  
650 <    <jar destfile="${4jdk7product.jar}" index="true">
650 >    <jar destfile="${4jdk7product.jar}">
651        <fileset dir="${build.4jdk7.classes.dir}"/>
652      </jar>
653  
567    <mkdir dir="${build.4jdk7.tck.classes.dir}"/>
568
569    <javac srcdir="${tck.src.dir}"
570           destdir="${build.4jdk7.tck.classes.dir}"
571           debug="${build.debug}"
572           debuglevel="${build.debuglevel}"
573           deprecation="${build.deprecation}"
574           source="1.6"
575           classpath="${junit.jar}"
576           bootclasspath="${4jdk7product.jar}:${bootclasspath6}"
577           includeAntRuntime="false"
578           includeJavaRuntime="false"
579           executable="${javac7}"
580           fork="true">
581
582      <include name="**/*.java"/>
583      <compilerarg line="${build.args}"/>
584      <compilerarg value="-XDignore.symbol.file=true"/>
585      <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
586
587    </javac>
588
654    </target>
655  
656  
657    <target name="4jdk7-test-tck"
658 <          depends="4jdk7compile"
658 >          depends="4jdk7jar"
659            description="Runs tck tests for jsr166-4jdk7 directly">
660 +
661      <run-tck-tests
662 <      jvm="${java7}"
663 <      tck.classes="${build.4jdk7.tck.classes.dir}"
664 <      product.jar="${4jdk7product.jar}"/>
662 >      target="7"
663 >      workdir="${build.4jdk7.dir}"
664 >      classes="${4jdk7product.jar}">
665 >      <javac-elements>
666 >        <!-- JDK8+ test classes -->
667 >        <exclude name="*8Test.java"/>
668 >        <exclude name="DoubleAccumulatorTest.java"/>
669 >        <exclude name="DoubleAdderTest.java"/>
670 >        <exclude name="LongAccumulatorTest.java"/>
671 >        <exclude name="LongAdderTest.java"/>
672 >        <exclude name="CompletableFutureTest.java"/>
673 >        <exclude name="StampedLockTest.java"/>
674 >      </javac-elements>
675 >    </run-tck-tests>
676    </target>
677  
678  
# Line 627 | Line 704
704      </junit>
705    </target>
706  
707 +  <target name="4jdk7-test-jtreg"
708 +          depends="4jdk7jar"
709 +          description="Runs jtreg tests for jsr166-4jdk7 using the jtreg ant task">
710 +    <run-jtreg-tests
711 +       target="7"
712 +       workdir="${build.4jdk7.dir}"
713 +       classes="${4jdk7product.jar}"/>
714 +  </target>
715 +
716 +
717 +  <target name="4jdk7-test"
718 +          depends="4jdk7-test-tck, 4jdk7-test-jtreg"
719 +          description="Runs tck and jtreg tests for jsr166-4jdk7">
720 +  </target>
721 +
722  
723    <target name="4jdk7docs"
724 <          description="Builds javadocs with custom tags to build folder">
724 >          description="Builds javadocs for src/jdk7 to dist dir">
725  
726 <    <delete dir="${build.4jdk7.docs.dir}"/>
727 <    <mkdir dir="${build.4jdk7.docs.dir}"/>
726 >    <delete dir="${4jdk7docs.dir}"/>
727 >    <mkdir dir="${4jdk7docs.dir}"/>
728  
729 <    <javadoc destdir="${build.4jdk7.docs.dir}"
729 >    <javadoc destdir="${4jdk7docs.dir}"
730               packagenames="none"
731               link="${jdkapi7docs.url}"
732               overview="${4jdk7src.dir}/intro.html"
733 +             access="${build.javadoc.access}"
734               sourcepath="${4jdk7src.dir}:${jdk7src.dir}"
735               classpath=""
736               executable="${javadoc7}">
644      <arg value="-XDignore.symbol.file=true"/>
737        <fileset dir="${4jdk7src.dir}" defaultexcludes="yes">
738          <include name="**/*.java"/>
739        </fileset>
740 +      <arg value="-XDignore.symbol.file=true"/>
741      </javadoc>
649
742    </target>
743  
744  
745    <target name="4jdk7dist"
746 <          depends="4jdk7dist-clean, 4jdk7dist-jar, 4jdk7dist-docs"
746 >          depends="4jdk7dist-jar, 4jdk7dist-docs"
747            description="Puts all distributable products in single hierarchy"/>
748  
749  
658
750    <target name="4jdk7clean"
751 <          description="Removes all build products">
751 >          description="Removes all 4jdk7 build products">
752  
753      <delete dir="${build.4jdk7.dir}"/>
754  
755    </target>
756  
757  
667
758    <target name="4jdk7dist-clean"
759            description="Removes all build and distribution products">
760  
761    </target>
762  
673  <target name="4jdk7dist-docs"
674          description="Builds javadocs without custom tags to dist folder">
675
676    <delete dir="${dist.4jdk7.docs.dir}"/>
677    <mkdir dir="${dist.4jdk7.docs.dir}"/>
678
679    <javadoc destdir="${dist.4jdk7.docs.dir}"
680             packagenames="none"
681             link="${jdkapi7docs.url}"
682             overview="${4jdk7src.dir}/intro.html"
683             sourcepath="${4jdk7src.dir}:${jdk7src.dir}"
684             classpath=""
685             executable="${javadoc7}">
686      <arg value="-XDignore.symbol.file=true"/>
687      <fileset dir="${4jdk7src.dir}" defaultexcludes="yes">
688        <include name="**/*.java"/>
689      </fileset>
690    </javadoc>
691
692  </target>
693
763    <target name="4jdk7dist-jar"
764 <          depends="4jdk7clean, 4jdk7compile">
696 <
764 >          depends="4jdk7clean, 4jdk7jar">
765      <copy file="${4jdk7product.jar}" todir="${dist.dir}"/>
766 +  </target>
767  
768 +
769 +  <target name="4jdk7dist-docs"
770 +          depends="4jdk7clean, 4jdk7docs">
771 +    <mirror-dir src="${4jdk7docs.dir}" dst="${dist.4jdk7docs.dir}"/>
772    </target>
773  
701  <!-- jsr166x -->
774  
775 +  <!-- jsr166x -->
776  
777    <target name="jsr166xcompile"
778 <          depends="init, configure-compiler"
779 <          description="Compiles jsr166x sources">
778 >          depends="configure-compiler"
779 >          description="Compiles jsr166x sources to build dir">
780  
781 <    <mkdir dir="${build.jsr166x.dir}"/>
781 >    <mkdir dir="${build.jsr166x.classes.dir}"/>
782  
783 <    <javac srcdir="${jsr166xsrc.dir}"
784 <          destdir="${build.jsr166x.dir}"
785 <            debug="${build.debug}"
786 <       debuglevel="${build.debuglevel}"
787 <      deprecation="${build.deprecation}"
788 <           source="${build.sourcelevel}"
789 <             fork="true">
783 >    <javac srcdir="${topsrc.dir}"
784 >           destdir="${build.jsr166x.classes.dir}"
785 >           debug="${build.debug}"
786 >           debuglevel="${build.debuglevel}"
787 >           deprecation="${build.deprecation}"
788 >           classpath=""
789 >           bootclasspath="${bootclasspath6}"
790 >           source="5"
791 >           includeAntRuntime="false"
792 >           includeJavaRuntime="false"
793 >           executable="${javac7}"
794 >           fork="true">
795  
796 <      <include name="**/*.java"/>
719 <      <compilerarg line="${build.args}"/>
796 >      <include name="jsr166x/**/*.java"/>
797        <compilerarg value="-XDignore.symbol.file=true"/>
798 +      <compilerarg value="-Xlint:all,-unchecked,-rawtypes"/>
799 +      <compilerarg line="${build.args}"/>
800  
801      </javac>
723
802    </target>
803  
804  
727
805    <target name="jsr166xjar"
806            depends="jsr166xcompile"
807            description="Builds library jar from compiled sources">
808  
809 <    <mkdir dir="${build.jsr166xlib.dir}"/>
810 <
734 <    <jar destfile="${jsr166xproduct.jar}">
735 <      <fileset dir="${build.jsr166x.dir}"/>
809 >    <jar destfile="${jsr166x.jar}">
810 >      <fileset dir="${build.jsr166x.classes.dir}"/>
811      </jar>
812  
813    </target>
814  
815  
741
816    <target name="jsr166xdocs"
817 <          description="Builds javadocs with custom tags to build folder">
817 >          description="Builds javadocs to dist dir">
818  
819 <    <delete dir="${build.jsr166xjavadocs.dir}"/>
820 <    <mkdir dir="${build.jsr166xjavadocs.dir}"/>
819 >    <delete dir="${jsr166xdocs.dir}"/>
820 >    <mkdir dir="${jsr166xdocs.dir}"/>
821  
822 <    <javadoc destdir="${build.jsr166xjavadocs.dir}"
823 <             packagenames="jsr166x"
822 >    <javadoc destdir="${jsr166xdocs.dir}"
823 >             packagenames="jsr166x.*"
824               link="${jdkapidocs.url}"
825 <             source="${build.sourcelevel}"
826 <             sourcepath="${topsrc.dir}:${jdksrc.dir}"
827 <             additionalparam="-XDignore.symbol.file=true" />
825 >             access="${build.javadoc.access}"
826 >             sourcepath="${topsrc.dir}:${jdk6src.dir}"
827 >             bootclasspath="${bootclasspath6}"
828 >             source="5"
829 >             executable="${javadoc7}">
830 >      <arg value="-XDignore.symbol.file=true"/>
831  
832 +    </javadoc>
833    </target>
834  
835  
836    <target name="jsr166xdist"
837 <          depends="jsr166xdist-clean, jsr166xdist-jar, jsr166xdist-docs"
837 >          depends="jsr166xdist-jar, jsr166xdist-docs"
838            description="Puts all distributable products in single hierarchy"/>
839  
840  
763
841    <target name="jsr166xclean"
842 <          description="Removes all build products">
842 >          description="Removes all jsr166x build products">
843  
844      <delete dir="${build.jsr166x.dir}"/>
768    <delete dir="${build.jsr166xlib.dir}"/>
845  
846    </target>
847  
848  
773
849    <target name="jsr166xdist-clean"
850            description="Removes all build and distribution products">
851  
852    </target>
853  
854  
780
781  <target name="jsr166xdist-docs"
782          description="Builds javadocs without custom tags to dist folder">
783
784    <delete dir="${dist.jsr166xjavadocs.dir}"/>
785    <mkdir dir="${dist.jsr166xjavadocs.dir}"/>
786
787    <javadoc destdir="${dist.jsr166xjavadocs.dir}"
788             packagenames="jsr166x"
789             link="${jdkapidocs.url}"
790             source="${build.sourcelevel}"
791             sourcepath="${topsrc.dir}:${jdksrc.dir}"
792             additionalparam="-XDignore.symbol.file=true" />
793
794  </target>
795
855    <target name="jsr166xdist-jar"
856            depends="jsr166xclean, jsr166xjar">
857 +    <copy file="${jsr166x.jar}" todir="${dist.dir}"/>
858 +  </target>
859  
860 <    <copy file="${jsr166xproduct.jar}" todir="${dist.dir}"/>
861 <
860 >  <target name="jsr166xdist-docs"
861 >          depends="jsr166xclean, jsr166xdocs">
862 >    <mirror-dir src="${jsr166xdocs.dir}" dst="${dist.jsr166xdocs.dir}"/>
863    </target>
864  
865    <!-- jsr166y -->
866  
867  
868    <target name="jsr166ycompile"
869 <          depends="init, configure-compiler"
869 >          depends="configure-compiler"
870            description="Compiles jsr166y sources">
871  
872 <    <mkdir dir="${build.jsr166y.dir}"/>
872 >    <mkdir dir="${build.jsr166y.classes.dir}"/>
873  
874 <    <javac srcdir="${jsr166ysrc.dir}"
875 <          destdir="${build.jsr166y.dir}"
876 <            debug="${build.debug}"
877 <       debuglevel="${build.debuglevel}"
878 <      deprecation="${build.deprecation}"
879 <           source="${build.sourcelevel}"
880 <             fork="true">
874 >    <javac srcdir="${topsrc.dir}"
875 >           destdir="${build.jsr166y.classes.dir}"
876 >           debug="${build.debug}"
877 >           debuglevel="${build.debuglevel}"
878 >           deprecation="${build.deprecation}"
879 >           source="6"
880 >           classpath=""
881 >           bootclasspath="${bootclasspath6}"
882 >           includeAntRuntime="false"
883 >           includeJavaRuntime="false"
884 >           executable="${javac7}"
885 >           fork="true">
886  
887 <      <include name="**/*.java"/>
821 <      <compilerarg line="${build.args}"/>
887 >      <include name="jsr166y/**/*.java"/>
888        <compilerarg value="-XDignore.symbol.file=true"/>
889 <      <compilerarg value="${bootclasspath.args}"/>
890 <
825 < <!--       <compilerarg line="-Xlint -Xmaxwarns 1000"/> -->
889 >      <compilerarg value="-Xlint:all"/>
890 >      <compilerarg line="${build.args}"/>
891  
892      </javac>
828
893    </target>
894  
895  
832
896    <target name="jsr166yjar"
897            depends="jsr166ycompile"
898            description="Builds library jar from compiled sources">
899  
900 <    <mkdir dir="${build.jsr166ylib.dir}"/>
901 <
839 <    <jar destfile="${jsr166yproduct.jar}" index="true">
840 <      <fileset dir="${build.jsr166y.dir}"/>
900 >    <jar destfile="${jsr166y.jar}" index="true">
901 >      <fileset dir="${build.jsr166y.classes.dir}"/>
902      </jar>
903  
904    </target>
905  
906  
846
907    <target name="jsr166ydocs"
908 <          description="Builds javadocs with custom tags to build folder">
908 >          description="Builds javadocs to dist dir">
909  
910 <    <delete dir="${build.jsr166yjavadocs.dir}"/>
911 <    <mkdir dir="${build.jsr166yjavadocs.dir}"/>
910 >    <delete dir="${jsr166ydocs.dir}"/>
911 >    <mkdir dir="${jsr166ydocs.dir}"/>
912  
913 <    <javadoc destdir="${build.jsr166yjavadocs.dir}"
914 <             packagenames="jsr166y"
913 >    <javadoc destdir="${jsr166ydocs.dir}"
914 >             packagenames="jsr166y.*"
915               link="${jdkapidocs.url}"
916 <             source="${build.sourcelevel}"
917 <             sourcepath="${topsrc.dir}:${jdksrc.dir}"
918 <             additionalparam="-XDignore.symbol.file=true" />
916 >             access="${build.javadoc.access}"
917 >             sourcepath="${topsrc.dir}:${jdk6src.dir}"
918 >             bootclasspath="${bootclasspath6}"
919 >             source="6"
920 >             executable="${javadoc7}">
921 >      <arg value="-XDignore.symbol.file=true"/>
922  
923 +    </javadoc>
924    </target>
925  
926  
927    <target name="jsr166ydist"
928 <          depends="jsr166ydist-clean, jsr166ydist-jar, jsr166ydist-docs"
928 >          depends="jsr166ydist-jar, jsr166ydist-docs"
929            description="Puts all distributable products in single hierarchy"/>
930  
931  
868
932    <target name="jsr166yclean"
933 <          description="Removes all build products">
933 >          description="Removes all jsr166y build products">
934  
935      <delete dir="${build.jsr166y.dir}"/>
873    <delete dir="${build.jsr166ylib.dir}"/>
936  
937    </target>
938  
939  
878
940    <target name="jsr166ydist-clean"
941            description="Removes all build and distribution products">
942  
943    </target>
944  
884  <target name="jsr166ydist-docs"
885          description="Builds javadocs without custom tags to dist folder">
886
887    <delete dir="${dist.jsr166yjavadocs.dir}"/>
888    <mkdir dir="${dist.jsr166yjavadocs.dir}"/>
889
890    <javadoc destdir="${dist.jsr166yjavadocs.dir}"
891             packagenames="jsr166y"
892             link="${jdkapidocs.url}"
893             source="${build.sourcelevel}"
894             sourcepath="${topsrc.dir}:${jdksrc.dir}"
895             additionalparam="-XDignore.symbol.file=true" />
896
897  </target>
898
945    <target name="jsr166ydist-jar"
946            depends="jsr166yclean, jsr166yjar">
947 +    <copy file="${jsr166y.jar}" todir="${dist.dir}"/>
948 +  </target>
949  
950 <    <copy file="${jsr166yproduct.jar}" todir="${dist.dir}"/>
951 <
950 >  <target name="jsr166ydist-docs"
951 >          depends="jsr166yclean, jsr166ydocs">
952 >    <mirror-dir src="${jsr166ydocs.dir}" dst="${dist.jsr166ydocs.dir}"/>
953    </target>
954  
955  
# Line 908 | Line 957
957  
958  
959    <target name="extra166ycompile"
960 <          depends="init, configure-compiler, jsr166ycompile"
960 >          depends="configure-compiler, jsr166yjar"
961            description="Compiles extra166y sources">
962  
963 <    <mkdir dir="${build.extra166y.dir}"/>
963 >    <mkdir dir="${build.extra166y.classes.dir}"/>
964  
965 <    <javac srcdir="${extra166ysrc.dir}"
966 <          destdir="${build.extra166y.dir}"
967 <            debug="${build.debug}"
968 <            classpath="${jsr166yproduct.jar}"
969 <       debuglevel="${build.debuglevel}"
970 <      deprecation="${build.deprecation}"
971 <           source="${build.sourcelevel}"
972 <             fork="true">
965 >    <javac srcdir="${topsrc.dir}"
966 >           destdir="${build.extra166y.classes.dir}"
967 >           debug="${build.debug}"
968 >           debuglevel="${build.debuglevel}"
969 >           deprecation="${build.deprecation}"
970 >           bootclasspath="@{jsr166y.jar}:${bootclasspath6}"
971 >           classpath=""
972 >           source="6"
973 >           includeAntRuntime="false"
974 >           includeJavaRuntime="false"
975 >           executable="${javac7}"
976 >           fork="true">
977  
978 <      <include name="**/*.java"/>
926 <      <compilerarg line="${build.args}"/>
978 >      <include name="extra166y/**/*.java"/>
979        <compilerarg value="-XDignore.symbol.file=true"/>
980 <      <compilerarg value="${bootclasspath.args}"/>
981 <
930 < <!--       <compilerarg line="-Xlint -Xmaxwarns 1000"/> -->
980 >      <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial"/>
981 >      <compilerarg line="${build.args}"/>
982  
983      </javac>
933
984    </target>
985  
986  
937
987    <target name="extra166yjar"
988            depends="extra166ycompile"
989            description="Builds library jar from compiled sources">
990  
991 <    <mkdir dir="${build.extra166ylib.dir}"/>
992 <
944 <    <jar destfile="${extra166yproduct.jar}" index="true">
945 <      <fileset dir="${build.extra166y.dir}"/>
991 >    <jar destfile="${extra166y.jar}" index="true">
992 >      <fileset dir="${build.extra166y.classes.dir}"/>
993      </jar>
994  
995    </target>
996  
997  
951
998    <target name="extra166ydocs"
999 <          description="Builds javadocs with custom tags to build folder">
999 >          description="Builds javadocs to build dir">
1000  
1001 <    <delete dir="${build.extra166yjavadocs.dir}"/>
1002 <    <mkdir dir="${build.extra166yjavadocs.dir}"/>
1001 >    <delete dir="${extra166ydocs.dir}"/>
1002 >    <mkdir dir="${extra166ydocs.dir}"/>
1003  
1004 <    <javadoc destdir="${build.extra166yjavadocs.dir}"
1005 <             packagenames="extra166y"
1004 >    <javadoc destdir="${extra166ydocs.dir}"
1005 >             packagenames="extra166y.*"
1006               link="${jdkapidocs.url}"
1007 <             source="${build.sourcelevel}"
1008 <             sourcepath="${topsrc.dir}:${jdksrc.dir}"
1009 <             additionalparam="-XDignore.symbol.file=true" />
1007 >             access="${build.javadoc.access}"
1008 >             sourcepath="${topsrc.dir}:${jdk6src.dir}"
1009 >             bootclasspath="${bootclasspath6}"
1010 >             source="6"
1011 >             executable="${javadoc7}">
1012 >      <arg value="-XDignore.symbol.file=true"/>
1013  
1014 +    </javadoc>
1015    </target>
1016  
1017  
1018    <target name="extra166ydist"
1019 <          depends="extra166ydist-clean, extra166ydist-jar, extra166ydist-docs"
1019 >          depends="extra166ydist-jar, extra166ydist-docs"
1020            description="Puts all distributable products in single hierarchy"/>
1021  
1022  
973
1023    <target name="extra166yclean"
1024 <          description="Removes all build products">
1024 >          description="Removes all extra166y build products">
1025  
1026      <delete dir="${build.extra166y.dir}"/>
978    <delete dir="${build.extra166ylib.dir}"/>
1027  
1028    </target>
1029  
1030  
983
1031    <target name="extra166ydist-clean"
1032            description="Removes all build and distribution products">
1033  
1034    </target>
1035  
989  <target name="extra166ydist-docs"
990          description="Builds javadocs without custom tags to dist folder">
991
992    <delete dir="${dist.extra166yjavadocs.dir}"/>
993    <mkdir dir="${dist.extra166yjavadocs.dir}"/>
994
995    <javadoc destdir="${dist.extra166yjavadocs.dir}"
996             packagenames="extra166y"
997             link="${jdkapidocs.url}"
998             source="${build.sourcelevel}"
999             sourcepath="${topsrc.dir}:${jdksrc.dir}"
1000             additionalparam="-XDignore.symbol.file=true" />
1001
1002  </target>
1003
1036    <target name="extra166ydist-jar"
1037            depends="extra166yclean, extra166yjar">
1038 +    <copy file="${extra166y.jar}" todir="${dist.dir}"/>
1039 +  </target>
1040  
1041 <    <copy file="${extra166yproduct.jar}" todir="${dist.dir}"/>
1042 <
1041 >  <target name="extra166ydist-docs"
1042 >          depends="extra166yclean, extra166ydocs">
1043 >    <mirror-dir src="${extra166ydocs.dir}" dst="${dist.extra166ydocs.dir}"/>
1044    </target>
1045  
1046    <!-- jsr166e -->
# Line 1014 | Line 1049
1049            depends="configure-compiler"
1050            description="Compiles jsr166e sources">
1051  
1052 <    <mkdir dir="${build.jsr166e.dir}"/>
1052 >    <mkdir dir="${build.jsr166e.classes.dir}"/>
1053  
1054      <javac srcdir="${topsrc.dir}"
1055 <           destdir="${build.jsr166e.dir}"
1055 >           destdir="${build.jsr166e.classes.dir}"
1056             debug="${build.debug}"
1057             debuglevel="${build.debuglevel}"
1058             deprecation="${build.deprecation}"
1059 <           source="1.7"
1059 >           source="7"
1060             classpath=""
1061             includeAntRuntime="false"
1062             includeJavaRuntime="false"
# Line 1029 | Line 1064
1064             fork="true">
1065  
1066        <include name="jsr166e/**/*.java"/>
1032      <compilerarg line="${build.args}"/>
1067        <compilerarg value="-XDignore.symbol.file=true"/>
1068        <compilerarg value="-Xlint:all"/>
1069 +      <compilerarg line="${build.args}"/>
1070  
1071      </javac>
1037
1072    </target>
1073  
1074  
1041
1075    <target name="jsr166ejar"
1076            depends="jsr166ecompile"
1077            description="Builds library jar from compiled sources">
1078  
1079 <    <mkdir dir="${build.jsr166elib.dir}"/>
1080 <
1048 <    <jar destfile="${jsr166eproduct.jar}" index="true">
1049 <      <fileset dir="${build.jsr166e.dir}"/>
1079 >    <jar destfile="${jsr166e.jar}" index="true">
1080 >      <fileset dir="${build.jsr166e.classes.dir}"/>
1081      </jar>
1082  
1083    </target>
1084  
1085  
1055
1086    <target name="jsr166edocs"
1087 <          description="Builds javadocs with custom tags to build folder">
1087 >          description="Builds javadocs to build dir">
1088  
1089 <    <delete dir="${build.jsr166ejavadocs.dir}"/>
1090 <    <mkdir dir="${build.jsr166ejavadocs.dir}"/>
1089 >    <delete dir="${jsr166edocs.dir}"/>
1090 >    <mkdir dir="${jsr166edocs.dir}"/>
1091  
1092 <    <javadoc destdir="${build.jsr166ejavadocs.dir}"
1093 <             packagenames="jsr166e,jsr166e.extra"
1094 <             link="${jdkapi7docs.url}"
1095 <             source="1.7"
1092 >    <javadoc destdir="${jsr166edocs.dir}"
1093 >             packagenames="jsr166e.*"
1094 >             link="${jdkapidocs.url}"
1095 >             access="${build.javadoc.access}"
1096               sourcepath="${topsrc.dir}:${jdk7src.dir}"
1097 <             executable="${javadoc7}"
1098 <             additionalparam="-XDignore.symbol.file=true" >
1099 <      <fileset dir="${topsrc.dir}" defaultexcludes="yes">
1100 <        <include name="jsr166e/**/*.java"/>
1071 <      </fileset>
1097 >             source="7"
1098 >             executable="${javadoc7}">
1099 >      <arg value="-XDignore.symbol.file=true"/>
1100 >
1101      </javadoc>
1102 +  </target>
1103 +
1104  
1105 +  <target name="jsr166e-test-tck"
1106 +          depends="jsr166ejar"
1107 +          description="Runs tck tests for jsr166e">
1108 +
1109 +    <run-tck-tests
1110 +      tck.src.dir="${test.src.dir}/tck-jsr166e"
1111 +      target="7"
1112 +      workdir="${build.jsr166e.dir}"
1113 +      classes="${jsr166e.jar}"/>
1114    </target>
1115  
1116  
1117    <target name="jsr166edist"
1118 <          depends="jsr166edist-clean, jsr166edist-jar, jsr166edist-docs"
1118 >          depends="jsr166edist-jar, jsr166edist-docs"
1119            description="Puts all distributable products in single hierarchy"/>
1120  
1121  
1082
1122    <target name="jsr166eclean"
1123 <          description="Removes all build products">
1085 <
1123 >          description="Removes all jsr166e build products">
1124      <delete dir="${build.jsr166e.dir}"/>
1087    <delete dir="${build.jsr166elib.dir}"/>
1088
1125    </target>
1126  
1127  
1092
1128    <target name="jsr166edist-clean"
1129            description="Removes all build and distribution products">
1130  
1131    </target>
1132  
1133 <  <target name="jsr166edist-docs"
1134 <          description="Builds javadocs without custom tags to dist folder">
1135 <
1136 <    <delete dir="${dist.jsr166ejavadocs.dir}"/>
1102 <    <mkdir dir="${dist.jsr166ejavadocs.dir}"/>
1103 <
1104 <    <javadoc destdir="${dist.jsr166ejavadocs.dir}"
1105 <             packagenames="jsr166e,jsr166e.extra"
1106 <             link="${jdkapidocs.url}"
1107 <             source="1.7"
1108 <             sourcepath="${topsrc.dir}:${jdksrc.dir}"
1109 <             additionalparam="-XDignore.symbol.file=true" />
1133 >  <target name="jsr166edist-jar"
1134 >          depends="jsr166eclean, jsr166ejar">
1135 >    <copy file="${jsr166e.jar}" todir="${dist.dir}"/>
1136 >  </target>
1137  
1138 +  <target name="jsr166edist-docs"
1139 +          depends="jsr166eclean, jsr166edocs">
1140 +    <mirror-dir src="${jsr166edocs.dir}" dst="${dist.jsr166edocs.dir}"/>
1141    </target>
1142  
1113  <target name="jsr166edist-jar"
1114          depends="jsr166eclean, jsr166ejar">
1143  
1144 <    <copy file="${jsr166eproduct.jar}" todir="${dist.dir}"/>
1144 > <!-- Find buglets that can be detected by static build tools -->
1145  
1146 +  <target name="lint">
1147 +    <antcall target="dists">
1148 +      <param name="build.javadoc.access" value="private"/>
1149 +    </antcall>
1150    </target>
1151  
1152 +
1153   </project>

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines