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 | ||||