bodewig 2003/06/24 05:46:57
Modified: . WHATSNEW
docs/manual/CoreTasks touch.html
src/main/org/apache/tools/ant/taskdefs Touch.java
Added: src/etc/testcases/taskdefs touch.xml
src/testcases/org/apache/tools/ant/taskdefs TouchTest.java
Log:
Allow <touch>'s datetime attribute to accept seconds as well.
PR: 21014
Revision Changes Path
1.445 +3 -0 ant/WHATSNEW
Index: WHATSNEW
===================================================================
RCS file: /home/cvs/ant/WHATSNEW,v
retrieving revision 1.444
retrieving revision 1.445
diff -u -r1.444 -r1.445
--- WHATSNEW 24 Jun 2003 11:29:19 -0000 1.444
+++ WHATSNEW 24 Jun 2003 12:46:56 -0000 1.445
@@ -440,6 +440,9 @@
* Added <scriptdef> task allowing tasks to be defined using any BSF-supported
scripting language.
+* <touch>'s datetime attribute can now accept time with a granularity
+ of seconds as well. Bugzilla Report 21014.
+
Changes from Ant 1.5.2 to Ant 1.5.3
===================================
1.8 +7 -2 ant/docs/manual/CoreTasks/touch.html
Index: touch.html
===================================================================
RCS file: /home/cvs/ant/docs/manual/CoreTasks/touch.html,v
retrieving revision 1.7
retrieving revision 1.8
diff -u -r1.7 -r1.8
--- touch.html 1 Jun 2002 12:26:33 -0000 1.7
+++ touch.html 24 Jun 2003 12:46:56 -0000 1.8
@@ -37,7 +37,7 @@
<tr>
<td valign="top">datetime</td>
<td valign="top">specifies the new modification time of the file
- in the format MM/DD/YYYY HH:MM AM_or_PM.</td>
+ in the format MM/DD/YYYY HH:MM AM_or_PM or MM/DD/YYYY HH:MM:SS
AM_or_PM.</td>
<td valign="top" align="center">No</td>
</tr>
</table>
@@ -56,8 +56,13 @@
</touch></pre>
<p>changes the modification time to Oct, 09 1974 4:30 pm of all files and
directories
found in <code>src_dir</code>. </p>
+<pre> <touch file="myfile" datetime="06/28/2000 2:02:17
pm"/></pre>
+<p>creates <code>myfile</code> if it doesn't exist and changes the
+modification time to Jun, 28 2000 2:02:17 pm (14:02:17 for those used to 24
+hour times), if the filesystem allows a precision of one second - a
+time close to it otherwise.</p>
<hr>
-<p align="center">Copyright © 2000-2001 Apache Software Foundation. All
rights
+<p align="center">Copyright © 2000-2001,2003 Apache Software
Foundation. All rights
Reserved.</p>
</body>
1.1 ant/src/etc/testcases/taskdefs/touch.xml
Index: touch.xml
===================================================================
<?xml version="1.0"?>
<project default="cleanup" basedir=".">
<target name="cleanup">
<delete file="touchtest" />
</target>
<target name="noSeconds">
<touch file="touchtest" datetime="2003/06/24 2:20 pm"/>
</target>
<target name="seconds">
<touch file="touchtest" datetime="2003/06/24 2:20:12 pm"/>
</target>
</project>
1.31 +32 -11 ant/src/main/org/apache/tools/ant/taskdefs/Touch.java
Index: Touch.java
===================================================================
RCS file: /home/cvs/ant/src/main/org/apache/tools/ant/taskdefs/Touch.java,v
retrieving revision 1.30
retrieving revision 1.31
diff -u -r1.30 -r1.31
--- Touch.java 7 Mar 2003 11:23:02 -0000 1.30
+++ Touch.java 24 Jun 2003 12:46:56 -0000 1.31
@@ -1,7 +1,7 @@
/*
* The Apache Software License, Version 1.1
*
- * Copyright (c) 2000-2002 The Apache Software Foundation. All rights
+ * Copyright (c) 2000-2003 The Apache Software Foundation. All rights
* reserved.
*
* Redistribution and use in source and binary forms, with or without
@@ -116,7 +116,8 @@
/**
* the new modification time of the file
- * in the format MM/DD/YYYY HH:MM AM <i>or</i> PM;
+ * in the format "MM/DD/YYYY HH:MM AM <i>or</i> PM"
+ * or "MM/DD/YYYY HH:MM:SS AM <i>or</i> PM".
* Optional, default=now
*/
public void setDatetime(String dateTime) {
@@ -148,22 +149,42 @@
try {
if (dateTime != null) {
+ /*
+ * The initial version used DateFormat.SHORT for the
+ * time format, which ignores seconds. If we want
+ * seconds as well, we need DateFormat.MEDIUM, which
+ * in turn would break all old build files.
+ *
+ * First try to parse with DateFormat.SHORT and if
+ * that fails with MEDIUM - throw an exception if both
+ * fail.
+ */
DateFormat df =
DateFormat.getDateTimeInstance(DateFormat.SHORT,
DateFormat.SHORT,
Locale.US);
try {
setMillis(df.parse(dateTime).getTime());
- if (millis < 0) {
- throw new BuildException("Date of " + dateTime
- + " results in negative "
- + "milliseconds value "
- + "relative to epoch "
- + "(January 1, 1970, "
- + "00:00:00 GMT).");
- }
} catch (ParseException pe) {
- throw new BuildException(pe.getMessage(), pe,
getLocation());
+ df =
+ DateFormat.getDateTimeInstance(DateFormat.SHORT,
+ DateFormat.MEDIUM,
+ Locale.US);
+ try {
+ setMillis(df.parse(dateTime).getTime());
+ } catch (ParseException pe2) {
+ throw new BuildException(pe2.getMessage(), pe,
+ getLocation());
+ }
+ }
+
+ if (millis < 0) {
+ throw new BuildException("Date of " + dateTime
+ + " results in negative "
+ + "milliseconds value "
+ + "relative to epoch "
+ + "(January 1, 1970, "
+ + "00:00:00 GMT).");
}
}
1.1
ant/src/testcases/org/apache/tools/ant/taskdefs/TouchTest.java
Index: TouchTest.java
===================================================================
/*
* The Apache Software License, Version 1.1
*
* Copyright (c) 2003 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 "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 [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.BuildFileTest;
public class TouchTest extends BuildFileTest {
public TouchTest(String name) {
super(name);
}
public void setUp() {
configureProject("src/etc/testcases/taskdefs/touch.xml");
}
public void tearDown() {
executeTarget("cleanup");
}
/**
* No real test, simply checks whether the dateformat without
* seconds is accepted - by erroring out otherwise.
*/
public void testNoSeconds() {
executeTarget("noSeconds");
}
/**
* No real test, simply checks whether the dateformat with
* seconds is accepted - by erroring out otherwise.
*/
public void testSeconds() {
executeTarget("seconds");
}
}
---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]