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.37 by tim, Fri May 30 03:24:18 2003 UTC vs.
Revision 1.50 by tim, Tue Aug 5 04:03:38 2003 UTC

# Line 39 | Line 39
39    <property name="build.reports.dir"    location="${build.dir}/reports"/>
40    <property name="build.doccheck.dir"   location="${build.dir}/doccheck"/>
41    <property name="build.filter.src.dir" location="${build.dir}/filtersrc"/>
42 +  <property name="build.filter.doccheck.dir" location="${build.dir}/filterdocchk"/>
43  
44    <!-- Source locations -->
45    <property name="src.dir"              location="${basedir}/src/main"/>
# Line 56 | Line 57
57    <property name="product.jar"          location="${build.lib.dir}/jsr166.jar"/>
58    <property name="junit.jar"            location="${lib.dir}/junit.jar"/>
59    <property name="rt.jar"               location="${java.home}/lib/rt.jar"/>
60 +  <property name="sinjdoc.jar"          location="${lib.dir}/sinjdoc.jar"/>
61  
62  
63 <
64 <  <!-- Files excluded from emulation and dist-docs -->
63 <  <patternset id="emulation.excludes">
63 >  <!-- Files excluded from dist-docs and emulation jar -->
64 >  <patternset id="unsafe.exclusion">
65      <exclude name="java/util/Random.*"/>
66      <exclude name="sun/misc/Unsafe.*"/>
67    </patternset>
68  
69 +  <!-- Files excludes from emulation jar -->
70 +  <patternset id="atomic.exclusion">
71 +    <exclude name="java/util/concurrent/atomic/AtomicBoolean*"/>
72 +    <exclude name="java/util/concurrent/atomic/AtomicInteger*"/>
73 +    <exclude name="java/util/concurrent/atomic/AtomicLong*"/>
74 +    <exclude name="java/util/concurrent/atomic/AtomicReference*"/>
75 +    <exclude name="java/util/concurrent/locks/LockSupport*"/>
76 +    <exclude name="java/util/concurrent/locks/ReentrantLock*"/>
77 +  </patternset>
78 +
79  
80  
81    <!-- Main targets -->
# Line 124 | Line 135
135  
136  
137    <target name="doccheck"
138 <          depends="filter-src"
139 <          description="Reports on javadoc style errors (not working yet)">
138 >          depends="filter-doccheck"
139 >          description="Reports on javadoc style errors">
140  
141      <delete dir="${build.doccheck.dir}"/>
142      <mkdir dir="${build.doccheck.dir}"/>
# Line 133 | Line 144
144      <javadoc doclet="com.sun.tools.doclets.doccheck.DocCheck"
145           docletpath="${lib.dir}/doccheck.jar"
146              destdir="${build.doccheck.dir}">
147 <      <packageset dir="${build.filter.src.dir}"/>
147 >      <packageset dir="${build.filter.doccheck.dir}"/>
148      </javadoc>
149  
150 +    <echo>DocCheck output is in ${build.doccheck.dir}</echo>
151 +
152    </target>
153  
154  
# Line 163 | Line 176
176    </target>
177  
178  
179 +  <target name="sinjdocs"
180 +          depends="configure-tests"
181 +          description="Builds javadocs with custom tags to build folder">
182 +
183 +    <delete dir="${build.javadocs.dir}"/>
184 +    <mkdir dir="${build.javadocs.dir}"/>
185 +
186 +    <java classname="net.cscott.sinjdoc.Main" fork="true">
187 +
188 +      <jvmarg value="-Xbootclasspath/p:${test.run.bootclasspath}"/>
189 +
190 +      <classpath>
191 +        <pathelement location="${sinjdoc.jar}"/>
192 +        <path refid="test.classpath"/>
193 +      </classpath>
194 +
195 +      <!-- <arg value="-link"/>       <arg value="http://java.sun.com/j2se/1.4.1/docs/api"/> -->
196 +
197 +      <arg value="-d"/>          <arg value="${build.javadocs.dir}"/>
198 +      <arg value="-sourcepath"/> <arg value="${src.dir}"/>
199 +      <arg value="-overview"/>   <arg value="${src.dir}/intro.html"/>
200 +      <arg value="-source"/>     <arg value="1.5"/>
201 +      <arg value="-verbose"/>
202 +      <arg value="java.util"/>
203 +
204 +      <!--
205 +      <arg value="-help"/>
206 +      -->
207 +
208 +    </java>
209 +
210 +  </target>
211 +
212 +
213    <target name="strip"
214            depends="init, configure-compiler"
215            description="Strip generics from java source (not working yet)">
# Line 194 | Line 241
241            depends="init, dist-clean, dist-jar, dist-docs"
242            description="Puts all distributable products in single hierarchy"/>
243  
244 +  <target name="release"
245 +          depends="dist"
246 +          description="Puts entire CVS tree, plus distribution productions, in a jar">
247 +
248 + <!--
249 +    #keep build dir? - dl
250 +    <delete dir="${build.dir}"/>
251 + -->
252 +    <property name="release.jar" value="dist/jsr166-${version}-dist.jar"/>
253 +
254 +    <jar basedir="${basedir}" destfile="${release.jar}">
255 +      <exclude name="${release.jar}"/>
256 +      <exclude name="user.properties"/>
257 +      <exclude name="etc/notes/**"/>
258 +      <exclude name="lib/gjc/2.1/**"/>
259 +      <exclude name="**/SyntaxTest.java"/>
260 +    </jar>
261 +
262 +  </target>
263  
264    <target name="clean"
265            description="Removes all build products">
# Line 292 | Line 358
358  
359      <jar destfile="${product.jar}" duplicate="add">
360        <fileset dir="${build.classes.dir}">
361 <        <patternset refid="emulation.excludes"/>
361 >        <patternset refid="atomic.exclusion"/>
362 >        <patternset refid="unsafe.exclusion"/>
363        </fileset>
364        <fileset dir="${build.emulation.dir}"/>
365      </jar>
# Line 332 | Line 399
399        </fileset>
400      </copy>
401  
335    <!-- Not needed now, used for doccheck filtering:
336    <property name="generic.declarations"
337             value="public interface E {} public interface T {} public interface K {} public interface V {}"
338    />
339    -->
340
402      <copy todir="${build.filter.src.dir}">
403        <fileset dir="${src.dir}">
404          <exclude name="**/*.html"/>
405 <        <patternset refid="emulation.excludes"/>
405 >        <patternset refid="unsafe.exclusion"/>
406        </fileset>
407        <filterchain>
408  
# Line 377 | Line 438
438            <param name="pattern"     value="^//@"/>
439            <param name="replacement" value=""/>
440          </filterreader>
441 +      </filterchain>
442 +    </copy>
443 +
444 +  </target>
445 +
446 +
447 +
448 +
449 +  <target name="filter-doccheck"
450 +          depends="filter-src">
451 +
452 +    <mkdir dir="${build.filter.doccheck.dir}"/>
453 +
454 +    <copy todir="${build.filter.doccheck.dir}">
455 +      <fileset dir="${build.filter.src.dir}">
456 +        <include name="**/*.html"/>
457 +      </fileset>
458 +    </copy>
459  
460 +    <property name="generic.declarations"
461 +             value="/** Fake type parameter. */ public interface E {} /** Fake type parameter. */ public interface T {} /** Fake type parameter. */ public interface K {} /** Fake type parameter. */ public interface V {}"
462 +    />
463  
464 +    <copy todir="${build.filter.doccheck.dir}">
465 +      <fileset dir="${build.filter.src.dir}">
466 +        <exclude name="**/*.html"/>
467 +      </fileset>
468 +      <filterchain>
469          <!--
470 <         # The next two filters try to make the source look like
470 >         # These two filters try to make the source look like
471           # something that doccheck can process. The first removes
472           # -source 1.4 assertions and the second adds in a bunch
473           # of single letter public nested marker interfaces so that
474           # the generic type parameters are recognized.
388         #
389         # Currently commented out because doccheck doesn't work. :-(
475           -->
476  
392        <!--
477          <filterreader classname="jsr166.ant.filters.ReplaceFilter"
478                        classpath="${build.ant.dir}">
479            <param name="matching"    value="^\s*assert[\s ].*$"/>
# Line 399 | Line 483
483  
484          <filterreader classname="jsr166.ant.filters.ReplaceFilter"
485                        classpath="${build.ant.dir}">
486 <          <param name="matching"    value="^(.*(class|interface|implements) .*|)\{.*$"/>
486 >          <param name="matching"    value="^([^*]*(class|interface|implements) .*|)\{.*$"/>
487            <param name="pattern"     value="$"/>
488            <param name="replacement" value=" ${generic.declarations}"/>
489          </filterreader>
406        -->
490  
491        </filterchain>
492      </copy>
# Line 498 | Line 581
581    <target name="configure-compiler">
582  
583      <property name="gjc.version"
584 <             value="2.0"/>
584 >             value="2.2"/>
585  
586      <condition property="novariance.arg" value="-novariance">
587        <and>
# Line 539 | Line 622
622       -->
623  
624      <path id="pre.bootclasspath">
542      <!-- <pathelement location="${src.dir}"/> -->
625        <pathelement location="${javac.jar}"/>
626      </path>
627  
628      <path id="compile.bootclasspath">
629 <      <!-- <pathelement location="${src.dir}"/> -->
629 >      <pathelement location="${build.classes.dir}"/>
630        <pathelement location="${collect.jar}"/>
631        <pathelement location="${rt.jar}"/>
632      </path>
# Line 660 | Line 742
742    </target>
743  
744  
745 +  <target name="ng" depends="test">
746 +    <java classname="SuperfluousAbstract" fork="true">
747 +
748 +      <jvmarg value="-Xbootclasspath/p:${test.run.bootclasspath}"/>
749 +
750 +    </java>
751 +  </target>
752 +
753 +
754   </project>

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines