From 1159111b7a71b72eb04326df33211e1733f7e742 Mon Sep 17 00:00:00 2001 From: mattinger Date: Thu, 6 Jul 2006 21:53:00 +0000 Subject: Initial addition into subversion with build script changes git-svn-id: file:///home/sven/projects/JOGL/temp/ant-contrib/svn/ant-contrib-code/trunk/ant-contrib@5 32d7a393-a5a9-423c-abd3-5d954feb1f2f --- docs/LICENSE.txt | 47 +++ docs/manual/index.html | 91 ++++++ docs/manual/tasks/antcallback_task.html | 177 ++++++++++ docs/manual/tasks/antclipse_task.html | 139 ++++++++ docs/manual/tasks/antfetch_task.html | 151 +++++++++ docs/manual/tasks/assert_task.html | 260 +++++++++++++++ docs/manual/tasks/compilewithwalls.html | 135 ++++++++ docs/manual/tasks/for.html | 198 ++++++++++++ docs/manual/tasks/foreach.html | 145 +++++++++ docs/manual/tasks/forget.html | 62 ++++ docs/manual/tasks/if.html | 94 ++++++ docs/manual/tasks/index.html | 16 + docs/manual/tasks/inifile.html | 110 +++++++ docs/manual/tasks/limit_task.html | 280 ++++++++++++++++ docs/manual/tasks/math_task.html | 405 +++++++++++++++++++++++ docs/manual/tasks/more_conditions.html | 461 +++++++++++++++++++++++++++ docs/manual/tasks/osfamily.html | 36 +++ docs/manual/tasks/outofdate.html | 326 +++++++++++++++++++ docs/manual/tasks/pathtofileset.html | 73 +++++ docs/manual/tasks/performance_monitor.html | 159 +++++++++ docs/manual/tasks/post_task.html | 366 +++++++++++++++++++++ docs/manual/tasks/propertycopy.html | 69 ++++ docs/manual/tasks/propertyregex.html | 133 ++++++++ docs/manual/tasks/propertyselector.html | 139 ++++++++ docs/manual/tasks/runtarget.html | 38 +++ docs/manual/tasks/server_tasks.html | 260 +++++++++++++++ docs/manual/tasks/shellscript.html | 140 ++++++++ docs/manual/tasks/sortlist.html | 145 +++++++++ docs/manual/tasks/stopwatch_task.html | 115 +++++++ docs/manual/tasks/switch.html | 82 +++++ docs/manual/tasks/throw.html | 39 +++ docs/manual/tasks/timestampselector.html | 132 ++++++++ docs/manual/tasks/toc.html | 64 ++++ docs/manual/tasks/trycatch.html | 96 ++++++ docs/manual/tasks/urlencode.html | 78 +++++ docs/manual/tasks/variable_task.html | 261 +++++++++++++++ docs/manual/tasks/verifydesign.html | 264 +++++++++++++++ docs/manual/tasks/verifylegacytutorial.html | 71 +++++ docs/manual/tasks/verifynewprojtutorial.html | 39 +++ 39 files changed, 5896 insertions(+) create mode 100644 docs/LICENSE.txt create mode 100644 docs/manual/index.html create mode 100644 docs/manual/tasks/antcallback_task.html create mode 100644 docs/manual/tasks/antclipse_task.html create mode 100644 docs/manual/tasks/antfetch_task.html create mode 100644 docs/manual/tasks/assert_task.html create mode 100644 docs/manual/tasks/compilewithwalls.html create mode 100644 docs/manual/tasks/for.html create mode 100644 docs/manual/tasks/foreach.html create mode 100644 docs/manual/tasks/forget.html create mode 100644 docs/manual/tasks/if.html create mode 100644 docs/manual/tasks/index.html create mode 100644 docs/manual/tasks/inifile.html create mode 100644 docs/manual/tasks/limit_task.html create mode 100644 docs/manual/tasks/math_task.html create mode 100644 docs/manual/tasks/more_conditions.html create mode 100644 docs/manual/tasks/osfamily.html create mode 100644 docs/manual/tasks/outofdate.html create mode 100644 docs/manual/tasks/pathtofileset.html create mode 100644 docs/manual/tasks/performance_monitor.html create mode 100644 docs/manual/tasks/post_task.html create mode 100644 docs/manual/tasks/propertycopy.html create mode 100644 docs/manual/tasks/propertyregex.html create mode 100644 docs/manual/tasks/propertyselector.html create mode 100644 docs/manual/tasks/runtarget.html create mode 100644 docs/manual/tasks/server_tasks.html create mode 100644 docs/manual/tasks/shellscript.html create mode 100644 docs/manual/tasks/sortlist.html create mode 100644 docs/manual/tasks/stopwatch_task.html create mode 100644 docs/manual/tasks/switch.html create mode 100644 docs/manual/tasks/throw.html create mode 100644 docs/manual/tasks/timestampselector.html create mode 100644 docs/manual/tasks/toc.html create mode 100644 docs/manual/tasks/trycatch.html create mode 100644 docs/manual/tasks/urlencode.html create mode 100644 docs/manual/tasks/variable_task.html create mode 100644 docs/manual/tasks/verifydesign.html create mode 100644 docs/manual/tasks/verifylegacytutorial.html create mode 100644 docs/manual/tasks/verifynewprojtutorial.html (limited to 'docs') diff --git a/docs/LICENSE.txt b/docs/LICENSE.txt new file mode 100644 index 0000000..4d8c2fb --- /dev/null +++ b/docs/LICENSE.txt @@ -0,0 +1,47 @@ +/* + * The Apache Software License, Version 1.1 + * + * Copyright (c) 2001-2003 Ant-Contrib project. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in + * the documentation and/or other materials provided with the + * distribution. + * + * 3. The end-user documentation included with the redistribution, if + * any, must include the following acknowlegement: + * "This product includes software developed by the + * Ant-Contrib project (http://sourceforge.net/projects/ant-contrib)." + * Alternately, this acknowlegement may appear in the software itself, + * if and wherever such third-party acknowlegements normally appear. + * + * 4. The name Ant-Contrib must not be used to endorse or promote products + * derived from this software without prior written permission. For + * written permission, please contact + * ant-contrib-developers@lists.sourceforge.net. + * + * 5. Products derived from this software may not be called "Ant-Contrib" + * nor may "Ant-Contrib" appear in their names without prior written + * permission of the Ant-Contrib project. + * + * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED + * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL THE ANT-CONTRIB PROJECT OR ITS + * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF + * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND + * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, + * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT + * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + * ==================================================================== + */ diff --git a/docs/manual/index.html b/docs/manual/index.html new file mode 100644 index 0000000..a5ab022 --- /dev/null +++ b/docs/manual/index.html @@ -0,0 +1,91 @@ + + + + Ant-Contrib Tasks + + + +

Ant-Contrib Tasks

+ +

Contents

+ + + +

What's this?

+ +

The Ant-Contrib project is a collection of tasks (and at one + point maybe types and other tools) for Apache Ant.

+ +

This Software is distributed under the Apache Software License.

+ +

Installation

+ +

First you must install Apache Ant itself, most of the + Ant-Contrib tasks require Ant 1.5 or higher to work properly, + however, there are some tasks, specifically <for> which + require Ant 1.6. You can download Ant from + Apache.

+ +

Then you need the Ant-Contrib tasks themselves. As there is no + release of these tasks yet, you have to build them from sources. + Fortunately this is easy, check out the sources (grab the + ant-contrib module from CVS), change + into the source directory of ant-contrib and type + ant. After Ant has completed, you'll find + ant-contrib-version.jar in the lib + subdirectory.

+ +

You now have the choice:

