Dear committers
Some time ago I implemented a rename task. It still has not be applied
with no apparent reason.
Attached please find a patch implementing the task and a patch to
docs/index.html documenting the task.
Can someone please commit the patches or tell me what is missing.
Thank you.
- tom
Test:
rename.xml:
<?xml version="1.0"?>
<project name="RenameTest" default="main" basedir=".">
<target name="main">
<rename src="foo1.jar" dest="bar1.jar" />
<rename src="foo2.jar" dest="bar2.jar" replace="off" />
</target>
</project>
$ touch foo1.jar foo2.jar bar1.jar bar2.jar
$ ant -buildfile rename.xml
Fails, because bar2.jar already exists.
$ ant -buildfile rename.xml
Fails, because foo1.jar does not exist anymore
$ touch foo1.jar foo2.jar bar1.jar bar2.jar; rm bar2.jar
$ ant -buildfile rename.xml
Succeess.
--- defaults.properties.orig Wed Mar 22 05:20:52 2000
+++ defaults.properties Wed Mar 22 20:35:40 2000
@@ -26,6 +26,7 @@
available=org.apache.tools.ant.taskdefs.Available
filter=org.apache.tools.ant.taskdefs.Filter
fixcrlf=org.apache.tools.ant.taskdefs.FixCRLF
+rename=org.apache.tools.ant.taskdefs.Rename
# optional tasks
script=org.apache.tools.ant.taskdefs.optional.Script
--- Rename.java.orig Wed Mar 22 21:02:42 2000
+++ Rename.java Wed Mar 22 21:02:42 2000
@@ -0,0 +1,116 @@
+/*
+ * The Apache Software License, Version 1.1
+ *
+ * Copyright (c) 1999 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", "Tomcat", 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 [EMAIL PROTECTED]
+ *
+ * 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.BuildException;
+import org.apache.tools.ant.Task;
+
+import java.io.File;
+
+/**
+ * Renames a file.
+ *
+ * @author [EMAIL PROTECTED]
+ */
+public class Rename extends Task {
+
+ private File src;
+ private File dest;
+ private boolean replace = true;
+
+
+ /**
+ * Sets the file to be renamed.
+ * @param src the file to rename
+ */
+ public void setSrc(String src) {
+ this.src = project.resolveFile(src);
+ }
+
+ /**
+ * Sets the new name of the file.
+ * @param dest the new name of the file.
+ */
+ public void setDest(String dest) {
+ this.dest = project.resolveFile(dest);
+ }
+
+ /**
+ * Sets wheter an existing file should be replaced.
+ * @param replace <code>on</code>, if an existing file should be replaced.
+ */
+ public void setReplace(String replace) {
+ this.replace = project.toBoolean(replace);
+ }
+
+
+ /**
+ * Renames the file <code>src</code> to <code>dest</code>
+ * @exception org.apache.tools.ant.BuildException The exception is
+ * thrown, if the rename operation fails.
+ */
+ public void execute() throws BuildException {
+ if (replace && dest.exists()) {
+ if (!dest.delete()) {
+ throw new BuildException("Unable to remove existing file " +
+ dest);
+ }
+ }
+ if (!src.renameTo(dest)) {
+ throw new BuildException("Unable to rename " + src + " to " +
+ dest);
+ }
+ }
+}
--- index.html.orig Wed Mar 22 05:20:50 2000
+++ index.html Wed Mar 22 20:58:28 2000
@@ -461,6 +461,7 @@
<li><a href="#keysubst">KeySubst</a></li>
<li><a href="#mkdir">Mkdir</a></li>
<li><a href="#property">Property</a></li>
+ <li><a href="#rename">Rename</a></li>
<li><a href="#replace">Replace</a></li>
<li><a href="#rmic">Rmic</a></li>
<li><a href="#tar">Tar</a></li>
@@ -1771,6 +1772,38 @@
<p>reads a set of properties from a file called "foo.properties".</p>
<pre> <property resource="foo.properties" /></pre>
<p>reads a set of properties from a resource called
"foo.properties".</p>
+<hr>
+<h2><a name="rename">Rename</a></h2>
+<h3>Description</h3>
+<p>Renames a given file.</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">src</td>
+ <td valign="top">file to rename.</td>
+ <td valign="top" align="center">Yes</td>
+ </tr>
+ <tr>
+ <td valign="top">dest</td>
+ <td valign="top">new name of the file.</td>
+ <td valign="top" align="center">Yes</td>
+ </tr>
+ <tr>
+ <td valign="top">replace</td>
+ <td valign="top">Enable replacing of existing file (default: on).</td>
+ <td valign="top" align="center">No</td>
+ </tr>
+</table>
+<h3>Examples</h3>
+<pre> <rename src="foo.jar"
dest="${name}-${version}.jar" /></pre>
+<p>Renames the file <code>foo.jar</code> to
<code>${name}-${version}.jar</code> (assuming <code>name</code>
+ and <code>version</code> being predefined properties). If a file named
<code>${name}-${version}.jar</code>
+ already exists, it will be removed prior to renameing
<code>foo.jar</code>.</p>
<hr>
<h2><a name="replace">Replace</a></h2>
<h3>Description</h3>