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: | |||
-------------- | |||
* New tasks: ear, p4counter, record, cvspass, vsscheckin, vsscheckout | |||
* New tasks: ear, p4counter, record, cvspass, vsscheckin, vsscheckout, | |||
typedef | |||
* 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/touch.html">Touch</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/untar.html">Untar</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; | |||
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 | |||
record=org.apache.tools.ant.taskdefs.Recorder | |||
cvspass=org.apache.tools.ant.taskdefs.CVSPass | |||
typedef=org.apache.tools.ant.taskdefs.Typedef | |||
# optional tasks | |||
script=org.apache.tools.ant.taskdefs.optional.Script | |||