+ +
    +
  1. Copy ant-contrib-version.jar to the + lib directory of your Ant installation, or on + your CLASSPATH environment variable. If you + want to use one of the tasks in your project, add the line +
    +<taskdef resource="net/sf/antcontrib/antlib.xml"/>
    +
    + to your build file.
  2. + +
    +
    + +
  3. Keep ant-contrib-version.jar in a separate + location. You now have to tell Ant explicitly where to find it + (say in /usr/share/java/lib): +
    +<taskdef resource="net/sf/antcontrib/antlib.xml">
    +  <classpath>
    +    <pathelement location="/usr/share/java/lib/ant-contrib-version.jar"/>
    +  </classpath>
    +</taskdef>
    +
    +
  4. + +
  5. If you would like to use run with Ant Version 1.5 you must use the + the .properties file instead. Keep in mind that some tasks will not + be available to you , such as the <for> task: + +
    +<taskdef resource="net/sf/antcontrib/antcontrib.properties">
    +  <classpath>
    +    <pathelement location="/usr/share/java/lib/ant-contrib-version.jar"/>
    +  </classpath>
    +</taskdef>
    +
    + + +
    +

    Copyright © 2002-2004 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/antcallback_task.html b/docs/manual/tasks/antcallback_task.html new file mode 100644 index 0000000..731e7c4 --- /dev/null +++ b/docs/manual/tasks/antcallback_task.html @@ -0,0 +1,177 @@ + + + + + +AntCallBack + + + + + + + + + + + + + + + +
    +
    +
    +
    +

    + + +AntCallBack

    +
    +
    +
    +
    +
    +

    + +AntCallBack is identical to the standard 'antcall' task, except that it allows properties set in the called target to be available in the calling target. +

    +

    + +

    +

    + +Some background may be in order: When the <antcall> task is used, in actuality, a new Ant project is created, and depending on the inheritAll property, it is populated with properties from the original project. Then the requested target in this new project is executed. Any properties set in the new project remain with that project, they do not get "passed back" to the original project. So, for example, if the target in the new project sets a property named "image.directory", there is no reference to that property in the original. Here's an example of what I mean: +

    +

    + + + + + +
    +
    +
    +
    +    <target name="testCallback" description="Test CallBack">
    +        <antcallback target="-testcb" return="a, b"/>
    +        <echo>a = ${a}</echo>
    +        <echo>b = ${b}</echo>
    +    </target>
    +
    +    <target name="-testcb">
    +        <property name="a" value="A"/>
    +        <property name="b" value="B"/>
    +    </target>
    +
    +
    +
    + +The output from executing "testCallback" looks like this: + + + + +
    +
    +
    +a = A
    +b = B
    +
    +
    + +Contrast with this output from "antcall": + + + + +
    +
    +
    +a = ${a}
    +b = ${b}
    +
    +
    + +

    +

    + +This is an often requested feature for Ant, at least judging from the Ant mailing lists. I assume this is because it allows a more functional programming style than Ant natively supports. The proper Ant way of doing the above is like this: + + + + +
    +
    +
    +
    +    <target name="testCallback" description="Test CallBack" depends="-testcb">
    +        <echo>a = ${a}</echo>
    +        <echo>b = ${b}</echo>
    +    </target>
    +
    +    <target name="-testcb">
    +        <property name="a" value="A"/>
    +        <property name="b" value="B"/>
    +    </target>
    +
    +
    +
    + +This is actually looks cleaner in this situation, and is faster, too. There is significant overhead in using both "antcall" and "antcallback" in that they both require a lot of object instantiation and property copying. That said, many people prefer to use "antcall" and "antcallback" as it better fits their logic and style. +

    +

    + +The attributes for AntCallBack are identical to the 'antcall' task, with one additional, optional attibute. This attribute is named "return" and can be either a single property name or a comma separated list of property names. +

    + + +

    + +Table 15.1. AntCallBack Attributes +

    + ++++++ + + + + + + + + + + + + + + + + +
    +Attribute +Description +Default +Required
    +return +A comma separated list of property names. Whitespace is allowed, so either "a,b" or "a, b" are acceptable. +None +No
    +
    + +

    +

    + +For other attribute and nested element information and more examples, see the documentation for the "antcall" task in the Ant documentation. +

    +
    +
    +

    Copyright © 2003 Ant-Contrib Project. All + rights Reserved.

    + + diff --git a/docs/manual/tasks/antclipse_task.html b/docs/manual/tasks/antclipse_task.html new file mode 100644 index 0000000..8ac5667 --- /dev/null +++ b/docs/manual/tasks/antclipse_task.html @@ -0,0 +1,139 @@ + + + + +Antclipse Task + + + + +

    Antclipse Task

    +

    Creator: Adrian Spinei (aspinei@myrealbox.com)

    +

    Description

    +

    UNSTABLE CODE, some parameters are supposed to change

    +

    This task creates classpaths or filesets based on your current .classpath file generated by Eclipse

    +

    Classpath creation is simple, it just produces a classpath that you can subsequently retrieve by its refid. +The filesets are a little trickier, because the task is producing a fileset per directory in the case of sources and another separate fileset for the +output file. Which is not necessarily bad, since the content of each directory usually serves a different purpose. Now, in order to avoit conflicting +refids each fileset has a name composed by the idcontainer, followed by a dash and postfixed by the path. Supposing that your output path is +bin/classes and the idcontainer is default, the task will create a fileset with refid "antclipse-bin/classes". The fileset will include all the files contained in +your output directory, but without the trailing path bin/classes (as you usually strip it when creating the distribution jar).

    +

    If you have two source directories, called src and test, you'll be provided with two filesets, with refids like antclipse-src and antclipse-test. +However, you don't have to code manually the path since some properties are created as a "byproduct" each time you execute the task. Their name is "idref" +postfixed by "outpath" and "srcpath" (in the case of the source, you'll find the location of the first source directory).

    + +

    Parameters

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    produceThis parameter tells the task wether to produce a "classpath" or a "fileset" (multiple filesets, as a matter of fact).Yes
    idcontainerThe refid which will serve to identify the deliverables. When multiple filesets are produces, their refid is a concatenation between this value and something else (usually obtained from a path). Default "antclipse"No
    includelibsBoolean, whether to include or not the project libraries. Default is true.No
    includesourceBoolean, whether to include or not the project source directories. Default is false.No
    includeoutputBoolean, whether to include or not the project output directories. Default is false.No
    verboseBoolean, telling the app to throw some info during each step. Default is false.No
    includesA regexp for files to include. It is taken into account only when producing a classpath, doesn't work on source or output files. It is a real regexp, not a "*" expression.No
    excludesA regexp for files to exclude. It is taken into account only when producing a classpath, doesn't work on source or output files. It is a real regexp, not a "*" expression.No
    + +

    Parameters specified as nested elements

    +

    None at the moment.

    + +

    TODOS

    +
      +
    • make "includes" and "excludes" to work on the source and output filesets
    • +
    • maybe find an elegant solution to this multiple fileset/directories issues
    • +
    • work with files referenced in other projects
    • +
    + +

    Example

    + +

    This is a pretty self-explanatory Ant script, just follow the comments.

    + +
    +<?xml version="1.0"?>
    +<project default="compile" name="test" basedir=".">
    +<taskdef name="antclipse" classname="net.sf.antcontrib.antclipse.ClassPathTask"/>
    +<target name="make.fs.output">
    +	<!-- creates a fileset including all the files from the output directory, called ecl1-bin if your binary directory is bin/ -->
    +	<antclipse produce="fileset" idcontainer="ecl1" includeoutput="true" includesource="false"
    +	includelibs="false" verbose="true"/>
    +</target>
    +<target name="make.fs.sources">
    +	<!-- creates a fileset for each source directory, called ecl2-*source-dir-name*/ -->
    +	<antclipse produce="fileset" idcontainer="ecl2" includeoutput="false" includesource="true"
    +	includelibs="false" verbose="true"/>
    +</target>
    +<target name="make.fs.libs">
    +	<!-- creates a fileset sontaining all your project libs called ecl3/ -->
    +	<antclipse produce="fileset" idcontainer="ecl3" verbose="true"/>
    +</target>
    +<target name="make.cp">
    +	<!-- creates a fileset sontaining all your project libs called ecl3/ -->
    +	<antclipse produce="classpath" idcontainer="eclp" verbose="true" includeoutput="true"/>
    +</target>
    +<target name="compile" depends="make.fs.libs, make.fs.output, make.fs.sources, make.cp">
    +    <echo message="The output path is ${ecl1outpath}"/>
    +    <echo message="The source path is ${ecl2srcpath}"/>
    +    <!-- makes a jar file with the content of the output directory -->
    +	<zip destfile="out.jar"><fileset refid="ecl1-${ecl1outpath}"/></zip>
    +	<!-- makes a zip file with all your sources (supposing you have only source directory) -->
    +	 <zip destfile="src.zip"><fileset refid="ecl2-${ecl2srcpath}"/></zip>
    +	<!-- makes a big zip file with all your project libraries -->
    +	 <zip destfile="libs.zip"><fileset refid="ecl3"/></zip>
    +	 <!-- imports the classpath into a property then echoes the property -->
    +	 <property name="cpcontent" refid="eclp"/>
    +	<echo>The newly created classpath is ${cpcontent}</echo>
    +</target>
    +</project>
    +
    + +
    +

    Copyright © 2002-2003 Ant-Contrib Project. All + rights Reserved.

    + + + + diff --git a/docs/manual/tasks/antfetch_task.html b/docs/manual/tasks/antfetch_task.html new file mode 100644 index 0000000..f92e635 --- /dev/null +++ b/docs/manual/tasks/antfetch_task.html @@ -0,0 +1,151 @@ + + + + +AntFetch + + + + + + + +
    +
    +
    +
    +

    + + +AntFetch

    +
    +
    +
    +
    +
    +

    + +AntFetch is identical to the standard 'Ant' task, except that it allows properties from the new project to be set in the original project. +

    +

    + +

    +

    + +Some background may be in order: When the <ant> task is used, in actuality, a new Ant project is created, and depending on the inheritAll property, it is populated with properties from the original project. Then the target in this new project is executed. Any properties set in the new project remain with that project, they do not get "passed back" to the original project. So, for example, if the target in the new project sets a property named "image.directory", there is no reference to that property in the original. Here's an example of what I mean: +

    +

    + +Suppose that the "fillImageDirectory" target sets a property named "image.directory" and I call the following: + + + + +
    +
    +
    +
    +    <ant dir="${image.project} target="fillImageDirectory"/>
    +    <echo>${image.directory}</echo>
    +
    +
    +
    + +The output of the echo task will be ${image.directory}, not whatever was set in the "fillImageDirectory" target. +

    +

    + +The AntFetch task allows that image.directory property to be set in the original project. The attributes for AntFetch are identical to the 'Ant' task, with one additional, optional attibute. This attribute is named "return" and can be either a single property name or a comma separated list of property names. +

    +

    + +Assuming that "fillImageDirectory" actually sets a property named "image.directory", the following example will print out the directory name: + + + + +
    +
    +
    +
    +    <antfetch dir="${image.project} target="fillImageDirectory" return="image.directory"/>
    +    <echo>${image.directory}</echo>
    +
    +
    +
    + +

    +

    + +And this one will also print out the thumbnail directory: + + + + +
    +
    +
    +
    +    <antfetch dir="${image.project} target="fillImageDirectory" return="image.directory, thumbnail.directory"/>
    +    <echo>${image.directory}</echo>
    +    <echo>${thumbnail.directory}</echo>
    +
    +
    +
    + +

    +

    + +The attributes for AntFetch are identical to the 'ant' task, with one additional, optional attibute. This attribute is named "return" and can be either a single property name or a comma separated list of property names. +

    + + +

    + +Table 14.1. AntFetch Attributes +

    + ++++++ + + + + + + + + + + + + + + + + +
    +Attribute +Description +Default +Required
    +return +A comma separated list of property names. Whitespace is allowed, so either "a,b" or "a, b" are acceptable. +None +No
    +
    + +

    +

    + +For other attribute and nested element information and more examples, see the documentation for the "ant" task in the Ant documentation. +

    +
    +
    +

    Copyright © 2003 Ant-Contrib Project. All + rights Reserved.

    + + diff --git a/docs/manual/tasks/assert_task.html b/docs/manual/tasks/assert_task.html new file mode 100644 index 0000000..7d375ce --- /dev/null +++ b/docs/manual/tasks/assert_task.html @@ -0,0 +1,260 @@ + + + + +Assert Task + + + + + + + +
    +
    +
    +
    +

    + + +Assert Task

    +
    +
    +
    +
    +
    +

    + +The Assert task adds an assertion capability to Ant projects. This task works in a manner very similar to the Java +assert + keyword, and provides a limited "design by contract" facility to Ant. This is very useful for testing build scripts prior to putting them into production. +

    +

    + +The Assert task verifies that a given property has a +given value and throws a BuildException if the property value is not as expected +or the property does not exist. +

    +

    + +Also like Java's +assert + keyword, the Assert task must be 'turned on' using the property +ant.enable.asserts +. If not set, or is set to +false +, the Assert task works exactly like the Sequential task. If the +Variable task + is used to define this property, then it can be turned on and off as needed throughout a build. +

    +

    + +This task can hold other tasks including Assert. +

    +

    + +The Assert task may contain one 'bool' element. The 'bool' element is identical to the ConditionTask, but unlike the ConditionTask, is actually a Task. The 'bool' element can contain all the conditions permitted by the ConditionTask, plus the +IsPropertyTrue +, +IsPropertyFalse +, + +StartsWith +, + +EndsWith +, + +IsGreaterThan +, + +IsLessThan + and conditions. +See the If task for examples of using these conditionals. +

    + +

    + +

    + + +

    + +Table 4.1. Assert Task Attributes +

    + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    +Attribute +Description +Default +Required
    +name +The name of the property to test for. +none +Yes
    +exists +Test for existence or non-existence of the property. +True +No
    +value +The value to test for, implies 'exists=true'. If the value in the project is different than this value, a BuildException will be thrown and the build will stop. +none +No
    +execute +Should the tasks contained in this task be executed? It may be useful to set this to false when testing build files. +True +No
    +failonerror +Should the build halt if the assertion fails? Setting this to false is contrary to the intented use of assertions, but may be useful in certain situations. +True +No
    +
    + + +

    +

    + +As stated above, the Assert task may contain a nested "bool" task, otherwise, +the Assert task does not support any nested +elements apart from Ant tasks. Any valid Ant task may be embedded within the +assert task. +

    +

    + +In the following example, the first +assert + task checks that the +wait + property exists and does not execute the +echo + and +sleep + tasks. The second +assert + task checks that the +wait + property exists, has a value of 2, and executes the +echo + task. +

    +

    + + + + + +
    +
    +
    +
    +     <property name="wait" value="2"/>
    +     <assert name="wait" execute="false">
    +        <echo>
    +            Waiting ${wait} seconds...
    +            Click the red button to stop waiting.
    +        </echo>
    +        <sleep seconds="${wait}"/>
    +     </assert>
    +     <assert name="wait" value="2" execute="true">
    +        <echo>done waiting!</echo>
    +     </assert>
    +
    +
    +
    + +

    +

    + +The next example shows Assert being used in a unit test for the "limit" task: + + + + +
    +
    +
    +
    +  <property name="ant.enable.asserts" value="true"/>
    +  <target name="test2">
    +    <!-- should not stop 'sleep' task, should print out '_passed_' -->
    +    <stopwatch name="timer"/>
    +    <limit maxwait="5">
    +        <sleep seconds="1"/>
    +        <echo>_passed_</echo>
    +    </limit>
    +    <stopwatch name="timer" action="total"/>
    +    <assert message="Too much time.">
    +        <bool>
    +            <islessthan arg1="${timer}" arg2="2"/>
    +        </bool>
    +    </assert>
    +  </target>
    +
    +
    +
    + +

    +

    + +If the +ant.enable.asserts + property is set to false, then in the above example, the +echo +, +sleep +, and +echo + tasks will all execute. +

    +
    +

    Copyright © 2003 Ant-Contrib Project. All + rights Reserved.

    +
    + + diff --git a/docs/manual/tasks/compilewithwalls.html b/docs/manual/tasks/compilewithwalls.html new file mode 100644 index 0000000..c3416cb --- /dev/null +++ b/docs/manual/tasks/compilewithwalls.html @@ -0,0 +1,135 @@ + + + + +Compile With Walls Task + + + + +

    Compile With Walls Task

    + +

    Deprecated: Use verifydesign task instead

    +

    Creator: Dean Hiller (dean@xsoftware.biz)

    +

    Description

    +

    Puts up walls in a the same source tree to ensure that designs are not violated

    +

    This task helps someone separate out packages and prevent dependencies from occurring on accident. For example, if there are three packages in one source tree +

      +
    • biz.xsoftware.mod
    • +
    • biz.xsoftware.modA
    • +
    • biz.xsoftware.modB
    • +
    +and modB and modA should be able to compiled independently, you can put a wall up in between the two so that if anyone adds a dependency between modA and modB, the build will break. This is particularly good if the builds are automated.

    + +

    This task is for low level design. For architectural walls like client and server, I would suggest using multiple source trees and compiling those source trees independently as two different ant compile targets.

    + +One pattern I personally like to follow can be seen on the vmaster project on sourceforge. Instructions to check it out and look at are HERE. The interesting files in vmaster to look at our here.... +
      +
    • vmaster/vmasterdiff/conf/build.xml(ant file using compilewithwalls)
    • +
    • vmaster/vmasterdiff/conf/dependencies.xml(The compilewithwalls task references this file as the walls)
    • +
    +Looking at some of the 2nd file(dependencies.xml), one can see apis separated out for many non-GUI and GUI components in these packages +
      +
    • api.biz.xsoftware.difflib.file.*
    • +
    • api.biz.xsoftware.difflib.dir.*
    • +
    • more api.* packages
    • +
    • org.vmasterdiff.gui.dirdiff.impl.*
    • +
    +Looking closely at the api.* packages, each one has a Factory. This factory uses reflection to create the implementation components. Basically, the api should not know of the implementation so there are walls around the api. Reflection to instantiate the implementation gets around these walls. My bigger components that use the smaller one's use these factories. In my design you are guaranteed these components are replaceable. Feel free to checkout vmaster and look at the factories also. +

    + +

    Parameters

    + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    wallsSpecifies the external dependency file to use(see example below)Either this or a nested walls element is required
    intermediaryBuildDirSpecifies scratch area for the compilewithwalls task to do the building and ensure dependencies are not violatedrequired
    + +

    Parameters specified as nested elements

    +

    This task can contain one nested javac task and one nested walls task. See the javac task for it's attributes and nested elements. + +

    +

    Walls element

    +

    +The nested walls element or the walls attribute must be specified. Only one may be used. The walls element contains nested package elements. These nested package elements have the following attributes. If any package depends on another, it must be listed after the package it depends on in the walls element. +

    + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    nameA smaller nickname for the package to reference in dependsRequired
    packageThe package to compile such as biz.xsoftware.* to + include the immediate package only or + biz.xsoftware.** to include biz.xsoftware and all subpackages.Required
    dependsIf a package need one of the previously specified packages to compile, it's name would be added here in a comma separated list. For example depends="modA,modB"Optional
    + +

    Examples

    + +In the examples, I will show the javac as a null element, because it's use is documented in the javac task documentation. + +

    Walls Nested Element....

    +
    +  <compilewithwalls>
    +     <walls>
    +        <package name="modA" package="biz.xsoftware.mod.modA.**"/>
    +        <package name="modB" package="biz.xsoftware.mod.modB.*"/>
    +        <package name="mod" package="biz.xsoftware.mod.modA.*" depends="modA,modB"/>
    +     </walls>
    +     <javac></javac>
    +  </compilewithwalls>
    +

    +Notice that the package named mod had to come after the packages it depended on. Now if anybody puts code in modA that uses classes in modB, the build will break telling them they are violating a design constraint. I personally have had many a devoloper accidentally put dependencies in that we agreed in the design should not be there. This includes myself. This prevents this from happening as long as someone doesn't change the ant build file....If someone does though, at least you can view the package dependencies and now what they are. +

    + +

    Walls attribute......

    +
    +These next lines would be in build.xml.....
    +  <compilewithwalls walls="dependencies.xml">
    +     <javac></javac>
    +  </compilewithwalls>
    + +
    +These lines would be in dependencies.xml.....
    +  <walls>
    +     <package name="modA" package="biz.xsoftware.mod.modA.**"/>
    +     <package name="modB" package="biz.xsoftware.mod.modB.*"/>
    +     <package name="mod" package="biz.xsoftware.mod.modA.*" depends="modA,modB"/>
    +  </walls>
    + + + + +
    +

    Copyright © 2002-2004 Ant-Contrib Project. All + rights Reserved.

    + + + + diff --git a/docs/manual/tasks/for.html b/docs/manual/tasks/for.html new file mode 100644 index 0000000..ecf23fe --- /dev/null +++ b/docs/manual/tasks/for.html @@ -0,0 +1,198 @@ + + + + Ant-contrib Tasks: For + + + +

    For

    + +

    The for task iterates over a list, a list of paths, or + any type that has a public iterator() method. + The list will be evaluated first. + Nested paths are evaluated in the order they + appear in the task. + Nested types will then be evalulated. +

    +

    + This task is the same as the <foreach> task, except that +

      +
    • it uses a nested sequential for each iteration; and +
    • it implements an additional "keepgoing" attribute. +
    + <for> makes use of ant's macrodef task, so the @{} notation + is used for parameter substition. +

    +

    + This task only works for ant version greater than or equal + to ant 1.6.0. + +

    + +

    Parameters

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    listThe list of values to process, with the + delimiter character, indicated by the "delimiter" + attribute, separating each value.Yes, unless a nested path + has been specified.
    paramName of the parameter to pass the tokens or + files in as to the sequential.Yes
    delimiterThe delimiter characters that separates the + values in the "list" attribute. Each character in the + supplied string can act as a delimiter. This follows the semantics + of the StringTokenizer class.No, defaults to ",".
    parallelIf true, all iterations of the nested + <sequential> + will execute in parallel. Defaults to false, + which forces sequential execution of the iterations. It is up to + the caller to ensure that parallel execution is safe. + No
    keepgoingIf true, all iterations of the called + <sequential> will be executed, even if a task in one or more of them fails. + Defaults + to false, which forces execution to stop as soon as a + task fails. At the end, if any iterator has failed, the <for> + task will fail, otherwise <for> will succeed. +

    + Note that execution does not proceed keepgoing from one task + to the next within the <sequential>, but rather from one iteration to the + next. +

    +

    It is up to the caller to ensure that keepgoing execution is safe.

    +
    No
    threadCountThe maximum number of allowable threads when executing + in parallel. + No. Defaults to 5.
    trimIf true, any leading or trailing + whitespace will be removed from the list item before it is passed + to the sequential. + No. Defaults to false.
    + +

    Parameters specified as nested elements

    + +

    path

    + +

    Paths + are used to select sets of files or directories to iterate over.

    + +

    Using a path allows you to determine the order by which files + are considered by using + filelists + or explicit pathelements. You also can specify + whether you want to iterate over files or directories by chosing + either filesets or + dirsets.

    +

    fileset

    +

    FileSets + are used to select sets of files to iterate over. +

    +

    dirset

    +

    DirSets + are used to select sets of directories to iterate over. +

    + +

    sequential

    + This is the list of tasks to be run for each iteration of + the list. +

    Example

    +

    + To print out the first five letters of the latin alphabet: +

    +
    +
    +<echo message="The first five letters of the alphabet are:"/>
    +<for list="a,b,c,d,e" param="letter">
    +  <sequential>
    +    <echo>Letter @{letter}</echo>
    +  </sequential>
    +</for>
    +        
    +
    +

    + A more complicated example to to iterate over a set + of c++ source files and invoke the <cc> task on them: +

    +
    +
    +<for param="file">
    +  <path>
    +    <fileset dir="${test.dir}/mains" includes="*.cpp"/>
    +  </path>
    +  <sequential>
    +    <propertyregex override="yes"
    +      property="program"  input="@{file}"
    +      regexp=".*/([^\.]*)\.cpp" replace="\1"/>
    +    <mkdir dir="${obj.dir}/${program}"/>
    +    <mkdir dir="${build.bin.dir}"/>
    +    <cc link="executable" objdir="${obj.dir}/${program}"
    +        outfile="${build.bin.dir}/${program}">
    +      <compiler refid="compiler.options"/>
    +      <fileset file="@{file}"/>
    +      <linker refid="linker-libs"/>
    +    </cc>
    +  </sequential>
    +</for>
    +        
    +
    + The preceding example will stop as soon as one of the <cc> tasks fails. + If you change the first line of the example to +
        <for param="file" keepgoing="true">
    + All iterations will be executed, and then <for> will fail if any one + or more of the <cc> tasks failed. +

    + The following example embeds an outofdate type and iterates over + the sources that are newer than their corresponding targets. +

    + +
    +    <ac:for param="xmlfile" xmlns:ac="antlib:net.sf.antcontrib">
    +      <ac:outofdate>
    +        <ac:sourcefiles>
    +          <ac:fileset dir="${basedir}/xdocs" includes="**/*.xml"/>
    +        </ac:sourcefiles>
    +        <ac:mapper dir="${basedir}/xdocs"
    +                   type="glob" from="*.xml" to="${basedir}/docs/*.html"/>
    +      </ac:outofdate>
    +      <ac:sequential>
    +        <echo>Need to generate a target html file from source file @{xmlfile}</echo>
    +      </ac:sequential>
    +    </ac:for>
    +      
    +
    +

    Copyright © 2003-2005 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/foreach.html b/docs/manual/tasks/foreach.html new file mode 100644 index 0000000..d3f6b0b --- /dev/null +++ b/docs/manual/tasks/foreach.html @@ -0,0 +1,145 @@ + + + + Ant-contrib Tasks: Foreach + + + +

    Foreach

    + +

    The foreach task iterates over a list, a list of paths, or + both. If both, list and paths, are specified, the list will be + evaluated first. Nested paths are evaluated in the order they + appear in the task.

    + +

    Parameters

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    listThe list of values to process, with the + delimiter character, indicated by the "delimiter" + attribute, separating each value.Yes, unless a nested Fileset + has been specified.
    targetName of the target to call for each token or + matched file.Yes
    paramName of the parameter to pass the tokens or + files in as to the target.Yes
    delimiterThe delimiter characters that separates the + values in the "list" attribute. Each character in the + supplied string can act as a delimiter. This follows the semantics + of the StringTokenizer class.No, defaults to ",".
    inheritallIf true, pass all properties to + the called target. Defaults to false.No
    inheritrefsIf true, pass all references to the + the called target. Defaults to false.No
    parallelIf true, all instances of the called + target will execute in parallel. Defaults to false, + which forces sequential execution of the targets. It is up to + the caller to ensure that parallel execution is safe. This is + accomplished through the means of the "parallel" task contained + in the ANT core.No
    maxThreadsThe maximum number of allowable threads when executing + in parallel.No. Defaults to 5.
    trimIf true, any leading or trailing + whitespace will be removed from the list item before it is passed + to the requested target + No. Defaults to false.
    + +

    Parameters specified as nested elements

    + +

    path

    + +

    Paths + are used to select sets of files or directories to iterate over.

    + +

    Using a path allows you to determine the order by which files + are considered by using + filelists + or explicit pathelements. You also can specify + whether you want to iterate over files or directories by chosing + either filesets or + dirsets.

    + +

    fileset

    + +

    FileSets + are used to select sets of files to iterate over. This + element is deprecated, use nested path elements + instead.

    + +

    param

    + +

    Specifies the properties to set before running the specified + target. See property + for usage guidelines.

    + +

    reference

    + +

    Used to chose references that shall be copied into the new + project, optionally changing their id.

    + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    refidThe id of the reference in the calling project.Yes
    torefidThe id of the reference in the called project.No, defaults to the value of + refid.
    + +
    +

    Copyright © 2002-2004 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/forget.html b/docs/manual/tasks/forget.html new file mode 100644 index 0000000..59b5d46 --- /dev/null +++ b/docs/manual/tasks/forget.html @@ -0,0 +1,62 @@ + + + + Ant-contrib Tasks: Forget + + + +

    Forget

    + +

    The Forget task will execute a set of tasks sequentially as a background + thread. Once the thread is started, control is returned to the calling + target. This is useful in being able to kick off a background server process, + such as a webserver. This allows you to not have to use the parallel + task to start server processes.

    + +

    Parameters

    + + + + + + + + + + + +
    AttributeDescriptionRequired
    daemonShould the created thread be a daemon thread. That is, + should the ANT program be allowed to exit if the thread is still + running.No. Defaults to true.
    + + +

    Example

    + + + The following code + +
    +    
    +    <forget>
    +        <exec executeable="${env.CATALINA_HOME}/bin/catalina.bat}">
    +            <arg line="start -security" />
    +        </exec>
    +    </forget>
    +
    +    <waitfor maxwait="1" maxwaitunit="minute"
    +                checkevery="100" checkeveryunit="millisecond">
    +        <http url="http://localhost:8080" />
    +    </waitfor>
    +
    +    
    +    
    + + Would start the Tomcat webserver as a background process, then waiting + for the server to become available. + +
    +

    Copyright © 2002-2003 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/if.html b/docs/manual/tasks/if.html new file mode 100644 index 0000000..e080d22 --- /dev/null +++ b/docs/manual/tasks/if.html @@ -0,0 +1,94 @@ + + + + Ant-contrib Tasks: If + + + +

    If

    + +

    Perform some tasks based on whether a given condition holds + true or not.

    + +

    This task is heavily based on the Condition framework that can + be found in Ant 1.4 and later, therefore it cannot be used + inconjunction with versions of Ant prior to 1.4. Due to numeruos + bugs in Ant 1.4(.1) that affect this task, we recommend to use Ant + 1.5 or later.

    + +

    Parameters

    + +

    This task doesn't have any attributes, the condition to test is + specified by a nested element - see the documentation of your + <condition> task (see the + online documentation for example) for a complete list of + nested elements.

    + +

    Just like the <condition> task, only a + single condition can be specified - you combine them using + <and> or <or> + conditions.

    + +

    In addition to the condition, you can specify three different + child elements, <elseif>, <then> and + <else>. All three subelements are optional. + + Both <then> and <else> must not be + used more than once inside the if task. Both are + containers for Ant tasks, just like Ant's + <parallel> and <sequential> + tasks - in fact they are implemented using the same class as Ant's + <sequential> task.

    + + The <elseif> behaves exactly like an <if> + except that it cannot contain the <else> element + inside of it. You may specify as may of these as you like, and the + order they are specified is the order they are evaluated in. If the + condition on the <if> is false, then the first + <elseif> who's conditional evaluates to true + will be executed. The <else> will be executed + only if the <if> and all <elseif> + conditions are false. + +

    Example

    + +
    
    +<if>
    + <equals arg1="${foo}" arg2="bar" />
    + <then>
    +   <echo message="The value of property foo is bar" />
    + </then>
    + <else>
    +   <echo message="The value of property foo is not bar" />
    + </else>
    +</if>
    +
    + +
    
    +<if>
    + <equals arg1="${foo}" arg2="bar" />
    + <then>
    +   <echo message="The value of property foo is 'bar'" />
    + </then>
    +
    + <elseif>
    +  <equals arg1="${foo}" arg2="foo" />
    +  <then>
    +   <echo message="The value of property foo is 'foo'" />
    +  </then>
    + </elseif>
    +
    +
    + <else>
    +   <echo message="The value of property foo is not 'foo' or 'bar'" />
    + </else>
    +</if>
    +
    + +
    +

    Copyright © 2002-2003 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/index.html b/docs/manual/tasks/index.html new file mode 100644 index 0000000..8da6784 --- /dev/null +++ b/docs/manual/tasks/index.html @@ -0,0 +1,16 @@ + + + + Ant-Contrib Tasks + + + + + + + + <h2>Ant-Contrib Tasks</h2> + + <a href="toc.html">Task List</a> + + diff --git a/docs/manual/tasks/inifile.html b/docs/manual/tasks/inifile.html new file mode 100644 index 0000000..d5722a9 --- /dev/null +++ b/docs/manual/tasks/inifile.html @@ -0,0 +1,110 @@ + + + + Ant-contrib Tasks: IniFile + + + +

    IniFile

    + +

    Build and Edit Windows .ini files. Only the simple edits, + remove and set are allowed. Set + has limited computation capability which is described later.

    + +

    Parameters

    + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    sourceThe name source .ini file to read in.No.
    destThe name destination .ini file to write.Yes.
    + + +

    Parameters specified as nested elements

    + + remove + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    sectionThe name of the sectionYes.
    propertyThe name property.No. If not supplied, the entire + section will be removed
    + + set + + + + + + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    sectionThe name of the sectionYes.
    propertyThe name property.Yes.
    valueThe value to set the property to.No, if + operation is specified.
    operationThe operation to perform on the existing value. + Possible values are "+" and "-", which add and subtract 1, + respectively from the existing value. If the value doesn't + already exist, the set is not performed.No, if value + is specified.
    + +

    Example

    + + + +
    
    +
    +<inifile source="myprog.ini" dest="myprog.new.ini">
    +   <set section="Section1" property="release-date" value="${todays.date}" />
    +   <set section="Section1" property="build-number" operation="+" />
    +   <remove section="Section2" property="useless" />
    +   <remove section="OutdatedSection" />
    +</inifile>
    +
    + + +
    +

    Copyright © 2002-2003 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/limit_task.html b/docs/manual/tasks/limit_task.html new file mode 100644 index 0000000..fb8f305 --- /dev/null +++ b/docs/manual/tasks/limit_task.html @@ -0,0 +1,280 @@ + + + + +Chapter 10. Limit + + + + + + + +
    +
    +
    +
    +

    + + +Limit

    +
    +
    +
    +
    +
    +

    + +The Limit task is a task container (that is, it holds other tasks) and sets a time limit on how long the nested tasks are allowed to run. This is useful for unit tests that go awry, hung socket connections, or other potentially long running tasks that need to be shut off without stopping the build. +

    + +

    + +

    + + +

    + +Table 10.1. Limit Task Attributes +

    + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    +Attribute +Description +Default +Required
    +maxwait +How long to wait for nested tasks to finish. +180 seconds (3 minutes) +No
    +maxwaitunit +The unit for maxwait. Valid values are "millisecond", "second", "minute", "hour", "day", "week". +seconds +No
    +failonerror +Should the build fail if the time limit has been exceeded? +false +No
    +property +The name of a property to set if the max wait time is exceeded. +none +No
    +value +The value to set for the property if the max wait time is exceeded. +true +No
    +milliseconds +How long to wait in milliseconds. +3 minutes +No
    +seconds +How long to wait in seconds. +3 minutes +No
    +minutes +How long to wait in minutes. +3 minutes +No
    +hours +How long to wait in hours. +3 minutes +No
    +days +How long to wait in days. +3 minutes +No
    +weeks +How long to wait in weeks. +3 minutes +No
    +
    + +

    +

    + +Examples: +

    +

    + +Neither the echo nor the fail will happen in this example. The build will continue once the time has expired. + + + + +
    +
    +
    +
    +<limit maxwait="3">
    +   <sleep seconds="10"/>
    +   <echo>This won't happen...</echo>
    +   <fail>This won't happen either...</fail>
    +</limit>
    +
    +
    +
    + +

    +

    + +This is identical to the above example, but uses the convenience "seconds" attribute: + + + + +
    +
    +
    +
    +<limit seconds="3">
    +   <sleep seconds="10"/>
    +   <echo>This won't happen...</echo>
    +   <fail>This won't happen either...</fail>
    +</limit>
    +
    +
    +
    + +

    +

    + +Neither the echo nor the fail will happen in this example. The build will not continue once the time has expired. + + + + +
    +
    +
    +
    +<limit maxwait="3" failonerror="true">
    +   <sleep seconds="10"/>
    +   <echo>This won't happen...</echo>
    +   <fail>This won't happen either...</fail>
    +</limit>
    +
    +
    +
    + +

    +

    + +The limit will be reached and a property will be set indicating so. + + + + +
    +
    +
    +
    +<limit minutes="3" property="limit_reached">
    +   <sleep minutes="10"/>
    +   <echo>This won't happen...</echo>
    +   <fail>This won't happen either...</fail>
    +</limit>
    +<echo>limit_reached = ${limit_reached)</echo>
    +
    +
    + +

    +
    +
    +

    Copyright © 2003-2004 Ant-Contrib Project. All + rights Reserved.

    + + diff --git a/docs/manual/tasks/math_task.html b/docs/manual/tasks/math_task.html new file mode 100644 index 0000000..bac6e04 --- /dev/null +++ b/docs/manual/tasks/math_task.html @@ -0,0 +1,405 @@ + + + + +Math + + + + + + + +
    +
    +
    +
    +

    + + +Math

    +
    +
    +
    +
    +
    +

    + +The Math task provides support for all the basic mathematical operations +provided by the java.lang.Math and java.lang.StrictMath classed. It supports int, long, float and double data types. Nesting of operations is supported to allow computation of formulas like (6 + (7.25 * 3.9))/(2 * 3 * 3) or calculating the area of a circle given a radius (I'm sure this comes up often in builds controlled by Ant!). +

    +

    + +In addition to the operations provided by the java.lang.Math and java.lang.StrictMath classes, the Math task provides several additional operations: "add", "subtract", "multiply", "divide", and "mod", which duplicate the basic Java mathematical operations "+", "-", "*", "/", and "%", respectively. In fact, either notation can be used, that is, the operation can be set to "add" or "+", depending only on which you feel is more convenient. +

    + +

    + +

    + + +

    + +Table 11.1. Math Task Attributes +

    + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    +Attribute +Description +Default +Required
    +result +The name of the property to hold the result of the operation. +None +Yes
    +datatype +Sets the datatype of the calculation. Allowed values are +"int", "long", "float", or "double". Optional, if +used, will be applied to all numbers in this math operation. +double +No
    +strict +If true, use the methods in the java.lang.StrictMath class. +false +No
    +operation +If used, any nested Ops will be ignored. This is for convenience for simple calculations. +None +No
    +operand1 +A number to use with the operation specified in the 'operation' attribute. +None +Depends on the specific operation.
    +operand2 +A number to use with the operation specified in the 'operation' attribute. +None +Depends on the specific operation.
    +
    + +

    +

    + +The 'result' property is reusable. +

    + + +The Math task supports nested "Op" elements. An Op element represents single mathematical operation, such as "min" or "add". +As an alternate, if using Ant 1.5+, you can specify the operation in the tag name itself. However, you must use the text +name (+,-,/,*,% are not permitted as tag names) + +
    +  <radians>
    +     <num value="90" />
    +  </radians>
    +
    + +instead of + +
    +  <op op="radians">
    +     <num value="90" />
    +  </op>
    +
    + + +

    + +

    + + +

    + +Table 11.2. Op Attributes +

    + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    +Attribute +Description +Default +Required
    +op +Set the name of this operation. Allowed values are +one of the method names from java.lang.Math or java.lang.StrictMath, or one of +"add", "subtract", "multiply", "divide", or "mod" (or "+", "-", "*", "/", or "%", +respectively). "toRadians" and "toDegrees" can be represented by "radians" and +"degrees", respectively, as a shorthand +None +Yes, if not specified in the tag name.
    +datatype +Sets the datatype of this calculation. Allowed values are +"int", "long", "float", or "double". Optional, default +is "double". If the parent Math task has a datatype set, this value will be ignored and the datatype specifed in the task will be used. +"int" +No
    +arg1, arg2, arg3, arg4, arg5/td> + +The arguments for this operation. This is a shorthand to avoid having to use nested +elements when performing a simple calculation. + +None +No. However, these attributes are mutually exclusive with the and subelements.
    +
    + +

    +

    + +The Op element supports nested "Op" elements and nested "Num" elements. A Num represents a number. +When an Op is nested in another Op, the result of the Op is treated as a Num. The nested elements +can be any combination of Op (short form included as mentioned above) or Num as appropriate for the +formula being calculated. Most of the +operations provided by java.lang.Math and java.lang.StrictMath operate on one or two numbers. +The "+", "-", "*", "/", and "%" operations can task any number of nested numbers. +

    +

    + +

    + + +

    + +Table 11.3. Num Attributes +

    + ++++++ + + + + + + + + + + + + + + + + + + + + + + +
    +Attribute +Description +Default +Required
    +value +Set the value for this number. Must be able to parse to the datatype set by the parent element or the default datatype set by the task. Two special numbers, pi and e, can be represented by PI and E respectively. ("PI" is the ratio of the diameter of a circle to its radius, "E" is Euler's e, the base for natural logrithms.) +None +Yes
    +datatype +Sets the datatype of this number. Allowed values are +"int", "long", "float", or "double". Optional, default +is "double". If the parent Math task has a datatype set, this value will be ignored and the datatype specifed in the task will be used. +double +No
    +
    + +

    +

    + +Some examples: +

    +

    + + + + + +
    +
    +
    +
    +    <var name="op1" value="12"/>
    +    <var name="op2" value="6"/>
    +    <var name="op" value="+"/>
    +
    +    <!-- demo plus -->
    +    <math result="result" operand1="${op1}" operation="${op}" operand2="${op2}" datatype="int"/>
    +    <echo>${op1} ${op} ${op2} = ${result}</echo>
    +    <assert name="result" value="18"/>
    +
    +    <!-- demo reusing result -->
    +    <math result="result" operand1="${result}" operation="${op}" operand2="${op2}" datatype="int"/>
    +    <echo>${op1} ${op} ${op2} = ${result}</echo>
    +    <assert name="result" value="24"/>
    +
    +    <!-- demo minus -->
    +    <var name="op" value="-"/>
    +    <math result="result" operand1="${op1}" operation="${op}" operand2="${op2}" datatype="int"/>
    +    <echo>${op1} ${op} ${op2} = ${result}</echo>
    +    <assert name="result" value="6"/>
    +
    +    <!-- demo multiply -->
    +    <var name="op" value="*"/>
    +    <math result="result" operand1="${op1}" operation="${op}" operand2="${op2}" datatype="int"/>
    +    <echo>${op1} ${op} ${op2} = ${result}</echo>
    +    <assert name="result" value="72"/>
    +
    +    <!-- demo divide -->
    +    <var name="op" value="/"/>
    +    <math result="result" operand1="${op1}" operation="${op}" operand2="${op2}" datatype="int"/>
    +    <echo>${op1} ${op} ${op2} = ${result}</echo>
    +    <assert name="result" value="2"/>
    +
    +    <!-- demo modulo -->
    +    <var name="op" value="%"/>
    +    <math result="result" operand1="${op1}" operation="${op}" operand2="${op2}" datatype="int"/>
    +    <echo>${op1} ${op} ${op2} = ${result}</echo>
    +    <assert name="result" value="0"/>
    +
    +    <!-- demo calculating the area of a circle -->
    +    <!-- first, calculate the radius -->
    +    <math result="radius">  <!-- defaults to double datatype -->
    +        <op type="*">
    +            <num value="1"/>
    +            <num value="2"/>
    +            <num value="3"/>
    +            <num value="4"/>
    +            <num value="5"/>
    +        </op>
    +    </math>
    +    <echo> 1 * 2 * 3 * 4 * 5 = ${radius}</echo>
    +
    +    <!-- now calculate the area -->
    +    <math result="area" precision="float">
    +        <op type="*">
    +            <num value="PI"/>
    +            <op type="pow">
    +                <num value="${radius}"/>
    +                <num value="2"/>
    +            </op>
    +        </op>
    +    </math>
    +    <echo>area = PI * radius ^ 2 = ${area}</echo>
    +
    +    <!-- demo calculating a random number between 0 and 100 -->
    +    <math result="result">
    +        <op op="rint">
    +            <op op="*">
    +                <num value="100"/>
    +                <op op="random"/>
    +            </op>
    +        </op>
    +    </math>
    +    <echo>a random number between 0 and 100: ${result}</echo>
    +
    +    <!-- demo another multiplication -->
    +    <math result="result" operation="multiply" operand1="17" operand2="13"/>
    +    <echo>${result}</echo>
    +
    +    <!-- demo shorthand notation for calculating sin of an angle, which is degrees -->
    +    <math result="sin">
    +      <sin>
    +        <radians arg1="${angle_in_degrees}" />
    +      </sin>
    +    </math>
    +    <echo>${sin}</echo>
    +
    +
    +
    + +

    +
    +
    +

    Copyright © 2003 Ant-Contrib Project. All + rights Reserved.

    + + diff --git a/docs/manual/tasks/more_conditions.html b/docs/manual/tasks/more_conditions.html new file mode 100644 index 0000000..5c64602 --- /dev/null +++ b/docs/manual/tasks/more_conditions.html @@ -0,0 +1,461 @@ + + + + +More Conditions + + + + + + + +
    +
    +
    +
    +

    + + +More Conditions

    +
    +
    +
    +
    +
    +

    + +These conditions are suitable for use in the <bool> element. Unfortunately, they cannot be used in the <condition> task, although all conditions for the <condition> task can be used with the <bool> and the <bool> can be used anywhere that <condition> can be used. +

    +

    + + +IfPropertyTrue

    +

    + +Given a property name, tests whether the value for that property equals "true" (or "yes" or "on"). +

    +

    + +

    + + +

    + +Table 5.2. IfPropertyTrue Attributes +

    + +++++ + + + + + + + + + + + + + + +
    +Attribute +Description +Required
    +property +The name of a property to test the value of. +Yes
    +
    + +

    +

    + + + + + +
    +
    +
    +
    +<ispropertytrue property="myprop"/>
    +<ispropertytrue property="${someprop}"/>
    +
    +
    +
    + +

    +

    + + +IfPropertyFalse

    +

    + +Given a property name, tests whether the value for that property equals "false" (or "no" or "off"). +

    +

    + +

    + + +

    + +Table 5.3. IfPropertyFalse Attributes +

    + +++++ + + + + + + + + + + + + + + +
    +Attribute +Description +Required
    +property +The name of a property to test the value of. +Yes
    +
    + +

    +

    + + + + + +
    +
    +
    +
    +<ispropertyfalse property="myprop"/>
    +<ispropertyfalse property="${someprop}"/>
    +
    +
    +
    + +

    +

    + + +StartsWith

    +

    + +Given a property name, tests whether the value for that property starts with a specified string. +

    +

    + +

    + + +

    + +Table 5.4. StartsWith Attributes +

    + +++++ + + + + + + + + + + + + + + + + + + + +
    +Attribute +Description +Required
    +string +The string to test. +Yes
    +with +Check if 'string' starts with this value. +Yes
    +
    + +

    +

    + + + + + +
    +
    +
    +
    +<startswith string="abcdefg" with="abc"/>
    +<startswith string="${myprop}" with="foo"/>
    +
    +
    +
    + +

    +

    + + +EndsWith

    +

    + +Given a property name, tests whether the value for that ends with with a specified string. +

    +

    + +

    + + +

    + +Table 5.5. EndsWith Attributes +

    + +++++ + + + + + + + + + + + + + + + + + + + +
    +Attribute +Description +Required
    +string +The string to test. +Yes
    +with +Check if 'string' ends with this value. +Yes
    +
    + +

    +

    + + + + + +
    +
    +
    +
    +<endswith string="abcdefg" with="efg"/>
    +<endswith string="${myprop}" with="bar"/>
    +
    +
    +
    + +

    +

    + + +IsGreaterThan

    +

    + +Tests whether the first argument is greater than the second argument. Will +automatically treat the arguments as numbers if both arguments consists of only the characters 0 through 9 and optionally a decimal point. Otherwise, a String +comparison is used. +

    +

    + +

    + + +

    + +Table 5.6. IsGreaterThan Attributes +

    + +++++ + + + + + + + + + + + + + + + + + + + +
    +Attribute +Description +Required
    +arg1 +The first argument. +Yes
    +arg2 +The second argument. +Yes
    +
    + +

    +

    + + + + + +
    +
    +
    +
    +<!-- evaluates to true -->
    +<isgreaterthan arg1="6.02" arg2="4"/>
    +
    +<!-- evaluates to false -->
    +<isgreaterthan arg1="bar" arg2="foo"/>
    +
    +
    +
    + +

    +

    + + +IsLessThan

    +

    + +Tests whether the first argument is less than the second argument. Will +automatically treat the arguments as numbers if both arguments consists of only the characters 0 through 9 and optionally a decimal point. Otherwise, a String +comparison is used. +

    +

    + +

    + + +

    + +Table 5.7. IsLessThan Attributes +

    + +++++ + + + + + + + + + + + + + + + + + + + +
    +Attribute +Description +Required
    +arg1 +The first argument. +Yes
    +arg2 +The second argument. +Yes
    +
    + +

    +

    + + + + + +
    +
    +
    +
    +<!-- evaluates to false -->
    +<islessthan arg1="6.02" arg2="4"/>
    +
    +<!-- evaluates to true -->
    +<islessthan arg1="bar" arg2="foo"/>
    +
    +
    +
    + +

    +
    +
    +

    Copyright © 2003 Ant-Contrib Project. All + rights Reserved.

    + + diff --git a/docs/manual/tasks/osfamily.html b/docs/manual/tasks/osfamily.html new file mode 100644 index 0000000..e56bdaf --- /dev/null +++ b/docs/manual/tasks/osfamily.html @@ -0,0 +1,36 @@ + + + + Ant-contrib Tasks: Osfamily + + + +

    Osfamily

    + +

    Task definition for the OsFamily task. This task + sets the property indicated in the "property" attribute + with the string representing the operating system family. + Possible values include "unix", "dos", + "mac", "os/2", "os/400", + "z/os", "tandem" and "windows".

    + +

    Parameters

    + + + + + + + + + + + +
    AttributeDescriptionRequired
    propertyThe name of the property to set with the OS + family name.Yes.
    +
    +

    Copyright © 2002-2003 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/outofdate.html b/docs/manual/tasks/outofdate.html new file mode 100644 index 0000000..adffa19 --- /dev/null +++ b/docs/manual/tasks/outofdate.html @@ -0,0 +1,326 @@ + + + + + Ant-contrib Tasks: OutOfDate + + + + + +

    OutOfDate

    +

    Task definition for the outofdate task. This is an +extension of uptodate which allows multible targets and contains an +embedded <parallel> or <sequential> element. If any of +the target file's dates are earlier than any of the source file's +dates, then the specified <parallel> or <sequential> +block is executed. The task may also contain mappers to map source +files to corresponding target files. +

    +

    Parameters

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    +

    Attribute

    +
    +

    Description

    +
    +

    Required

    +
    +

    property

    +
    +

    The name of the property to set to the contents of the value + parameter if any of the target files are out of date

    +
    +

    No

    +
    +

    value

    +
    +

    The value to set the property specified by the parameter + property to, if any of the target files are out of + date

    +
    +

    No, defaults to "true"

    +
    force + Force outofdate ("true"/"false"). Default is "false". + No
    verbose + Set vebose logging level for this task ("true"/"false"). + Default is "false". + No
    +

    outputsources

    +
    +

    The name of a property to set containing the sources that are + newer that their corresponding targets.

    +
    +

    No

    +
    +

    outputtargets

    +
    +

    The name of a property to set containing the targets that are + outofDate with respect to their corresponding sources.

    +
    +

    No

    +
    +

    alltargets

    +
    +

    The name of a property to set containing all the targets. This + is usefull for debugging mapper nested elements.

    +
    +

    No

    +
    +

    separator

    +
    +

    The separator used to separate the files in the properties + above. If a filename contains the separator, double quotes will be + placed aroudnd the filename.

    +
    +

    No, defaults to “ “

    +
    +

    outputsourcespath

    +
    +

    The id of a path to create containing the source files that are + outofdate.

    +
    +

    No

    +
    +

    outputtargetspath

    +
    +

    The id of a path to create containing the target files that + need to be updated.

    +
    +

    No

    +
    +

    alltargetspath

    +
    +

    The id of a path to create containing all the target files. +

    +
    +

    No

    +
    +

    Attributes specified as nested elements

    + +

    sourcefiles - The list of files which are source files. +This element is required. +

    targetfiles - The list of +files which are target files. +

    +

    Both of these nested elements are Path +elements which are are used to select sets or lists of files or +directories

    +

    The sourcefiles may contain no files. In this case, outofdate will + check the existance of the targetfiles.

    +

    mapper – This is used to map source files to target +files.

    +As well as the regular attributes for mapper, there is a extra attribute to specify + the relative directory of the sources.

    + + + + + + + + + + + +
    AttributeDescriptionRequired
    dir + The directory to the sources are relative to for the mapper. + Default is ${base.dir}. + No
    + +

    There may be a number of mapper nested elements. +

    deletetargets – This is used to delete targets if the +corresponding sources are outofdate. +

    + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    all + Whether to delete all the targets ("true"/"false"). Defaults to + "false". + No
    quiet + Do not display diagnostic messages when deleting targets + ("true"/ "false"). Defaults to false. + When set to "true", if a file or directory cannot be deleted, + no error is reported. This setting emulates the -f option to + the Unix rm command. Default is "false". + Setting this to "true" implies setting failonerror to "false" + No
    failonerror + Controls whether an error (such as a failure to delete a file) + stops the build or is merely reported to the screen. + Only relevant if quiet is "false". + Default is "true". + Controls whether a failure to delete a target stops + the build or is merely reported to the screen. + No
    + +

    +

    Examples

    +

    The following example creates the file ${jrun.file} if is older +that build.xml, or any file in ${lib.dir}.

    +
            <outofdate>
    +          <sourcefiles>
    +            <pathelement path="build.xml"/>
    +            <fileset dir="${lib.dir}"/>
    +          </sourcefiles>
    +          <targetfiles path="${jrun.file}"/>
    +          <sequential>
    +            <mkdir dir="${build.bin.dir}"/>
    +            <echo file="${jrun.file}" message="java -cp ${jrun.path} $*"/>
    +            <chmod file="${jrun.file}" perm="ugo+rx"/>
    +          </sequential>
    +        </outofdate> 

    +The following example check the generated files, MODULE.IDS, +acme_agent_mib.h, acme_agent_mib.cpp are older that miblist.txt, or +any file in ${mib.src}, and if so an embedded shellScript is invoked +to update the files.

    +
            <outofdate>
    +          <sourcefiles>
    +            <pathelement path="${agent.src}/miblist.txt"/>
    +            <fileset dir="${mib.src}"/>
    +          </sourcefiles>
    +          <targetfiles>
    +            <pathelement path="${rep}/MODULE.IDS"/>
    +            <pathelement path="${gen-agent}/acme_agent_mib.h"/>
    +            <pathelement path="${gen-agent}/acme_agent_mib.cpp"/>
    +          </targetfiles>
    +          <sequential>
    +            <shellscript shell="bash" dir="${agent.src}">
    +                    classname=com.agentpp.agentgen.AgentGenConsole
    +                    h1=${gen-agent}/acme_agent_mib.x
    +                    ag() {
    +                        java -cp ${lib.dir}/agentgen.jar $classname ${rep} $@
    +                    }
    +                    ag initialize
    +                    ag load miblist.txt
    +                    ag generate ACME-AGENT-MIB h > $h1
    +                    (head -16 $h1; echo "using namespace Agentpp;";
    +                    tail +16 $h1) > ${gen-agent}/acme_agent_mib.h
    +                    ag generate ACME-AGENT-MIB c >\
    +                        ${gen-agent}/acme_agent_mib.cpp
    +            </shellscript>
    +          </sequential>
    +        </outofdate>

    +The following example sets the project manual.outofdate if any +of the xml files are newer than index.html, or if any of the xml +files are newer than their corresponding .html file. A path +identified by sources.path, is created which contains the +sources that fullfilled these conditions.

    +
    +    <outofdate property="manual.outofdate" outputsourcespath="sources.path">
    +      <sourcefiles>
    +        <fileset dir="${src.manual}" includes="**/*.xml"/>
    +      </sourcefiles>
    +      <targetfiles path="${doc.manual}/index.html"/>
    +      <mapper type="glob" dir="${src.manual}" from="*.xml" to="${doc.manual}/*.html"/>
    +    </outofdate>
    +
    +

    +The following assumes that there is a program called gengrammer +that takes a grammer file as an input and generates a .h and a .c +file in the current directory.

    +
    +  <outofdate property="manual.outofdate"
    +             outputsources="grammer.sources">
    +    <sourcefiles>
    +      <fileset dir="${src.grammer}" includes="**/*.y"/>
    +    </sourcefiles>
    +    <mapper type="glob" dir="${src.grammer}" from="*.y" to="${gen.grammer}/*.c"/>
    +    <mapper type="glob" dir="${src.grammer}" from="*.y" to="${gen.grammer}/*.h"/>
    +    <sequential>
    +      <shellscript shell="bash">
    +        cd ${gen.grammer}
    +        for g in ${grammer.sources}
    +        do
    +            gengrammer $g
    +        done
    +      </shellscript>
    +    </sequential>
    +  </outofdate>
    +
    +
    +

    Copyright © 2003 Ant-Contrib Project. All rights +Reserved.

    + + \ No newline at end of file diff --git a/docs/manual/tasks/pathtofileset.html b/docs/manual/tasks/pathtofileset.html new file mode 100644 index 0000000..52e9cb7 --- /dev/null +++ b/docs/manual/tasks/pathtofileset.html @@ -0,0 +1,73 @@ + + + + Ant-contrib Tasks: Pathtofileset + + + +

    Pathtofileset

    + +

    Coverts a path to a fileset. This is usefull if you have + a path but need to use a fileset as input in a ant task. +

    + +

    Parameters

    + + + + + + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    dirThe root of the directory tree of this FileSetYes
    pathrefidThe reference to the path to convert fromYes
    ignorenonrelativeThis boolean controls what will happen if any of the + files in the path are not in the directory for the fileset. If this + is "true" the files are ignored, if this is "false" a build exception + is thrown. (Note: if files are not present no check is made). + No, default is "false"
    nameThis is the identifier of the fileset to create. This + fileset will contain the files that are relative to the directory root. + Any files that are not present will not be placed in the set. + Yes
    + +

    Example

    +
    +    <outofdate outputsourcespath="modified.sources.path">
    +      <sourcefiles>
    +        <fileset dir="a/b/c" includes="**/*.java"/>
    +      </sourcefiles>
    +      <mapper dir="a/b/c" type="glob" from="*.java" to="output/*.xml"/>
    +      <sequential>
    +        <pathtofileset name="modified.sources.fileset"
    +                       pathrefid="modified.sources.path"
    +                       dir="a/b/c"/>
    +        <copy todir="output">
    +          <fileset refid="modified.sources.fileset"/>
    +          <mapper type="glob" from="*.java" to="*.xml"/>
    +        </copy>
    +      </sequential>
    +    </outofdate>
    +    
    + +
    +

    Copyright © 2003 Ant-Contrib Project. All + rights Reserved.

    + + diff --git a/docs/manual/tasks/performance_monitor.html b/docs/manual/tasks/performance_monitor.html new file mode 100644 index 0000000..3f92c80 --- /dev/null +++ b/docs/manual/tasks/performance_monitor.html @@ -0,0 +1,159 @@ + + + + +Performance Monitoring + + + + + + + +
    +
    +
    +
    +

    + + +Performance Monitoring

    +
    +
    +
    +
    +
    +

    + +The "Performance Monitor" is +a special Ant listener than can keep track of the amount of time that each target +and task takes to execute. At the end of the build, these times will be sorted +from fastest to slowest and displayed following the build output. This can be +useful to pinpoint slow and/or inefficient spots in the build process and +identify those areas that could benefit from optimization. +

    +

    + +The performance listener can be used by passing a parameter +to the command line for Ant: +

    +

    + + + + + +
    +
    +
    +
    +    ant -listener net.sf.antcontrib.perf.AntPerformanceListener target
    +
    +
    +
    + +

    +

    + +Following is an example of the results from using the listener. The result format is projectname.targetname for targets and projectname.targetname.taskname for tasks. All times are shown to the nearest millisecond. + + + + +
    +
    +
    +
    +[danson@blackdog antelope]$ ant -listener net.sf.antcontrib.perf.AntPerformanceListener dist
    +Buildfile: build.xml
    +
    +init:
    +
    +clean:
    +   [delete] Deleting 170 files from /home/danson/apps/antelope/build
    +
    +compile:
    +    [javac] Compiling 61 source files to /home/danson/apps/antelope/build
    +
    +all:
    +
    +-build_number:
    +
    +prep_files:
    +   [delete] Deleting 3 files from /home/danson/apps/antelope/config
    +     [copy] Copying 3 files to /home/danson/apps/antelope/config
    +
    +combined:
    +     [echo] basedir = /home/danson/apps/antelope
    +      [jar] Building jar: /home/danson/apps/antelope/Antelope_1.208.jar
    +
    +dist:
    +   [delete] Deleting 4 files from /home/danson/apps/antelope/dist
    +      [zip] Building zip: /home/danson/apps/antelope/dist/Antelope_1.208.zip
    +     [echo] Created zip file.
    +
    +-zip_docs:
    +      [zip] Building zip: /home/danson/apps/antelope/dist/Antelope_docs_1.208.zip
    +     [echo] Zipped docs to Antelope_docs_1.208.zip.
    +
    +-zip_tasks:
    +      [jar] Building jar: /tmp/Antelope_tasks_1.208.jar
    +      [zip] Building zip: /home/danson/apps/antelope/dist/Antelope_tasks_1.208.zip
    +   [delete] Deleting: /tmp/Antelope_tasks_1.208.jar
    +     [echo] Zipped tasks to Antelope_tasks_1.208.zip.
    +     [copy] Copying 1 file to /home/danson/apps/antelope/dist
    +
    +BUILD SUCCESSFUL
    +Total time: 8 seconds
    +
    +-------------- Target Results -----------------------
    +Antelope.all: 0.000 sec
    +Antelope.init: 0.011 sec
    +Antelope.-build_number: 0.014 sec
    +Antelope.clean: 0.233 sec
    +Antelope.-zip_tasks: 0.297 sec
    +Antelope.prep_files: 0.311 sec
    +Antelope.-zip_docs: 0.546 sec
    +Antelope.combined: 1.290 sec
    +Antelope.compile: 1.724 sec
    +Antelope.dist: 2.162 sec
    +
    +-------------- Task Results -----------------------
    +Antelope.init.mkdir: 0.000 sec
    +Antelope.init.mkdir: 0.001 sec
    +Antelope.dist.echo: 0.002 sec
    +Antelope.prep_files.delete: 0.004 sec
    +Antelope.combined.echo: 0.005 sec
    +Antelope.dist.delete: 0.006 sec
    +Antelope.-zip_tasks.echo: 0.007 sec
    +Antelope.dist.copy: 0.011 sec
    +Antelope.-build_number.buildnumber: 0.014 sec
    +Antelope.compile.copy: 0.016 sec
    +Antelope.prep_files.copy: 0.020 sec
    +Antelope.prep_files.replace: 0.071 sec
    +Antelope.-zip_tasks.zip: 0.122 sec
    +Antelope.-zip_tasks.jar: 0.161 sec
    +Antelope.prep_files.replace: 0.216 sec
    +Antelope.clean.delete: 0.233 sec
    +Antelope.dist.antcall: 0.421 sec
    +Antelope.-zip_docs.zip: 0.540 sec
    +Antelope.dist.antcall: 0.685 sec
    +Antelope.dist.zip: 1.036 sec
    +Antelope.combined.jar: 1.284 sec
    +Antelope.compile.javac: 1.708 sec
    +
    +-------------- Totals -----------------------
    +Start time: Thu, 5 Dec 2002 17:18:30
    +Stop time: Thu, 5 Dec 2002 17:18:39
    +Total time: 8.476 sec
    +
    +
    +
    + +

    +
    +
    +

    Copyright © 2003 Ant-Contrib Project. All + rights Reserved.

    + + diff --git a/docs/manual/tasks/post_task.html b/docs/manual/tasks/post_task.html new file mode 100644 index 0000000..3be383c --- /dev/null +++ b/docs/manual/tasks/post_task.html @@ -0,0 +1,366 @@ + + + + +HTTP Post + + + + + + + +
    +
    +
    +
    +

    + + +HTTP Post

    +
    +
    +
    +
    +
    +

    +The Post task is a companion to the standard Ant "Get" task. This task does a post and does not necessarily expect anything in return. Almost always, there will be some sort of returned data, this can be logged or written to a file if needed. +

    +

    +Basically, an HTTP POST sends name/value pairs to a web server. A very common usage is for html forms for submitting data. A typical use of this task is to send data to a servlet for updating a web page with the status of a build. +

    +

    +This task handles cookies correctly, which is useful for websites that set a session id to track logins or whatever. This means that if you do several posts in a row, cookies gathered from the first post will be returned with subsequent posts. +

    +

    +The Post task has three ways of specifying the data to be posted. Nested "prop" elements can be used. A "prop" element represents a single name/value pair. The second way is to specify a property file as an attribute to the Post. All properties from the file will be sent as part of the Post data. The third way is to just type in some defined Ant properties. Is it allowed to use all three ways at once, that is, read some properties from a file, specify others via "prop" elements, and just type in some Ant properties. +

    +

    + +

    + + +

    + +Table 12.1. Post Task Attributes +

    + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    +Attribute +Description +Default +Required
    +to +The URL of the remote server to send the post. +None +Yes
    +encoding +Character encoding for the name/value pairs. +UTF-8 +No
    +logfile +The name of a file to write any response to. Ignored if wantresponse is set to false. +None +No
    +property +The name of a property to write any response to. Ignored if wantresponse is set to false. + +None +No
    +append +Should an existing log file be appended to or overwritten? +True, append to an existing file. +No
    +file +A file to read POST data from. All Ant properties contained in this file will be resolved (that is, ${} syntax will be expanded to their values) prior to sending the file contents. +None +No
    +rawFile +Should the file be trated as raw file instead of property-like file. True - send the content of the file directly to http-post, all properties set by 'property' are ignored!
    +Has only impact when the property 'file' is specified.
    +False, treat file as property-like +No
    +rawFileNoEncoding +Don't encode the raw file prior to sending http post request.
    +Has only impact when the property 'rawFile' is specified.
    +False, http-encode the content of the file +No
    +maxwait +The maximum amount of time in seconds to wait for the data to be sent or for a response from the remote server. Setting this to zero means wait forever. +180 (3 minutes) +No
    +wantresponse +Whether to wait for a response from the remote server or not. In many cases this can greatly improve the performance of the build script as the server response may be large and useless to the script. Use this with caution - while the response from the server may not be required for the client, the server may require that the client accept the response prior to processing the post data. +true +No
    +failonerror +Whether the build should fail if the post fails. +false +No
    +
    + +

    +

    + +Post supports nested "prop" elements. As an HTTP POST basically sends a list of names and values, the "prop" element represents one name/value pair. A Post may contain any number of "prop" elements. +

    +

    + +

    + + +

    + +Table 12.2. Prop Attributes +

    + ++++++ + + + + + + + + + + + + + + + + + + + + + + +
    +Attribute +Description +Default +Required
    +name +The name of a property to post. +None +Yes
    +value +The value associated with the name. +None +No
    +
    + +

    +

    + +The "value" attribute is not strictly required. This provides a short-cut method in cases where the property data is an already-defined Ant property. Suppose the build file has this property defined: +

    +

    + + + + + +
    +
    +
    +
    +    <property name="src.dir" value="/home/user/project/src"/>
    +
    +
    +
    + +

    +

    + +Then the following are equivalent: +

    +

    + + + + + +
    +
    +
    +
    +    <prop name="src.dir"/>
    +    <prop name="src.dir" value="${src.dir}"/>
    +    <prop name="src.dir" value="/home/user/project/src"/>
    +
    +
    +
    + +

    +

    + +Defined Ant properties can be entered directly into the post element. Again, suppose the build file has this property defined: +

    +

    + + + + + +
    +
    +
    +
    +    <property name="src.dir" value="/home/user/project/src"/>
    +
    +
    +
    + +

    +

    + +Then the following are equivalent: +

    +

    + + + + + +
    +
    +
    +
    +    ${src.dir}
    +    <prop name="src.dir"/>
    +    <prop name="src.dir" value="${src.dir}"/>
    +    <prop name="src.dir" value="/home/user/project/src"/>
    +
    +
    +
    + +

    +

    + +I googled for the URL in the following example. +

    +

    + + + + + +
    +
    +
    +
    +    <property name="test.val" value="here's my test value"/>
    +    <property name="test.val2" value="second test value"/>
    +    <post to="http://wwwj.cs.unc.edu:8888/tang/servlet/tangGetPostServlet"
    +        verbose="true">
    +        <prop name="prop1" value="val1 ${test.val}"/>
    +        <prop name="prop2" value="val1 value 2"/>
    +        <prop name="prop3" value="val got some spaces %funky ^$* chars"/>
    +        <prop name="prop4" value="&amp; do an ampersand like this &amp;amp; or
    +        Ant will whine"/>
    +        <prop name="thanks" value="dude, thanks for the echo server!"/>
    +        <prop name="test.val"/>
    +        ${test.val2}
    +    </post>
    +
    +
    +
    + +

    +
    +
    +

    Copyright © 2003 Ant-Contrib Project. All + rights Reserved.

    + + diff --git a/docs/manual/tasks/propertycopy.html b/docs/manual/tasks/propertycopy.html new file mode 100644 index 0000000..e24358a --- /dev/null +++ b/docs/manual/tasks/propertycopy.html @@ -0,0 +1,69 @@ + + + + Ant-contrib Tasks: Propertycopy + + + +

    Propertycopy

    + +

    Copies the value of a named property to another property. This + is useful when you need to plug in the value of another property + in order to get a property name and then want to get the value of + that property name.

    + +

    Parameters

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    propertyThe name of the property to set.Yes.
    overrideIf the property is already set, should we change it's value. + Can be true or falseNo. Defaults to false
    name DeprecatedThe name of the property to set.No. Use the property attribute + instead
    fromThe name of the property you wish to copy the + value from.Yes.
    silentDo you want to suppress the error if the + "from" property does not exist, and just not set the + property "name".No, default is "false".
    + +

    Example

    +
    +<property name="org" value="MyOrg" />
    +<property name="org.MyOrg.DisplayName" value="My Organiziation" />
    +<propertycopy name="displayName" from="org.${org}.DisplayName" />
    +
    + +

    Sets displayName to "My + Organiziation".

    + +
    +

    Copyright © 2002 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/propertyregex.html b/docs/manual/tasks/propertyregex.html new file mode 100644 index 0000000..33b855e --- /dev/null +++ b/docs/manual/tasks/propertyregex.html @@ -0,0 +1,133 @@ + + + + Ant-contrib Tasks: PropertyRegex + + + +

    PropertyRegex

    + +

    Performs regular expression operations on an input string, and sets + the results to a property. There are two different operations that + can be performed: +

      +
    1. Replacement - The matched regular expression is replaced with + a substitition pattern
    2. +
    3. Selection - Groupings within the regular expression are selected + via a selection expression. +
    +

    + +

    Parameters

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    propertyThe name of the property to set.Yes.
    overrideIf the property is already set, should we change it's value. + Can be true or falseNo. Defaults to false
    inputThe input string to be processedYes.
    regexpThe regular expression which is matched in + the input string.Yes (can be specified in a + <regexp> subelement). +
    selectA pattern which indicates what selection pattern you want + in the returned value. This uses the substitution pattern + syntax to indicate where to insert groupings created as a result + of the regular expression match.Yes, unless a replace is specified
    replaceA regular expression substitition pattern, which will be used + to replace the given regular expression in the input string.Yes, unless a select is specified
    casesensitiveShould the match be case sensitiveNo. default is "true".
    globalShould a replacement operation be performed on the entire + string, rather than just the first occuranceNo. default is false.
    defaultValueThe value to set the output property to, if the + input string does not match the specific regular expression.No.
    + +

    Select expressions

    + + Expressions are selected in a the same syntax as a regular expression + substitution pattern. + +
      +
    • \0 indicates the entire property name (default). +
    • \1 indicates the first grouping +
    • \2 indicates the second grouping +
    • etc... +
    + +

    Replacement

    + It is important to note that when doing a "replace" operation, + if the input string does not match the regular expression, then + the property is not set. You can change this behavior by supplying + the "defaultValue" attribute. This attribute should contain the value + to set the property to in this case. + +

    Example

    + +
    +    
    +    <propertyregex property="pack.name"
    +              input="package.ABC.name"
    +              regexp="package\.([^\.]*)\.name"
    +              select="\1"
    +              casesensitive="false" />
    +    
    +    yields ABC
    +    
    + +
    +    
    +    <propertyregex property="pack.name"
    +              input="package.ABC.name"
    +              regexp="(package)\.[^\.]*\.(name)"
    +              replace="\1.DEF.\2"
    +              casesensitive="false" />
    +    
    +    yields package.DEF.name
    +    
    + +
    +

    Copyright © 2003 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/propertyselector.html b/docs/manual/tasks/propertyselector.html new file mode 100644 index 0000000..4e5102e --- /dev/null +++ b/docs/manual/tasks/propertyselector.html @@ -0,0 +1,139 @@ + + + + Ant-contrib Tasks: PropertySelector + + + +

    PropertySelector

    + +

    Selects property names that match a given regular expression and + returns them in a delimited list

    + +

    Parameters

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    propertyThe name of the property you wish to set.Yes.
    overrideIf the property is already set, should we change it's value. + Can be true or falseNo. Defaults to false
    matchThe regular expression which is used to select + property names for inclusion in the list. This follows + the standard regular expression syntax accepted by ant's + regular expression tasks.Yes.
    selectA pattern which indicates what selection pattern you want + in the returned list. This used the substitution pattern + syntax to indicate where to insert groupings created as a result + of the regular expression match.No. default is "\0".
    casesensitiveShould the match be case sensitiveNo. default is "true".
    delimiterThe delimiter used to seperate entries in the resulting + propertyNo. default is ",".
    distinctShould the returned entries be a distinct set (no duplicate + entries)No. default is "false".
    + +

    Select expressions

    + + Expressions are selected in a the same syntax as a regular expression + substitution pattern. + +
      +
    • \0 indicates the entire property name (default). +
    • \1 indicates the first grouping +
    • \2 indicates the second grouping +
    • etc... +
    + +

    Example

    + + The following code + +
    +    
    +    <property name="package.ABC.name" value="abc pack name" />
    +    <property name="package.DEF.name" value="def pack name" />
    +    <property name="package.GHI.name" value="ghi pack name" />
    +    <property name="package.JKL.name" value="jkl pack name" />
    +
    +    <propertyselector property="pack.list"
    +                         delimiter=","
    +                         match="package\.([^\.]*)\.name"
    +                         select="\1"
    +                         casesensitive="false" />
    +
    +    
    +    
    + + would yield the results + +
    +    
    +    ABC,DEF,GHI,JKL
    +    
    +    
    + + You could then iterate through this list using the ForEach Task as follows: + +
    +    
    +    <foreach list="${pack.list}"
    +                delimiter=","
    +                target="print.name"
    +                param="pack.id" />
    +
    +    <target name="print.name" >
    +      <propertycopy name="pack.name" value="package.${pack.id}.name" />
    +      <echo message="${pack.name}" />
    +    </target>
    +    
    +    
    + + Would print + +
    +    
    +      [echo] abc pack name
    +      [echo] def pack name
    +      [echo] ghi pack name
    +      [echo] jkl pack name
    +    
    +    
    + +
    +

    Copyright © 2003 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/runtarget.html b/docs/manual/tasks/runtarget.html new file mode 100644 index 0000000..c2af7da --- /dev/null +++ b/docs/manual/tasks/runtarget.html @@ -0,0 +1,38 @@ + + + + Ant-contrib Tasks: RunTarget + + + +

    RunTarget

    +

    + Ant task that runs a target without creating a new project. +

    +

    Parameters

    + + + + + + + + + + + +
    AttributeDescriptionRequired
    targetThe name of the target to run.Yes.
    + +
    + +

    Example

    +
    +      
    +      TO BE DONE
    +      
    +    
    +

    Copyright © 2003 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/server_tasks.html b/docs/manual/tasks/server_tasks.html new file mode 100644 index 0000000..5122be0 --- /dev/null +++ b/docs/manual/tasks/server_tasks.html @@ -0,0 +1,260 @@ + + + + Ant-contrib Server Tasks + + + +

    Ant-Contrib Server Tasks

    + +

    The following tasks exist for running Ant server on one machine, and + calling that server from another (or possibly the same) machine, to + execute tasks.

    + + +
    + +

    AntServer

    + +

    + Starts an ANT server in current process. This server will wait for + client connections, and when received, it will execute the commands + that the client has sent. NOTE: This is a blocking call, and this + task will not return until someone sends the server a shutdown command. +

    + +

    Parameters

    + + + + + + + + + + + + +
    AttributeDescriptionRequired
    portThe port on which the server will listen.No. Defaults to 17000
    + +

    Example:

    + +
    +    
    +        <antserver port="12345" />
    +    
    +    
    + + +

    RemoteAnt

    + +

    + Sends command requests to a running instance of an AntServer which + was started using the <antserver> task. + These commands are executed in the space of the server, and therefore + have no access to any variables or references in the currently executing + project. +

    + +

    Parameters

    + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    machineThe machine name on which the server is running.No. Defaults to "localhost"
    portThe port on which the server is listening.No. Defaults to 17000
    persistantShould we execute all commands, regardless of whether + or not one of them fails. If false, as soon as a failure is encountered, + we will stop execution.No. Defaults to false
    failonerrorIf any of the sent commands encounters a build failure on + the server, should we fail this task.No. Defaults to true.
    + +

    Parameters Specified as Nested Elements

    + +

    + The commands to send are represented as nested elements as described + below +

    + + +

    runtarget

    + +

    Runs a target which is contained in the same buildfile where the + <antserver> task was called. This element may contain nested + <property> elements for sending parameters to the target, and + nested <reference> elements for sending references to the target.

    + +

    Parameters

    + + + + + + + + + + + +
    AttributeDescriptionRequired
    targetThe name of the target to run.Yes.
    + +

    runant

    + +

    Runs a target in an arbitrary buildfile on the machine where the + <antserver> task was called. If a relative pathname is given, + then the path of the buildfile is relative to the base directory of + the project where the <antserver> task was called. This element + may contain nested <property> elements for sending text parameters + to the target, and nested <reference> elements for sending references + to the target.

    + +

    Parameters

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    antfileThe path of the ant file to run (if relative, then + the filename is computed relative to the buildfile of the server + task's base directoryNo. Defaults to "build.xml" in the + directory where the buildfile is to execute (specified by the dir + attribute)
    targetThe name of the target to run.No. Defaults to the default target of + the specified antfile.
    dirthe directory to use as a basedir for the new Ant project. Defaults to + the server project's basedir, unless inheritall has been set to false, in which + case it doesn't have a default value. This will override the basedir setting of + the called project.No.
    inheritallShould the target task inherit all of + the server's properties. This is equivalent to the flag of + the same name on the <ant> task.No. Defaults to false
    inheritrefsShould the target task inherit all of + the server's references. This is equivalent to the flag of + the same name on the <ant> task.No. Defaults to false
    + + +

    shutdown

    + +

    Instructs the <antserver> task to shut itself down. Control + will return to the ANT engine and will procede as necessary in the + server's buildfile.

    + + +

    Example:

    + +
    +    
    +        <remoteant machine="localhost" port="12345">
    +            <runtarget target="execute.build">
    +               <property name="build.type" value="full" />
    +            </runtarget>
    +            <runant dir="tests" target="build.tests">
    +               <property name="build.type" value="full" />
    +               <reference refid="my.ref" torefid="inherited.ref" />
    +            </runtarget>
    +        </remoteant>
    +    
    +    
    + + +

    + would be the equivalent of running the following directly on + the server machine, from within the same buildfile where the + <antserver> task was run +

    + + +
    +    
    +        <antcall target="execute.build">
    +           <param name="build.type" value="full" />
    +        </antcall>
    +        <ant dir="tests">
    +           <property name="build.type" value="full" />
    +           <reference refid="my.ref" torefid="inherited.ref" />
    +        </antcall>
    +    
    +    
    + +

    sendfile

    + +

    Sends a file from the client to the server

    + +

    Parameters

    + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    fileThe path of the file to send.Yes.
    tofileThe filename where the file is to be stored + on the server, if a relative path, then it is stored relative + to the server project's base directory.No. If todir is specified
    tofileThe directory where the file is to be stored + on the server, if a relative path, then it is stored relative + to the server project's base directory. The name of the file + will be the same name as the source fileNo. If tofile is specified
    + +
    +

    Copyright © 2003 Ant-Contrib Project. All + rights Reserved.

    + + + \ No newline at end of file diff --git a/docs/manual/tasks/shellscript.html b/docs/manual/tasks/shellscript.html new file mode 100644 index 0000000..34c4112 --- /dev/null +++ b/docs/manual/tasks/shellscript.html @@ -0,0 +1,140 @@ + + + + + Ant-contrib Tasks: ShellScript + + + + + +

    ShellScript

    +

    Task definition for the shellscript task. This task +allows the user to execute a script against a particular shell +program on a machine. It is an extension of the "exec" +task, and as such, supports the same attributes. One can however use +"shell" instead of "executable". Also the +"command" attribute is not allowed. See the ANT +documentation for a description of the <exec> task parameters.

    +

    Parameters

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    +

    Attribute

    +
    +

    Description

    +
    +

    Required

    +
    +

    shell

    +
    +

    The name of the shell executable which is to be executed. This + shell must support taking a single parameter whose value is a + script file which is to be executed. +

    +
    +

    Yes

    +
    +

    executable

    +
    +

    Same as “shell”

    +
    +


    +

    +
    +

    tmpsuffix

    +
    +

    The contents of the script are placed in a temporary file. This + attribute is the extension to use. note: The value must + contain any dots required. This attribute is usefull for using + script files with windows +

    +
    +

    No

    +
    +

    inputstring

    +
    +

    This is placed in the script file.

    +
    +

    No

    +
    +

    Nested Text

    +

    Any nested text is treated as the contents of the script that is +to be executed within the shell. Embedded ant properties will be +converted.

    +

    Examples

    +
            <shellscript shell="bash" dir="${src.mib.dir}">
    +           mibgen -i ../include mib.mib -c ${build.gen.dir}/generated.cpp
    +           mibgen -i ../include mib.mib -h ${build.gen.dir}/generated.h
    +        </shellscript>
    +
    +        <shellscript shell="sed" outputproperty="sed.output">
    +          <arg value="-e"/>
    +          <arg value="s/FOO/BAR/g"/>
    +          FOO bar bar bar FOO bar bar
    +        </shellscript>
    +
    +        <shellscript shell="cmd.exe" tmpsuffix=".bat">
    +          <arg value="/c"/>
    +          <arg value="call"/>
    +          echo hello world
    +        </shellscript>
    +
    +        <shellscript shell="bash"
    +          dir="${build.bin.dir}"
    +          inputstring="ls -rt | tail -n 1"
    +          outputproperty="last.bin.file"/>
    +
    +        <shellscript executable="perl">
    +          print STDOUT "Hello World!\n";
    +        </shellscript>
    +
    +        <shellscript shell="sh" dir="${thirdparty.dist.dir}/lib">
    +          rm *.so
    +          for file in *.0
    +          do
    +            x=`echo $file | sed -e's/.0.1.0//'`
    +            ln -s $file $x
    +          done
    +        </shellscript>

    +

    +

    +

    Warning:

    +

    One should be carefull in using +shellscript, as overuse will make your build files difficult +to understand, to maintain and to support multiplatform builds. Use +of cygwin in a windows environment will help. However one +should strive to use the java tasks whereever possible.

    +
        
    +
    +

    Copyright © 2003 Ant-Contrib Project. All rights +Reserved.

    + + \ No newline at end of file diff --git a/docs/manual/tasks/sortlist.html b/docs/manual/tasks/sortlist.html new file mode 100644 index 0000000..5af5d41 --- /dev/null +++ b/docs/manual/tasks/sortlist.html @@ -0,0 +1,145 @@ + + + + Ant-contrib Tasks: SortList + + + +

    SortList

    + +

    Sort a delimited list of items in their natural string order. Note that + the value and refid attributes are mutually exclusive, + and the value attribute takes precedence if both are specified.

    + +

    Parameters

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    propertyThe name of the property to set.Yes.
    overrideIf the property is already set, should we change it's value. + Can be true or falseNo. Defaults to false
    valueThe list of values to process, with the + delimiter character, indicated by the "delimiter" + attribute, separating each value.Yes, unless "refid" is + specified.
    refidThe id of where the list of values to sort is + stored.Yes, unless "value" is + specified.
    delimiterThe delimiter string that separates the + values in the "list" attribute.No, defaults to ",".
    casesensitiveIf true, does a case sensitive sorting + of the strings. If false does case insensitive sorting. + No. Defaults to true.
    numericIf true, does a numeric sorting, treating + all list entries as if they were numbers. + No. Defaults to false.
    orderPropertyFileIf specified, the list will sorted as if they were property + names, and will be sorted in the order those properties appear + in the given property file. Any properties in the + value attribute which do not appear in the properties file + will be inserted at the end of the list. This property is most useful + when used in conjunction with the <propertyselector> + task (see Example 2). + No.
    orderPropertyFilePrefixIf orderPropertyFile is specified, this + value (with a trailing '.') will be prefixed to each property in the + specified orderPropertyFile to determine sorting order + No.
    + +
    + +

    Example 1

    +
    +    
    +    <property name="my.list" value="z,y,x,w,v,u,t" />
    +    <sortlist property="my.sorted.list" value="${my.list}"
    +                 delimiter="," />
    +    <echo message="${my.sorted.list}" />
    +    
    +
    +    prints
    +
    +    
    +     [echo] t,u,v,w,x,y,z
    +    
    +
    +    

    Example 2

    +
    +    test.properties
    +    ---------------
    +    a.name=a
    +    c.name=c
    +    b.name=b
    +
    +    
    +    <property file="test.properties" prefix="test" />
    +    <propertyselector property="my.list"
    +                         delimiter=","
    +                         match="test\..*\.name"
    +                         select="\0" />
    +    <sortlist property="my.sorted.list"
    +                 value="${my.list}"
    +                 delimiter=","
    +                 orderPropertyFile="test.properties"
    +                 orderPropertyFilePrefix="test" />
    +
    +    <echo message="${my.sorted.list}" />
    +
    +    prints
    +
    +    
    +     [echo] test.a.name,test.c.name,test.b.name
    +    
    +
    +    Notice that the test.properties file did not have "test."
    +    prefixing all the properties.  The orderPropertyFilePrefix was
    +    used to do that.
    +    
    +

    Copyright © 2002-2003 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/stopwatch_task.html b/docs/manual/tasks/stopwatch_task.html new file mode 100644 index 0000000..8520c78 --- /dev/null +++ b/docs/manual/tasks/stopwatch_task.html @@ -0,0 +1,115 @@ + + + + +Stopwatch + + + + + + + +
    +
    +
    +
    +

    + + +Stopwatch

    +
    +
    +
    +
    +
    +

    + +The Stopwatch task makes it easy to add performance timing to Ant targets. Stopwatches are named so that multiple watches can run simultaneously. +

    + +

    + +

    + + +

    + +Table 9.1. Stopwatch Task Attributes +

    + ++++++ + + + + + + + + + + + + + + + + + + + + + + +
    +Attribute +Description +Default +Required
    +name +The name for the stopwatch. The elapsed time or total time will be stored as an Ant property with this name. +None +Yes
    +action +Valid values are "start", "stop", "elapsed", and "total". +"start" +No
    +
    + +

    +

    + +The stopwatch is started with the "start" action. When the action is "elapsed" or "total", the running time of the stopwatch is printed out. Both "stop" and "total" stop the stopwatch and reset it to zero. "elapsed" prints out the current running time of the stopwatch without stopping it. +

    +

    + +Example: + + + + +
    +
    +
    +
    +<stopwatch name="timer1"/>
    +<!-- do some tasks here... -->
    +<stopwatch name="timer1" action="elapsed"/> <!-- print the elapsed time -->
    +<!-- do some more tasks here... -->
    +<stopwatch name="timer1" action="total"/> <!-- print out the total time -->
    +
    +
    +
    + +

    +
    +
    +

    Copyright © 2003 Ant-Contrib Project. All + rights Reserved.

    + + diff --git a/docs/manual/tasks/switch.html b/docs/manual/tasks/switch.html new file mode 100644 index 0000000..837c701 --- /dev/null +++ b/docs/manual/tasks/switch.html @@ -0,0 +1,82 @@ + + + + Ant-contrib Tasks: Switch + + + +

    Switch

    + +

    Task definition for the ANT task to switch on a particular value.

    + +

    Parameters

    + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    valueThe value to switch on.Yes.
    caseinsensitiveShould we do case insensitive comparisons?No, default is "false"
    + +

    Parameters specified as nested elements

    + +

    At least one <case> or + <default> is required.

    + +

    case

    + +

    An individual case to consider, if the value that is being + switched on matches to value attribute of the case, then the + nested tasks will be executed.

    + +

    Parameters

    + + + + + + + + + + + +
    AttributeDescriptionRequired
    valueThe value to match against the tasks value attribute.Yes.
    + +

    default

    + +

    The default case for when no match is found. Must not appear + more than once per task.

    + +

    Example

    + +
    +<switch value="${foo}">
    +  <case value="bar">
    +    <echo message="The value of property foo is bar" />
    +  </case>
    +  <case value="baz">
    +    <echo message="The value of property foo is baz" />
    +  </case>
    +  <default>
    +    <echo message="The value of property foo is not sensible" />
    +  </default>
    +</switch>
    +
    + +
    +

    Copyright © 2002 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/throw.html b/docs/manual/tasks/throw.html new file mode 100644 index 0000000..0aeb0e8 --- /dev/null +++ b/docs/manual/tasks/throw.html @@ -0,0 +1,39 @@ + + + + Ant-contrib Tasks: Throw + + + +

    Throw

    + +

    Extension of Ant's built-in <fail> task that + can throw an exception that is given by a reference. This may be + useful if you want to rethrow the exception that has been caught + by a <trycatch> task in the + <catch> block.

    + +

    Parameters

    + + + + + + + + + + + +
    AttributeDescriptionRequired
    refidId of the referenced exception.No.
    + +

    In addition, all attributes of the <fail> + task are supported.

    + +
    +

    Copyright © 2002 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/timestampselector.html b/docs/manual/tasks/timestampselector.html new file mode 100644 index 0000000..c4186d1 --- /dev/null +++ b/docs/manual/tasks/timestampselector.html @@ -0,0 +1,132 @@ + + + + Ant-contrib Tasks: TimestampSelector + + + +

    TimestampSelector

    + +

    The TimestampSelector task takes either a nested <path> element, + or a path reference, and sets either a named property, or a path + instance to absolute pathnames of the files with either the N latest or earliest + modification dates (based on the age attribute)

    + +

    Parameters

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    propertyThe property to set with the most recently modified file. Mutually + exclusive with the outputsetid attribute.Yes, if outputsetid is not specified.
    outputsetidThe id of a path instance which will contain the + resulting list of files. This id should not already exist. Mutually exclusive + with the property attributeYes, if property is note specified.
    countThe number of files to find. If more than 1, than the + files in the output appear in the order indicated by the age + attribute.No. Defaults to 1
    ageThe age of the files to retrieve, either eldest + or youngest. Defaults to youngest.No. Defaults to 1
    pathSepThe path separator to separate paths with when using the + property attribute in conjunction with the count + attributeNo. Defaults to ,
    pathrefId of the path to find the most recently modified file in.No, if a path subelement is + specified.
    + +

    Parameters specified as nested elements

    + +

    path

    + +

    Path + is used to select sets of files or directories in which to find the + most recently modified file

    + +

    Example

    + +

    Using a path reference

    +
    +    
    +
    +    <path id="mypath">
    +       <fileset dir="${log.dir}">
    +         <include name="update*.log" />
    +       </fileset>
    +    <path>
    +    <timestampselector property="most.recent.logs"
    +                        pathref="mypath" count="3"
    +                        pathsep=";" />
    +
    +    <echo message="${most.recent.logs}" />
    +    
    +    
    + +

    Using a nested path element

    +
    +    
    +
    +    <timestampselector property="most.recent.logs"
    +                        count="3"
    +                        pathsep=";" >
    +      <path>
    +         <fileset dir="${log.dir}">
    +           <include name="update*.log" />
    +         </fileset>
    +      <path>
    +    </timestampselector>
    +
    +    <echo message="${most.recent.logs}" />
    +    
    +    
    + +

    Outputing to a path element

    +
    +    
    +
    +    <timestampselector outputsetref="most.recent.logs"
    +                        pathref="mypath" count="3">
    +      <path>
    +         <fileset dir="${log.dir}">
    +           <include name="update*.log" />
    +         </fileset>
    +      <path>
    +    </timestampselector>
    +
    +    <copy todir="somedir">
    +      <path refid="most.recent.logs" />
    +    </copy>
    +    
    +    
    + +
    +

    Copyright © 2002-2003 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/toc.html b/docs/manual/tasks/toc.html new file mode 100644 index 0000000..b1d926f --- /dev/null +++ b/docs/manual/tasks/toc.html @@ -0,0 +1,64 @@ + + + + Task List + + + +

    Logic Tasks

    + +

    Network Tasks

    + +

    Performance Monitoring and Tasks

    + +

    Platform Tasks

    + +

    Property Tasks

    + + +

    Process Tasks

    + + +

    Other Tasks

    + + + diff --git a/docs/manual/tasks/trycatch.html b/docs/manual/tasks/trycatch.html new file mode 100644 index 0000000..7eb38a8 --- /dev/null +++ b/docs/manual/tasks/trycatch.html @@ -0,0 +1,96 @@ + + + + Ant-contrib Tasks: Trycatch + + + +

    Trycatch

    + +

    A wrapper that lets you run a set of tasks and optionally run a + different set of tasks if the first set fails and yet another set + after the first one has finished.

    + +

    This mirrors Java's try/catch/finally.

    + +

    The tasks inside of the required <try> + element will be run. If one of them should throw a BuildException + several things can happen:

    + +
      +
    • If there is no <catch> block, the + exception will be passed through to Ant.
    • + +
    • If the property attribute has been set, a property of the + given name will be set to the message of the exception.
    • + +
    • If the reference attribute has been set, a reference of the + given id will be created and point to the exception object.
    • + +
    • If there is a <catch> block, the tasks + nested into it will be run.
    • +
    + +

    If a <finally> block is present, the task + nested into it will be run, no matter whether the first tasks have + thrown an exception or not.

    + +

    Parameters

    + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    propertyName of a property that will receive the + message of the exception that has been caught (if any)No.
    referenceId of a reference that will point to the + exception object that has been caught (if any)No
    + +

    Example

    + +
    +<trycatch property="foo" reference="bar">
    +  <try>
    +    <fail>Tada!</fail>
    +  </try>
    +
    +  <catch>
    +    <echo>In &lt;catch&gt;.</echo>
    +  </catch>
    +
    +  <finally>
    +    <echo>In &lt;finally&gt;.</echo>
    +  </finally>
    +</trycatch>
    +
    +<echo>As property: ${foo}</echo>
    +<property name="baz" refid="bar" />
    +<echo>From reference: ${baz}</echo>
    +
    + +

    results in

    + +
    +  [trycatch] Caught exception: Tada!
    +      [echo] In <catch>.
    +      [echo] In <finally>.
    +      [echo] As property: Tada!
    +      [echo] From reference: Tada!
    +
    + +
    +

    Copyright © 2002-2003 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/urlencode.html b/docs/manual/tasks/urlencode.html new file mode 100644 index 0000000..be6a322 --- /dev/null +++ b/docs/manual/tasks/urlencode.html @@ -0,0 +1,78 @@ + + + + Ant-contrib Tasks: URLEncode + + + +

    Foreach

    + +

    The URLEncode task will encode a given property for use within a + a URL string. This value which is actually set will be encoded + via the java.net.URLEncoder.encode() method. + Typically, you must do this for all parameter values within a URL.

    + +

    Parameters

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    propertyThe name of the property to set.Yes.
    overrideIf the property is already set, should we change it's value. + Can be true or falseNo. Defaults to false
    name DeprecatedThe name of the property to set.No. Use the property attribute + instead
    valueThe value of the property.No, if refid or location is specified
    locationThe location of a file whose absolute path will be the value + of the property.No, if value or refid is specified.
    refidThe id of a saved reference whose value will be the value + of the property.No, defaults to ",".
    + + +

    Example

    + + + The following code + +
    +    
    +    <urlencode name="file.location" location="C:\\wwwhome\\my reports\\report.xml" />
    +    
    +    
    + + would set the "file.location" property to the value: C%3A%5Cwwwhome%5Cmy+reports%5Creport.xml + which could then be used in a URL. + +
    +

    Copyright © 2002-2003 Ant-Contrib Project. All + rights Reserved.

    + + + diff --git a/docs/manual/tasks/variable_task.html b/docs/manual/tasks/variable_task.html new file mode 100644 index 0000000..7e16ab9 --- /dev/null +++ b/docs/manual/tasks/variable_task.html @@ -0,0 +1,261 @@ + + + + +Variable Task + + + + + + + +
    +
    +
    +
    +

    + + +Chapter 8. Variable Task

    +
    +
    +
    +
    +
    +

    + +The Variable task provides a mutable property to Ant and works much like variable assignment in Java. This task is similar to the standard Ant Property task, except that THESE PROPERTIES ARE MUTABLE. While this goes against the standard Ant use of properties, occasionally it is useful to be able to change a property value within the build. + +In general, use of this task is DISCOURAGED, and the standard Ant Property should be used if possible. + + Having said that, in real life I use this a lot. +

    + +

    + +Variables can be set individually or loaded from a standard properties file. A 'feature' of variables is that they can override properties, but properties cannot override variables. So if an already established property exists, its value can be reassigned by use of this task. +

    +

    + +

    + + +

    + +Table 8.1. Variable Task Attributes +

    + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    +Attribute +Description +Default +Required
    +name +The name of the property to set. +None +Yes, unless 'file' is used.
    +value +The value of the property. +"" +No
    +unset +Removes the property from the project as if it had never been set. +false + +No +
    +file +The name of a standard properties file to load variables from. +None +No
    +
    + +

    +

    + +In the following example, the property +x + is first set to "6", then evaluated by the +if +, and reassigned the value "12". The +echo + task will print out 12. +

    +

    + + + + + +
    +
    +
    +
    +    <var name="x" value="6"/>
    +    <if>
    +        <equals arg1="${x}" arg2="6" />
    +        <then>
    +            <var name="x" value="12"/>
    +        </then>
    +    </if>
    +    <echo>${x}</echo>   <!-- will print 12 -->
    +
    +
    +
    + +

    + +

    +The next example shows a property being set, echoed, unset, then reset: + + + + +
    +
    +
    +
    +    <property name="x" value="6"/>
    +    <echo>${x}</echo>   <!-- will print 6 -->
    +    <var name="x" unset="true"/>
    +    <property name="x" value="12"/>
    +    <echo>${x}</echo>   <!-- will print 12 -->
    +
    +
    +
    +
    + +

    + +

    + +The following shows some more uses of the Variable task. It is especially handy for property appending. Notice a couple of things: the property task can't override a var value, in general, you should use var with the unset attribute to change the value of a property. +

    +

    + + + + + +
    +
    +
    +
    +    <var name="x" value="6"/>
    +    <echo>x = ${x}</echo>   <!-- print: 6 -->
    +
    +    <var name="x" value="12"/>
    +    <echo>x = ${x}</echo>   <!-- print: 12 -->
    +
    +    <var name="x" value="6 + ${x}"/>
    +    <echo>x = ${x}</echo>   <!-- print: 6 + 12 -->
    +
    +    <var name="str" value="I "/>
    +    <var name="str" value="${str} am "/>
    +    <var name="str" value="${str} a "/>
    +    <var name="str" value="${str} string."/>
    +    <echo>${str}</echo>     <!-- print: I am a string. -->
    +
    +    <var name="x" value="6"/>
    +    <echo>x = ${x}</echo>   <!-- print: 6 -->
    +
    +    <property name="x" value="12"/>
    +    <echo>x = ${x}</echo>   <!-- print: 6 (property can't override) -->
    +
    +    <var name="x" value="blue"/>
    +    <tstamp>
    +        <format property="x" pattern="EEEE"/>
    +    </tstamp>
    +    <echo>Today is ${x}.</echo> <!-- print: Today is blue. -->
    +
    +    <var name="x" value="" unset="true"/>
    +    <tstamp>
    +        <format property="x" pattern="EEEE"/>
    +    </tstamp>
    +    <echo>Today is ${x}.</echo> <!-- print: Today is Friday. -->
    +
    +
    +
    +
    + +

    +

    + + +

    +
    +
    +

    Copyright © 2003-2004 Ant-Contrib Project. All + rights Reserved.

    + + diff --git a/docs/manual/tasks/verifydesign.html b/docs/manual/tasks/verifydesign.html new file mode 100644 index 0000000..80f1588 --- /dev/null +++ b/docs/manual/tasks/verifydesign.html @@ -0,0 +1,264 @@ + + + + +VerifyDesign Ant Task + + + + +

    VerifyDesign Ant Task

    +
      +
    • Creator: Dean Hiller (dean@xsoftware.biz)
    • +
    • Contributor: Matt Inger (thanks for some really awesome changes)
    • +
    • Contributor: Anthony Y Robins
    • +
    +

    Feedback on task and documentation are welcome!

    +

    Description

    +

    Describe your design dependencies in an xml file, and this task will enforce them so they are not violated

    +

    For example, if there are three packages in one source tree +

      +
    • biz.xsoftware.presentation
    • +
    • biz.xsoftware.business
    • +
    • biz.xsoftware.dataaccess
    • +
    +and naturally presentation should only depend on business package, and business should depend on dataaccess. If you define your design this way and it is violated the build will fail when the verifydesign ant task is called. For example, if I created a class in biz.xsoftware.presentation and that class depended on a class in biz.xsoftware.dataaccess, the build would fail. This ensures the design actually follows what is documented(to some degree at least). This is especially nice with automated builds

    + +

    Getting Started

    +Download bcel jar from this link Bcel download as this ant task uses the jar built from the bcel project on jakarta. Choose a directory to put in place of the XXXXXX below and add the ant-contrib jar as well as the bcel jar to that directory. You should now be all set to use the verifydesign element in your build.xml file as well as any other ant-contrib tasks. If you want to use this with 5.0jdk, you must download the bcel from the head of cvs until something better than 5.1 is released. This version of ant-contrib will work with both 5.0jdk and 1.4 jdk. 1.3 and before is not tested. +
    +    <taskdef resource="net/sf/antcontrib/antlib.xml">
    +        <classpath>
    +           <fileset dir="XXXXXX">
    +               <include name="**/*.jar"/>
    +           </fileset>
    +        </classpath>
    +    </taskdef>
    +
    + +Now, you can skip to the VerifyDesign Legacy Project Tutorial which guides you through how to use this task if you already have alot of existing code, or you can start with the VerifyDesign New Project Tutorial where you don't have much code or any at all. + +

    Parameters

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    designThe file that specifies the design in xml format(Examples below)required
    jarThe jar file of who's design we want to validaterequired
    circularDesignI strongly encourage you not to use this. This turns on allowing circular dependencies. There is always a way to get around circular dependencies, and I suggest you use it instead of introducing a circular dependency. If you think you have found one you can't work around, send me mail and maybe I can give you some ideas.optional(default=false)
    deleteFilesDeletes jar/class files upon build failure to prevent usage. Use this option for new projects so the binaries are not used without the design being met. optional(default=false)
    fillInBuildExceptionFills the BuildException with all the same errors reported in the logs. This is for products like cruisecontrol who only see standard ant task logs and would miss reporting these errors otherwise(ie. instead it just reports build failed with look at the design errors)optional(default=false)
    needDeclarationsDefaultfalse is saying that for this particular package, no other package needs to declare that they depend on this package. It is basically saying the needDeclarations attribute in the package element in the design file is whatever the value of this attribute is in the build.xml file if the design file does not override it.optional(default=true)
    needDependsDefaultfalse is saying that by default no package in the design file has to declare it's dependencies. It is basically saying the needDepends attribute in the package element in the design file is whatever the value of this attribute is in the build.xml file if the design file does not override it.optional(default=true)
    + +

    Parameters specified as nested elements

    +

    No nested elements allowed + + +

    +

    Design File

    +

    +The design file is an xml based file specifying dependencies that are ok. Any dependencies not specified will not be allowed and will make sure the build fails. Examples of the contents of the design file can be found below. +

    + +

    design Root Element

    +

    The root element of the design file is 'design'. Here are design's allowed subelements.

    + + + + + + + + + + + + +
    SubelementDescriptionRequired
    packagesubelement representing a package and it's dependenciesOne or more Required
    + +

    package SubElement

    +

    Here are package elements allowed attributes and subelements

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    AttributeDescriptionRequired
    nameA smaller nickname for the package to reference in the depends subelement or attributeRequired
    packageThe package to compile such as biz.xsoftware.presentationRequired
    dependsContains one and only one 'name' of a package to depend on(taken from name attribute above). If you want to specify more, use the depends subelementOptional(Default=no dependencies)
    subpackagesCan be set to include or exclude. Basically allows classes in subpackages to be part of the package specified.(see examples below)Optional(default=exclude)
    needdeclarationsCan be set to true or false. True means if other packages depend on this package, a depends subelement or attribute must exist stating the dependency. False means other packages need not declare they depend on this package. This should be used sparingly for things like java.lang. By default "java" package and all subpackages are set to false. This can be overridden if you need however so you can make sure only certain packages depend on java.util or something if you really need that. (see examples below)Optional(default=true)
    needdependsCan be set to true or false. True means if this package depends on other packages, those dependencies must be defined(unless those other packages have needdeclarations set to false). False means this package must list all the packages it depends on. This is typically for legacy code where you don't want to deal with what this package depends on right now. On a new project, I never use this.Optional(default=true)
    +
    + + + + + + + + + + + +
    SubelementDescriptionRequired
    dependsContains one and only one 'name' of a package to depend on(taken from name attribute above)One or more Optional
    + +

    depends SubElement

    +Contents contain the 'name' of a package found in the package element's name attribute + +

    Examples

    + +

    Ant's build.xml File

    +
    +  <verifydesign jar="application.jar" design="design.xml"/>
    +
    +

    +That is simple enough. application.jar is the jar I am verifying the design of. design.xml contains the design I want the jar file to adhere to. There is no need to include third party jars(unless you want to verify their design which you shouldn't). The design file can still define what your stuff depends on in those third party libraries without requiring those libraries to be present. If it does not adhere to that design, the build fails. Examples of a design.xml can be found further below. +

    +

    +Another example equivalent to the above is below. verifydesign takes a path like structure(see ant documentation). I highly advise breaking the design on purpose and verifying that the build fails. This ensures you have the ant task set up correctly. +

    +
    +  <verifydesign design="design.xml">
    +     <path>
    +        <pathelement jar="application.jar"/>
    +     </path>
    +  </verifydesign>
    +
    + +One last example would be like so +
    +  <verifydesign design="design.xml">
    +     <path>
    +        <fileset dir="${classesDir}">
    +            <include name="**/*.class"/>
    +        </fileset>
    +     </path>
    +  </verifydesign>
    +
    + +Now let's move on to define the contents of design.xml file. + +

    design.xml File

    + +
    +These lines would be in dependencies.xml.....
    +  <design>
    +     <package name="alljavax" package="javax" subpackages="include" needdeclarations="false"/>
    +     <package name="util" package="biz.xsoftware.util" subpackages="include"/>
    +     <package name="dataaccess" package="biz.xsoftware.dataaccess"/>
    +     <package name="business" package="biz.xsoftware.business" depends="dataaccess"/>
    +     <package name="presentation" package="biz.xsoftware.presentation">
    +        <depends>business</depends>
    +        <depends>util</depends>
    +     </package>
    +  </design>
    +
    +

    Notice in this example, if biz.xsoftware.dataaccess.XYZClass depended on biz.xsoftware.util.Util, the build would fail since that package dependency is not defined. Similarly, any class in biz.xsoftware.presentation cannot depend on any class in biz.xsoftware.dataaccess

    +

    Also, notice that biz.xsoftware.presentation.Gui is allowed to depend on biz.xsoftware.util.pres.ClassInSubpackage because subpackages is set to include. This allows subpackages of biz.xsoftware.util to also be included in the design without having to define every subpackage.

    +

    Lastly, notice the first line so javax and all javax subpackages can be depended on without declaring them. Use this sparingly though as sometimes you might want to isolate dependencies like depending on JMX to a certain package. For example, you may want only biz.xsoftware.management to depend on JMX and nothing else to depend on it. If you declare the same declaration I declared here for javax, you will not be able to guarantee that.

    + +

    The wad design.xml file

    +If you really want to, you could design for a wad. This is not suggested and if you want to do this, don't use this ant task please. +
    +  <design>
    +     <package name="wad" package="<default package>" subpackages="include"/>
    +  </design>
    +
    + +

    Including subpackages design.xml

    +
    +  <design>
    +     <package name="service1" package="biz.xsoftware.service1" subpackages="include"/>
    +     <package name="client1"  package="biz.xsoftware.client1"  depends="service1"/>
    +     <package name="service2" package="biz.xsoftware.service2"/>
    +     <package name="client2"  package="biz.xsoftware.client2"  depends="service2" subpackages="include"/>
    +  </design>
    +
    +

    +Note that here for service 1, classes in package biz.xsoftware.client1 can depend on any classes in biz.xsoftware.service1 and can also depend on classes in subpackages of biz.xsoftware.service1. +

    +

    +Note that for service 2, classes in biz.xsoftware.client2 and client2's subpackages are all allowed to depend on classes in biz.xsoftware.service2. +

    +

    One Design Note

    +One big note to consider, there is one design dependency that verifydesign cannot see from the class file. This is due to the String constants(This only happens with static final Strings and static final primitives being compiled into the class file. Here is example code demonstrating this task cannot catch these dependencies.... +
    +public class Client {
    +    public void fakeMethod() {
    +	     String s = Dependency.CONSTANT;  //verifydesign task can't tell this depends on
    +		                                  //DependencyClass as that info is lost after compiling
    +	}
    +}
    +
    +public class DependencyClass {
    +    public static final String CONSTANT = "asdf"; 
    +}
    +
    + +
    +

    Copyright © 2002-2004 Ant-Contrib Project. All + rights Reserved.

    + + + + diff --git a/docs/manual/tasks/verifylegacytutorial.html b/docs/manual/tasks/verifylegacytutorial.html new file mode 100644 index 0000000..6999882 --- /dev/null +++ b/docs/manual/tasks/verifylegacytutorial.html @@ -0,0 +1,71 @@ + + + + +VerifyDesign Legacy System Tutorial + + + + +

    VerifyDesign Legacy System Tutorial

    + +

    If you have a legacy system, it can be overwhelming as a typical system is a mess when it comes to package dependencies. This tutorial shows a way to ease into the verifydesign task instead of fixing everything all at once.

    + +

    First, in your build.xml file, use this line to verify your jar(or you can modify it to verify multiple jars)

    + +
    +    <verifydesign jar="yourjarname.jar"
    +                  design="design.xml" 
    +                  />
    +
    + +Now is the hardest part, go ahead and define every package and set the needDepends attribute to false for all of them so your design.xml should look like so + +
    +  <design>
    +      <package name="first" package="your.first.package" needDepends="false"/>
    +      <package name="second" package="your.second.package" needDepends="false"/>
    +      <package name="third" package="your.third.package" needDepends="false"/>
    +      <package name="fourth" package="your.fourth.package" needDepends="false"/>
    +      <package name="fifth" package="your.fifth.package" needDepends="false"/>
    +  </design>
    +
    + +Please give them better names then first, second, third, etc. You may have 100 packages on some projects and this may take a while to get started, but keep in mind once you are done with this, you are done with the majority of the work and the build will pass once you are done with this too! + +Now comes the fun part, learning about your design. Take a package that you want to start restricting dependencies on and erase the needDepends(by default it's value will be true). Let's take your.first.package and create the new design.xml file like so... + +
    +  <design>
    +      <package name="first" package="your.first.package"/>
    +      <package name="second" package="your.second.package" needDepends="false"/>
    +      <package name="third" package="your.third.package" needDepends="false"/>
    +      <package name="fourth" package="your.fourth.package" needDepends="false"/>
    +      <package name="fifth" package="your.fifth.package" needDepends="false"/>
    +  </design>
    +
    + +Now we run the build and we get errors that your.first.package depends on second, third, and fourth. Let's pretend we only wanted to depend on second and third. We then change our design file to so... + +
    +  <design>
    +      <package name="first" package="your.first.package"
    +         <depends>second</depends>
    +         <depends>third</depends>
    +      </package>
    +      <package name="second" package="your.second.package" needDepends="false"/>
    +      <package name="third" package="your.third.package" needDepends="false"/>
    +      <package name="fourth" package="your.fourth.package" needDepends="false"/>
    +      <package name="fifth" package="your.fifth.package" needDepends="false"/>
    +  </design>
    +
    + +Now we run the build and clean up all the code so that first doesn't depend on fourth anymore. This first step can typically take a full release if you are doing this in the margins. That is ok and now forever your.first.package will only depend on second and third until the design file is changed. You have made major progress. I would suggest a package a release. It can clean up dependencies and you will start finding it can be easier to add more and more features and not end up with a wad or mess on your hands. Good luck designing. Refactoring a legacy system can be very challenging and very long with or without this task. This ant task guarantees that you are actually heading in your defined direction. Whether the direction is correct or not is another story :). + +
    +

    Copyright © 2002-2004 Ant-Contrib Project. All + rights Reserved.

    + + + + diff --git a/docs/manual/tasks/verifynewprojtutorial.html b/docs/manual/tasks/verifynewprojtutorial.html new file mode 100644 index 0000000..96e066d --- /dev/null +++ b/docs/manual/tasks/verifynewprojtutorial.html @@ -0,0 +1,39 @@ + + + + +VerifyDesign New Project Tutorial + + + + +

    VerifyDesign New Project Tutorial

    + +This is by far the easiest tutorial. Before you have any code, add this to your build.xml file. + +
    +    <verifydesign jar="yourjarname.jar"
    +                  design="design.xml" 
    +                  />
    +
    + +Create your design.xml file from the design that is in your head or in documentation like so + +
    +  <design>
    +     <package name="service1" package="biz.xsoftware.service1" subpackages="include"/>
    +     <package name="client1"  package="biz.xsoftware.client1"  depends="service1"/>
    +     <package name="service2" package="biz.xsoftware.service2"/>
    +     <package name="client2"  package="biz.xsoftware.client2"  depends="service2" subpackages="include"/>
    +  </design>
    +
    + +From now on, when you run the build, if this is violated like service1 depending on client2 or something, the build will fail and you will catch the errors of violating the design before it is too late. You can then guarantee things like only this package will depend on the JMS technology. This way if you change JMS to something later, you know you only have to change that one package. + +
    +

    Copyright © 2002-2004 Ant-Contrib Project. All + rights Reserved.

    + + + + -- cgit v1.2.3