PR: 5000 Reported by: max@eos.dk (Max Rydahl Andersen) git-svn-id: https://svn.apache.org/repos/asf/ant/core/trunk@270005 13f79535-47bb-0310-9956-ffa450edef68master
@@ -35,8 +35,8 @@ probably in an initialization target.</p> | |||||
<h3>Nested Elements</h3> | <h3>Nested Elements</h3> | ||||
The Tstamp task supports a <code><format></code> nested element that | The Tstamp task supports a <code><format></code> nested element that | ||||
allows a property to be set to the current date and time in a given format. | allows a property to be set to the current date and time in a given format. | ||||
The date/time patterns are as defined in the Java | |||||
<a href="http://java.sun.com/products/jdk/1.2/docs/api/java/text/SimpleDateFormat.html">SimpleDateFormat</a> class. | |||||
The date/time patterns are as defined in the Java | |||||
<a href="http://java.sun.com/products/jdk/1.2/docs/api/java/text/SimpleDateFormat.html">SimpleDateFormat</a> class. | |||||
The format element also allows offsets to be applied to the time to generate different time values. | The format element also allows offsets to be applied to the time to generate different time values. | ||||
<br><br> | <br><br> | ||||
<table width="60%" border="1" cellpadding="2" cellspacing="0"> | <table width="60%" border="1" cellpadding="2" cellspacing="0"> | ||||
@@ -57,6 +57,11 @@ The format element also allows offsets to be applied to the time to generate dif | |||||
<td valign="top">The date/time pattern to be used. The values are as defined by the Java SimpleDateFormat class.</td> | <td valign="top">The date/time pattern to be used. The values are as defined by the Java SimpleDateFormat class.</td> | ||||
<td align="center" valign="top">Yes</td> | <td align="center" valign="top">Yes</td> | ||||
</tr> | </tr> | ||||
<tr> | |||||
<td valign="top">timezone</td> | |||||
<td valign="top">The timezone to use for displaying time. The values are as defined by the Java <a href="http://java.sun.com/products/jdk/1.2/docs/api/java/util/TimeZone.html">TimeZone</a> class.</td> | |||||
<td align="center" valign="top">No</td> | |||||
</tr> | |||||
<tr> | <tr> | ||||
<td valign="top">offset</td> | <td valign="top">offset</td> | ||||
<td valign="top">The numeric offset to the current time</td> | <td valign="top">The numeric offset to the current time</td> | ||||
@@ -84,7 +89,7 @@ The format element also allows offsets to be applied to the time to generate dif | |||||
<td valign="top">The locale used to create date/time string. The general | <td valign="top">The locale used to create date/time string. The general | ||||
form is "language, country, variant" but either variant or variant and | form is "language, country, variant" but either variant or variant and | ||||
country may be omitted. For more information please refer to documentation | country may be omitted. For more information please refer to documentation | ||||
for the | |||||
for the | |||||
<a href="http://java.sun.com/j2se/1.3/docs/api/java/util/Locale.html">Locale</a> | <a href="http://java.sun.com/j2se/1.3/docs/api/java/util/Locale.html">Locale</a> | ||||
class.</td> | class.</td> | ||||
<td align="center" valign="top">No</td> | <td align="center" valign="top">No</td> | ||||
@@ -112,10 +117,10 @@ using English locale (eg. 21-May-2001).</p> | |||||
<pre> | <pre> | ||||
<tstamp> | <tstamp> | ||||
<format property="touch.time" pattern="MM/dd/yyyy hh:mm aa" | |||||
<format property="touch.time" pattern="MM/dd/yyyy hh:mm aa" | |||||
offset="-5" unit="hour"/> | offset="-5" unit="hour"/> | ||||
</tstamp> | |||||
</pre> | |||||
</tstamp> | |||||
</pre> | |||||
<p> | <p> | ||||
Creates a timestamp, in the property touch.time, 5 hours before the current time. The format in this example | Creates a timestamp, in the property touch.time, 5 hours before the current time. The format in this example | ||||
is suitable for use with the <touch> task</p> | is suitable for use with the <touch> task</p> | ||||
@@ -66,6 +66,7 @@ import java.util.Enumeration; | |||||
import java.util.Calendar; | import java.util.Calendar; | ||||
import java.util.StringTokenizer; | import java.util.StringTokenizer; | ||||
import java.util.NoSuchElementException; | import java.util.NoSuchElementException; | ||||
import java.util.TimeZone; | |||||
import java.text.SimpleDateFormat; | import java.text.SimpleDateFormat; | ||||
/** | /** | ||||
@@ -77,7 +78,7 @@ import java.text.SimpleDateFormat; | |||||
* @author conor@cognet.com.au | * @author conor@cognet.com.au | ||||
*/ | */ | ||||
public class Tstamp extends Task { | public class Tstamp extends Task { | ||||
private Vector customFormats = new Vector(); | private Vector customFormats = new Vector(); | ||||
public void execute() throws BuildException { | public void execute() throws BuildException { | ||||
@@ -92,18 +93,18 @@ public class Tstamp extends Task { | |||||
SimpleDateFormat today = new SimpleDateFormat ("MMMM d yyyy", Locale.US); | SimpleDateFormat today = new SimpleDateFormat ("MMMM d yyyy", Locale.US); | ||||
project.setProperty("TODAY", today.format(d)); | project.setProperty("TODAY", today.format(d)); | ||||
Enumeration i = customFormats.elements(); | Enumeration i = customFormats.elements(); | ||||
while(i.hasMoreElements()) { | while(i.hasMoreElements()) { | ||||
CustomFormat cts = (CustomFormat)i.nextElement(); | CustomFormat cts = (CustomFormat)i.nextElement(); | ||||
cts.execute(project,d, location); | cts.execute(project,d, location); | ||||
} | } | ||||
} catch (Exception e) { | } catch (Exception e) { | ||||
throw new BuildException(e); | throw new BuildException(e); | ||||
} | } | ||||
} | } | ||||
public CustomFormat createFormat() | public CustomFormat createFormat() | ||||
{ | { | ||||
CustomFormat cts = new CustomFormat(); | CustomFormat cts = new CustomFormat(); | ||||
@@ -113,6 +114,7 @@ public class Tstamp extends Task { | |||||
public class CustomFormat | public class CustomFormat | ||||
{ | { | ||||
private TimeZone timeZone; | |||||
private String propertyName; | private String propertyName; | ||||
private String pattern; | private String pattern; | ||||
private String language; | private String language; | ||||
@@ -157,7 +159,11 @@ public class Tstamp extends Task { | |||||
throw new BuildException( "bad locale format", e, getLocation()); | throw new BuildException( "bad locale format", e, getLocation()); | ||||
} | } | ||||
} | } | ||||
public void setTimezone(String id){ | |||||
timeZone = TimeZone.getTimeZone(id); | |||||
} | |||||
public void setOffset(int offset) { | public void setOffset(int offset) { | ||||
this.offset = offset; | this.offset = offset; | ||||
} | } | ||||
@@ -218,7 +224,9 @@ public class Tstamp extends Task { | |||||
calendar.add(field, offset); | calendar.add(field, offset); | ||||
date = calendar.getTime(); | date = calendar.getTime(); | ||||
} | } | ||||
if (timeZone != null){ | |||||
sdf.setTimeZone(timeZone); | |||||
} | |||||
project.setProperty(propertyName, sdf.format(date)); | project.setProperty(propertyName, sdf.format(date)); | ||||
} | } | ||||
} | } | ||||
@@ -0,0 +1,103 @@ | |||||
/* | |||||
* 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; | |||||
import java.util.Calendar; | |||||
import java.util.TimeZone; | |||||
import java.util.Date; | |||||
import java.text.SimpleDateFormat; | |||||
import junit.framework.TestCase; | |||||
import org.apache.tools.ant.Project; | |||||
import org.apache.tools.ant.Location; | |||||
/** | |||||
* | |||||
* @author <a href="mailto:sbailliez@apache.org">Stephane Bailliez</a> | |||||
*/ | |||||
public class TStampTest extends TestCase { | |||||
protected Tstamp tstamp; | |||||
protected Project project; | |||||
protected Location location; | |||||
public TStampTest(String s) { | |||||
super(s); | |||||
} | |||||
protected void setUp() throws Exception { | |||||
location = new Location("test.xml"); | |||||
project = new Project(); | |||||
tstamp = new Tstamp(); | |||||
tstamp.setLocation(location); | |||||
tstamp.setProject(project); | |||||
} | |||||
public void testTimeZone() throws Exception { | |||||
Tstamp.CustomFormat format = tstamp.createFormat(); | |||||
format.setProperty("today"); | |||||
format.setPattern("HH:mm:ss z"); | |||||
format.setTimezone("GMT"); | |||||
Date date = Calendar.getInstance().getTime(); | |||||
format.execute(project, date, location); | |||||
String today = project.getProperty("today"); | |||||
SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss z"); | |||||
sdf.setTimeZone( TimeZone.getTimeZone("GMT") ); | |||||
String expected = sdf.format(date); | |||||
assertEquals(expected, today); | |||||
} | |||||
} |