git-svn-id: https://svn.apache.org/repos/asf/ant/core/trunk@269117 13f79535-47bb-0310-9956-ffa450edef68master
| @@ -21,7 +21,8 @@ Changes that could break older environments: | |||||
| Other changes: | Other changes: | ||||
| -------------- | -------------- | ||||
| * New tasks: ear, p4counter, record, cvspass, vsscheckin, vsscheckout | |||||
| * New tasks: ear, p4counter, record, cvspass, vsscheckin, vsscheckout, | |||||
| typedef | |||||
| * Ant now uses JAXP 1.1 | * Ant now uses JAXP 1.1 | ||||
| @@ -0,0 +1,60 @@ | |||||
| <html> | |||||
| <head> | |||||
| <meta http-equiv="Content-Language" content="en-us"> | |||||
| <title>Ant User Manual</title> | |||||
| </head> | |||||
| <body> | |||||
| <h2><a name="typedef">Typedef</a></h2> | |||||
| <h3>Description</h3> | |||||
| <p>Adds a data type definition to the current project, such that this | |||||
| new type can be used in the current project. Two attributes are | |||||
| needed, the name that identifies this data type uniquely, and the full | |||||
| name of the class (including the packages) that implements this | |||||
| type.</p> | |||||
| <p>Typedef should be used to add your own types to the system. Data | |||||
| types are things like <a href="../using.html#path">paths</a> or <a | |||||
| href="../CoreTypes/fileset.html">filesets</a> that can be defined at | |||||
| the project level and referenced via their ID attribute.</p> | |||||
| <p>Custom data types usually need custom tasks to put them to good use.</p> | |||||
| <h3>Parameters</h3> | |||||
| <table border="1" cellpadding="2" cellspacing="0"> | |||||
| <tr> | |||||
| <td valign="top"><b>Attribute</b></td> | |||||
| <td valign="top"><b>Description</b></td> | |||||
| <td align="center" valign="top"><b>Required</b></td> | |||||
| </tr> | |||||
| <tr> | |||||
| <td valign="top">name</td> | |||||
| <td valign="top">the name of the data type</td> | |||||
| <td valign="top" align="center">Yes</td> | |||||
| </tr> | |||||
| <tr> | |||||
| <td valign="top">classname</td> | |||||
| <td valign="top">the full class name implementing the data type</td> | |||||
| <td valign="top" align="center">Yes</td> | |||||
| </tr> | |||||
| <tr> | |||||
| <td valign="top">classpath</td> <td valign="top">the classpath to | |||||
| use when looking up <code>classname</code>.</td> <td | |||||
| align="center" valign="top">No</td> | |||||
| </tr> | |||||
| </table> | |||||
| <h3>Parameters specified as nested elements</h3> | |||||
| <h4>classpath</h4> | |||||
| <p><code>Typedef</code>'s <i>classpath</i> attribute is a | |||||
| <a href="../using.html#path">PATH like structure</a> and can also be set | |||||
| via a nested <i>classpath</i> element.</p> | |||||
| <h3>Examples</h3> | |||||
| <pre> <typedef name="urlset" classname="com.mydomain.URLSet"/></pre> | |||||
| <p>makes a data type called <code>urlset</code> available to Ant. The | |||||
| class <code>com.mydomain.URLSet</code> implements this type.</p> | |||||
| <hr> | |||||
| <p align="center">Copyright © 2000,2001 Apache Software | |||||
| Foundation. All rights Reserved.</p> | |||||
| </body> | |||||
| </html> | |||||
| @@ -61,6 +61,7 @@ | |||||
| <a href="CoreTasks/taskdef.html">Taskdef</a><br> | <a href="CoreTasks/taskdef.html">Taskdef</a><br> | ||||
| <a href="CoreTasks/touch.html">Touch</a><br> | <a href="CoreTasks/touch.html">Touch</a><br> | ||||
| <a href="CoreTasks/tstamp.html">Tstamp</a><br> | <a href="CoreTasks/tstamp.html">Tstamp</a><br> | ||||
| <a href="CoreTasks/typedef.html">Typedef</a><br> | |||||
| <a href="CoreTasks/unzip.html">Unjar</a><br> | <a href="CoreTasks/unzip.html">Unjar</a><br> | ||||
| <a href="CoreTasks/untar.html">Untar</a><br> | <a href="CoreTasks/untar.html">Untar</a><br> | ||||
| <a href="CoreTasks/unzip.html">Unwar</a><br> | <a href="CoreTasks/unzip.html">Unwar</a><br> | ||||
| @@ -0,0 +1,144 @@ | |||||
| /* | |||||
| * The Apache Software License, Version 1.1 | |||||
| * | |||||
| * Copyright (c) 1999-2001 The Apache Software Foundation. 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 | |||||
| * Apache Software Foundation (http://www.apache.org/)." | |||||
| * Alternately, this acknowlegement may appear in the software itself, | |||||
| * if and wherever such third-party acknowlegements normally appear. | |||||
| * | |||||
| * 4. The names "The Jakarta Project", "Ant", and "Apache Software | |||||
| * Foundation" must not be used to endorse or promote products derived | |||||
| * from this software without prior written permission. For written | |||||
| * permission, please contact apache@apache.org. | |||||
| * | |||||
| * 5. Products derived from this software may not be called "Apache" | |||||
| * nor may "Apache" appear in their names without prior written | |||||
| * permission of the Apache Group. | |||||
| * | |||||
| * 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 APACHE SOFTWARE FOUNDATION 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. | |||||
| * ==================================================================== | |||||
| * | |||||
| * This software consists of voluntary contributions made by many | |||||
| * individuals on behalf of the Apache Software Foundation. For more | |||||
| * information on the Apache Software Foundation, please see | |||||
| * <http://www.apache.org/>. | |||||
| */ | |||||
| package org.apache.tools.ant.taskdefs; | |||||
| import org.apache.tools.ant.*; | |||||
| import org.apache.tools.ant.types.*; | |||||
| /** | |||||
| * Base class for Taskdef and Typedef - does all the classpath | |||||
| * handling and and class loading. | |||||
| * | |||||
| * @author costin@dnt.ro | |||||
| * @author <a href="stefan.bodewig@epost.de">Stefan Bodewig</a> | |||||
| */ | |||||
| public abstract class Definer extends Task { | |||||
| private String name; | |||||
| private String value; | |||||
| private Path classpath; | |||||
| public void setClasspath(Path classpath) { | |||||
| if (this.classpath == null) { | |||||
| this.classpath = classpath; | |||||
| } else { | |||||
| this.classpath.append(classpath); | |||||
| } | |||||
| } | |||||
| public Path createClasspath() { | |||||
| if (this.classpath == null) { | |||||
| this.classpath = new Path(project); | |||||
| } | |||||
| return this.classpath.createPath(); | |||||
| } | |||||
| public void setClasspathRef(Reference r) { | |||||
| createClasspath().setRefid(r); | |||||
| } | |||||
| public void execute() throws BuildException { | |||||
| if (name==null || value==null ) { | |||||
| String msg = "name or classname attributes of " | |||||
| + getTaskName() + " element " | |||||
| + "are undefined"; | |||||
| throw new BuildException(msg); | |||||
| } | |||||
| try { | |||||
| ClassLoader loader = null; | |||||
| if (classpath != null) { | |||||
| AntClassLoader al = new AntClassLoader(project, classpath, | |||||
| false); | |||||
| // need to load Task via system classloader or the new | |||||
| // task we want to define will never be a Task but always | |||||
| // be wrapped into a TaskAdapter. | |||||
| al.addSystemPackageRoot("org.apache.tools.ant"); | |||||
| loader = al; | |||||
| } else { | |||||
| loader = this.getClass().getClassLoader(); | |||||
| } | |||||
| Class c = null; | |||||
| if (loader != null) { | |||||
| c = loader.loadClass(value); | |||||
| AntClassLoader.initializeClass(c); | |||||
| } else { | |||||
| c = Class.forName(value); | |||||
| } | |||||
| addDefinition(name, c); | |||||
| } catch (ClassNotFoundException cnfe) { | |||||
| String msg = getTaskName()+" class " + value + | |||||
| " cannot be found"; | |||||
| throw new BuildException(msg, cnfe, location); | |||||
| } catch (NoClassDefFoundError ncdfe) { | |||||
| String msg = getTaskName()+" class " + value + | |||||
| " cannot be found"; | |||||
| throw new BuildException(msg, ncdfe, location); | |||||
| } | |||||
| } | |||||
| public void setName( String name) { | |||||
| this.name = name; | |||||
| } | |||||
| public String getClassname() { | |||||
| return value; | |||||
| } | |||||
| public void setClassname(String v) { | |||||
| value = v; | |||||
| } | |||||
| protected abstract void addDefinition(String name, Class c); | |||||
| } | |||||
| @@ -54,86 +54,13 @@ | |||||
| package org.apache.tools.ant.taskdefs; | package org.apache.tools.ant.taskdefs; | ||||
| import org.apache.tools.ant.*; | |||||
| import org.apache.tools.ant.types.*; | |||||
| /** | /** | ||||
| * Define a new task - name and class | |||||
| * Define a new task. | |||||
| * | * | ||||
| * @author costin@dnt.ro | |||||
| * @author <a href="stefan.bodewig@epost.de">Stefan Bodewig</a> | |||||
| */ | */ | ||||
| public class Taskdef extends Task { | |||||
| private String name; | |||||
| private String value; | |||||
| private Path classpath; | |||||
| public void setClasspath(Path classpath) { | |||||
| if (this.classpath == null) { | |||||
| this.classpath = classpath; | |||||
| } else { | |||||
| this.classpath.append(classpath); | |||||
| } | |||||
| } | |||||
| public Path createClasspath() { | |||||
| if (this.classpath == null) { | |||||
| this.classpath = new Path(project); | |||||
| } | |||||
| return this.classpath.createPath(); | |||||
| } | |||||
| public void setClasspathRef(Reference r) { | |||||
| createClasspath().setRefid(r); | |||||
| } | |||||
| public void execute() throws BuildException { | |||||
| if (name==null || value==null ) { | |||||
| String msg = "name or classname attributes of taskdef element " | |||||
| + "are undefined"; | |||||
| throw new BuildException(msg); | |||||
| } | |||||
| try { | |||||
| ClassLoader loader = null; | |||||
| if (classpath != null) { | |||||
| AntClassLoader al = new AntClassLoader(project, classpath, | |||||
| false); | |||||
| // need to load Task via system classloader or the new | |||||
| // task we want to define will never be a Task but always | |||||
| // be wrapped into a TaskAdapter. | |||||
| al.addSystemPackageRoot("org.apache.tools.ant"); | |||||
| loader = al; | |||||
| } else { | |||||
| loader = this.getClass().getClassLoader(); | |||||
| } | |||||
| Class taskClass = null; | |||||
| if (loader != null) { | |||||
| taskClass = loader.loadClass(value); | |||||
| AntClassLoader.initializeClass(taskClass); | |||||
| } else { | |||||
| taskClass = Class.forName(value); | |||||
| } | |||||
| project.addTaskDefinition(name, taskClass); | |||||
| } catch (ClassNotFoundException cnfe) { | |||||
| String msg = "taskdef class " + value + | |||||
| " cannot be found"; | |||||
| throw new BuildException(msg, cnfe, location); | |||||
| } catch (NoClassDefFoundError ncdfe) { | |||||
| String msg = "taskdef class " + value + | |||||
| " cannot be found"; | |||||
| throw new BuildException(msg, ncdfe, location); | |||||
| } | |||||
| } | |||||
| public void setName( String name) { | |||||
| this.name = name; | |||||
| } | |||||
| public String getClassname() { | |||||
| return value; | |||||
| } | |||||
| public void setClassname(String v) { | |||||
| value = v; | |||||
| public class Taskdef extends Definer { | |||||
| protected void addDefinition(String name, Class c) { | |||||
| project.addTaskDefinition(name, c); | |||||
| } | } | ||||
| } | } | ||||
| @@ -0,0 +1,66 @@ | |||||
| /* | |||||
| * The Apache Software License, Version 1.1 | |||||
| * | |||||
| * Copyright (c) 2001 The Apache Software Foundation. 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 | |||||
| * Apache Software Foundation (http://www.apache.org/)." | |||||
| * Alternately, this acknowlegement may appear in the software itself, | |||||
| * if and wherever such third-party acknowlegements normally appear. | |||||
| * | |||||
| * 4. The names "The Jakarta Project", "Ant", and "Apache Software | |||||
| * Foundation" must not be used to endorse or promote products derived | |||||
| * from this software without prior written permission. For written | |||||
| * permission, please contact apache@apache.org. | |||||
| * | |||||
| * 5. Products derived from this software may not be called "Apache" | |||||
| * nor may "Apache" appear in their names without prior written | |||||
| * permission of the Apache Group. | |||||
| * | |||||
| * 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 APACHE SOFTWARE FOUNDATION 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. | |||||
| * ==================================================================== | |||||
| * | |||||
| * This software consists of voluntary contributions made by many | |||||
| * individuals on behalf of the Apache Software Foundation. For more | |||||
| * information on the Apache Software Foundation, please see | |||||
| * <http://www.apache.org/>. | |||||
| */ | |||||
| package org.apache.tools.ant.taskdefs; | |||||
| /** | |||||
| * Define a new data type. | |||||
| * | |||||
| * @author <a href="stefan.bodewig@epost.de">Stefan Bodewig</a> | |||||
| */ | |||||
| public class Typedef extends Definer { | |||||
| protected void addDefinition(String name, Class c) { | |||||
| project.addDataTypeDefinition(name, c); | |||||
| } | |||||
| } | |||||
| @@ -45,6 +45,7 @@ uptodate=org.apache.tools.ant.taskdefs.UpToDate | |||||
| apply=org.apache.tools.ant.taskdefs.Transform | apply=org.apache.tools.ant.taskdefs.Transform | ||||
| record=org.apache.tools.ant.taskdefs.Recorder | record=org.apache.tools.ant.taskdefs.Recorder | ||||
| cvspass=org.apache.tools.ant.taskdefs.CVSPass | cvspass=org.apache.tools.ant.taskdefs.CVSPass | ||||
| typedef=org.apache.tools.ant.taskdefs.Typedef | |||||
| # optional tasks | # optional tasks | ||||
| script=org.apache.tools.ant.taskdefs.optional.Script | script=org.apache.tools.ant.taskdefs.optional.Script | ||||