All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.fortuna.ical4j.model.Date Maven / Gradle / Ivy

/**
 * Copyright (c) 2012, Ben Fortuna
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *
 *  o Redistributions of source code must retain the above copyright
 * notice, this list of conditions and the following disclaimer.
 *
 *  o 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.
 *
 *  o Neither the name of Ben Fortuna nor the names of any other contributors
 * may be used to endorse or promote products derived from this software
 * without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS 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 COPYRIGHT OWNER OR
 * 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.
 */
package net.fortuna.ical4j.model;

import net.fortuna.ical4j.util.CompatibilityHints;
import net.fortuna.ical4j.util.Dates;
import net.fortuna.ical4j.util.TimeZones;

import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.TimeZone;


/**
 * A representation of the DATE object defined in RFC5445.
 * 

* NOTE: iCal4j calculates the timezone of Date objects by default. In the iCalendar specification a * DATE object doesn't really have a timezone associated with it, but in the ical4j implementation it does (as it is * based on a java.util.Date object). An unfortunate side effect of this is that a Date object can be affected by * daylight savings rules for the associated timezone. So currently ical4j offers two approaches to setting the * timezone: *

*

    *
  1. Use UTC time (no DST rules, but depending on how the Date is constructed it may change the displayed value
  2. *
  3. Use local timezone (in rare cases the DST rules may affect the displayed value).
  4. *
*

* By default option 1 is used, but you can override this with the following flag in the ical4j.properties file: * net.fortuna.ical4j.timezone.date.floating=true *

* Alternatively you can avoid using the constructor that accepts a java.util.Date object, and instead provide a date * string value. This should always display the correct value, however when the local timezone is used any calculations * (recurrences, etc.) may still be affect by DST rules. *

* Extract from RFC5545: *

*

 * 3.3.4.  Date
 * 
 * Value Name:  DATE
 * 
 * Purpose:  This value type is used to identify values that contain a
 * calendar date.
 * 
 * Format Definition:  This value type is defined by the following
 * notation:
 * 
 * date               = date-value
 * 
 * date-value         = date-fullyear date-month date-mday
 * date-fullyear      = 4DIGIT
 * date-month         = 2DIGIT        ;01-12
 * date-mday          = 2DIGIT        ;01-28, 01-29, 01-30, 01-31
 * ;based on month/year
 * 
 * Description:  If the property permits, multiple "date" values are
 * specified as a COMMA-separated list of values.  The format for the
 * value type is based on the [ISO.8601.2004] complete
 * representation, basic format for a calendar date.  The textual
 * format specifies a four-digit year, two-digit month, and two-digit
 * day of the month.  There are no separator characters between the
 * year, month, and day component text.
 * 
 * No additional content value encoding (i.e., BACKSLASH character
 * encoding, see Section 3.3.11) is defined for this value type.
 * 
 * Example:  The following represents July 14, 1997:
 * 
 * 19970714
 * 
 * 
* * @author Ben Fortuna * @version 2.0 */ public class Date extends Iso8601 { private static final long serialVersionUID = 7136072363141363141L; private static final String DEFAULT_PATTERN = "yyyyMMdd"; private static final String VCARD_PATTERN = "yyyy'-'MM'-'dd"; /** * Default constructor. */ public Date() { super(DEFAULT_PATTERN, Dates.PRECISION_DAY, TimeZones.getDateTimeZone()); } /** * Creates a new date instance with the specified precision. This * constructor is only intended for use by sub-classes. * @param precision the date precision * @param tz the timezone * @see Dates#PRECISION_DAY * @see Dates#PRECISION_SECOND */ protected Date(final int precision, TimeZone tz) { super(DEFAULT_PATTERN, precision, tz); } /** * @param time a date value in milliseconds */ public Date(final long time) { super(time, DEFAULT_PATTERN, Dates.PRECISION_DAY, TimeZones.getDateTimeZone()); } /** * Creates a new date instance with the specified precision. This * constructor is only intended for use by sub-classes. * @param time a date value in milliseconds * @param precision the date precision * @param tz the timezone * @see Dates#PRECISION_DAY * @see Dates#PRECISION_SECOND */ protected Date(final long time, final int precision, TimeZone tz) { super(time, DEFAULT_PATTERN, precision, tz); } /** * @param calendar a calendar value */ public Date(final java.util.Calendar calendar) { this(calendar.getTimeInMillis(), Dates.PRECISION_DAY, TimeZones.getDateTimeZone()); } /** * @param date a date value */ public Date(final java.util.Date date) { // this(); this(date.getTime(), Dates.PRECISION_DAY, TimeZones.getDateTimeZone()); // setTime(date.getTime()); } /** * @param value a string representation of a date * @throws ParseException where the specified string is not a valid date */ public Date(final String value) throws ParseException { this(); try { setTime(getFormat().parse(value).getTime()); } catch (ParseException pe) { if (CompatibilityHints.isHintEnabled(CompatibilityHints.KEY_VCARD_COMPATIBILITY)) { final DateFormat parseFormat = new SimpleDateFormat(VCARD_PATTERN); parseFormat.setTimeZone(TimeZones.getDateTimeZone()); setTime(parseFormat.parse(value).getTime()); } else { throw pe; } } } /** * @param value a string representation of a date * @param pattern a date pattern to apply when parsing * @throws ParseException where the specified string is not a valid date */ public Date(String value, String pattern) throws ParseException { super(DEFAULT_PATTERN, Dates.PRECISION_DAY, TimeZones.getDateTimeZone()); final DateFormat parseFormat = new SimpleDateFormat(pattern); parseFormat.setTimeZone(TimeZones.getDateTimeZone()); setTime(parseFormat.parse(value).getTime()); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy