2000-11-28 04:09:22 +01:00
|
|
|
/* java.util.TimeZone
|
2003-12-18 17:43:02 +01:00
|
|
|
Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003
|
|
|
|
Free Software Foundation, Inc.
|
1999-04-07 16:42:40 +02:00
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
This file is part of GNU Classpath.
|
|
|
|
|
|
|
|
GNU Classpath is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2, or (at your option)
|
|
|
|
any later version.
|
|
|
|
|
|
|
|
GNU Classpath is distributed in the hope that it will be useful, but
|
|
|
|
WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with GNU Classpath; see the file COPYING. If not, write to the
|
|
|
|
Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
|
|
|
02111-1307 USA.
|
|
|
|
|
2002-01-22 23:40:42 +01:00
|
|
|
Linking this library statically or dynamically with other modules is
|
|
|
|
making a combined work based on this library. Thus, the terms and
|
|
|
|
conditions of the GNU General Public License cover the whole
|
|
|
|
combination.
|
|
|
|
|
|
|
|
As a special exception, the copyright holders of this library give you
|
|
|
|
permission to link this library with independent modules to produce an
|
|
|
|
executable, regardless of the license terms of these independent
|
|
|
|
modules, and to copy and distribute the resulting executable under
|
|
|
|
terms of your choice, provided that you also meet, for each linked
|
|
|
|
independent module, the terms and conditions of the license of that
|
|
|
|
module. An independent module is a module which is not derived from
|
|
|
|
or based on this library. If you modify this library, you may extend
|
|
|
|
this exception to your version of the library, but you are not
|
|
|
|
obligated to do so. If you do not wish to do so, delete this
|
|
|
|
exception statement from your version. */
|
1999-04-07 16:42:40 +02:00
|
|
|
|
|
|
|
|
|
|
|
package java.util;
|
2000-11-28 04:09:22 +01:00
|
|
|
import java.text.DateFormatSymbols;
|
2002-05-13 22:10:37 +02:00
|
|
|
import gnu.classpath.Configuration;
|
1999-04-07 16:42:40 +02:00
|
|
|
|
|
|
|
/**
|
2000-11-28 04:09:22 +01:00
|
|
|
* This class represents a time zone offset and handles daylight savings.
|
|
|
|
*
|
|
|
|
* You can get the default time zone with <code>getDefault</code>.
|
|
|
|
* This represents the time zone where program is running.
|
|
|
|
*
|
|
|
|
* Another way to create a time zone is <code>getTimeZone</code>, where
|
|
|
|
* you can give an identifier as parameter. For instance, the identifier
|
|
|
|
* of the Central European Time zone is "CET".
|
|
|
|
*
|
|
|
|
* With the <code>getAvailableIDs</code> method, you can get all the
|
|
|
|
* supported time zone identifiers.
|
|
|
|
*
|
|
|
|
* @see Calendar
|
|
|
|
* @see SimpleTimeZone
|
|
|
|
* @author Jochen Hoenicke
|
1999-04-07 16:42:40 +02:00
|
|
|
*/
|
|
|
|
public abstract class TimeZone implements java.io.Serializable, Cloneable
|
|
|
|
{
|
2000-11-28 04:09:22 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Constant used to indicate that a short timezone abbreviation should
|
|
|
|
* be returned, such as "EST"
|
|
|
|
*/
|
1999-04-07 16:42:40 +02:00
|
|
|
public static final int SHORT = 0;
|
2000-11-28 04:09:22 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Constant used to indicate that a long timezone name should be
|
|
|
|
* returned, such as "Eastern Standard Time".
|
|
|
|
*/
|
1999-04-07 16:42:40 +02:00
|
|
|
public static final int LONG = 1;
|
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* The time zone identifier, e.g. PST.
|
|
|
|
*/
|
|
|
|
private String ID;
|
1999-04-07 16:42:40 +02:00
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* The default time zone, as returned by getDefault.
|
|
|
|
*/
|
2003-09-18 08:34:00 +02:00
|
|
|
private static TimeZone defaultZone0;
|
|
|
|
/* initialize this static field lazily to overhead if
|
|
|
|
* it is not needed:
|
|
|
|
*/
|
|
|
|
private static synchronized TimeZone defaultZone() {
|
|
|
|
/* Look up default timezone */
|
|
|
|
if (defaultZone0 == null)
|
|
|
|
{
|
|
|
|
if (Configuration.INIT_LOAD_LIBRARY)
|
|
|
|
{
|
|
|
|
System.loadLibrary("javautil");
|
|
|
|
}
|
|
|
|
String tzid = System.getProperty("user.timezone");
|
|
|
|
|
|
|
|
if (tzid == null)
|
|
|
|
tzid = getDefaultTimeZoneId();
|
|
|
|
|
|
|
|
if (tzid == null)
|
|
|
|
tzid = "GMT";
|
|
|
|
|
|
|
|
defaultZone0 = getTimeZone(tzid);
|
|
|
|
}
|
|
|
|
return defaultZone0;
|
|
|
|
}
|
|
|
|
|
1999-04-07 16:42:40 +02:00
|
|
|
|
2000-09-08 21:37:09 +02:00
|
|
|
private static final long serialVersionUID = 3581463369166924961L;
|
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* Hashtable for timezones by ID.
|
|
|
|
*/
|
2003-09-18 08:34:00 +02:00
|
|
|
private static Hashtable timezones0;
|
|
|
|
/* initialize this static field lazily to overhead if
|
|
|
|
* it is not needed:
|
|
|
|
*/
|
|
|
|
private static synchronized Hashtable timezones() {
|
|
|
|
if (timezones0==null)
|
2002-05-13 22:10:37 +02:00
|
|
|
{
|
2003-09-18 08:34:00 +02:00
|
|
|
Hashtable timezones = new Hashtable();
|
|
|
|
timezones0 = timezones;
|
1999-04-07 16:42:40 +02:00
|
|
|
|
2003-09-18 08:34:00 +02:00
|
|
|
TimeZone tz;
|
|
|
|
// Automatically generated by scripts/timezones.pl
|
|
|
|
// XXX - Should we read this data from a file?
|
|
|
|
tz = new SimpleTimeZone(-11000 * 3600, "MIT");
|
|
|
|
timezones0.put("MIT", tz);
|
|
|
|
timezones0.put("Pacific/Apia", tz);
|
|
|
|
timezones0.put("Pacific/Midway", tz);
|
|
|
|
timezones0.put("Pacific/Niue", tz);
|
|
|
|
timezones0.put("Pacific/Pago_Pago", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-10000 * 3600, "America/Adak",
|
|
|
|
Calendar.APRIL, 1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("America/Adak", tz);
|
|
|
|
tz = new SimpleTimeZone(-10000 * 3600, "HST");
|
|
|
|
timezones0.put("HST", tz);
|
|
|
|
timezones0.put("Pacific/Fakaofo", tz);
|
|
|
|
timezones0.put("Pacific/Honolulu", tz);
|
|
|
|
timezones0.put("Pacific/Johnston", tz);
|
|
|
|
timezones0.put("Pacific/Rarotonga", tz);
|
|
|
|
timezones0.put("Pacific/Tahiti", tz);
|
|
|
|
tz = new SimpleTimeZone(-9500 * 3600, "Pacific/Marquesas");
|
|
|
|
timezones0.put("Pacific/Marquesas", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-9000 * 3600, "AST",
|
|
|
|
Calendar.APRIL, 1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("AST", tz);
|
|
|
|
timezones0.put("America/Anchorage", tz);
|
|
|
|
timezones0.put("America/Juneau", tz);
|
|
|
|
timezones0.put("America/Nome", tz);
|
|
|
|
timezones0.put("America/Yakutat", tz);
|
|
|
|
tz = new SimpleTimeZone(-9000 * 3600, "Pacific/Gambier");
|
|
|
|
timezones0.put("Pacific/Gambier", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-8000 * 3600, "PST",
|
|
|
|
Calendar.APRIL, 1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("PST", tz);
|
|
|
|
timezones0.put("PST8PDT", tz);
|
|
|
|
timezones0.put("America/Dawson", tz);
|
|
|
|
timezones0.put("America/Los_Angeles", tz);
|
|
|
|
timezones0.put("America/Tijuana", tz);
|
|
|
|
timezones0.put("America/Vancouver", tz);
|
|
|
|
timezones0.put("America/Whitehorse", tz);
|
|
|
|
timezones0.put("US/Pacific-New", tz);
|
|
|
|
tz = new SimpleTimeZone(-8000 * 3600, "Pacific/Pitcairn");
|
|
|
|
timezones0.put("Pacific/Pitcairn", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-7000 * 3600, "MST",
|
|
|
|
Calendar.APRIL, 1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("MST", tz);
|
|
|
|
timezones0.put("MST7MDT", tz);
|
|
|
|
timezones0.put("America/Boise", tz);
|
|
|
|
timezones0.put("America/Chihuahua", tz);
|
|
|
|
timezones0.put("America/Denver", tz);
|
|
|
|
timezones0.put("America/Edmonton", tz);
|
|
|
|
timezones0.put("America/Inuvik", tz);
|
|
|
|
timezones0.put("America/Mazatlan", tz);
|
|
|
|
timezones0.put("America/Shiprock", tz);
|
|
|
|
timezones0.put("America/Yellowknife", tz);
|
|
|
|
tz = new SimpleTimeZone(-7000 * 3600, "MST7");
|
|
|
|
timezones0.put("MST7", tz);
|
|
|
|
timezones0.put("PNT", tz);
|
|
|
|
timezones0.put("America/Dawson_Creek", tz);
|
|
|
|
timezones0.put("America/Hermosillo", tz);
|
|
|
|
timezones0.put("America/Phoenix", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-6000 * 3600, "CST",
|
|
|
|
Calendar.APRIL, 1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("CST", tz);
|
|
|
|
timezones0.put("CST6CDT", tz);
|
|
|
|
timezones0.put("America/Cambridge_Bay", tz);
|
|
|
|
timezones0.put("America/Cancun", tz);
|
|
|
|
timezones0.put("America/Chicago", tz);
|
|
|
|
timezones0.put("America/Menominee", tz);
|
|
|
|
timezones0.put("America/Merida", tz);
|
|
|
|
timezones0.put("America/Mexico_City", tz);
|
|
|
|
timezones0.put("America/Monterrey", tz);
|
|
|
|
timezones0.put("America/Rainy_River", tz);
|
|
|
|
timezones0.put("America/Winnipeg", tz);
|
|
|
|
tz = new SimpleTimeZone(-6000 * 3600, "America/Belize");
|
|
|
|
timezones0.put("America/Belize", tz);
|
|
|
|
timezones0.put("America/Costa_Rica", tz);
|
|
|
|
timezones0.put("America/El_Salvador", tz);
|
|
|
|
timezones0.put("America/Guatemala", tz);
|
|
|
|
timezones0.put("America/Managua", tz);
|
|
|
|
timezones0.put("America/Regina", tz);
|
|
|
|
timezones0.put("America/Swift_Current", tz);
|
|
|
|
timezones0.put("America/Tegucigalpa", tz);
|
|
|
|
timezones0.put("Pacific/Galapagos", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-6000 * 3600, "Pacific/Easter",
|
|
|
|
Calendar.OCTOBER, 9, -Calendar.SUNDAY, 0 * 3600,
|
|
|
|
Calendar.MARCH, 9, -Calendar.SUNDAY, 0 * 3600);
|
|
|
|
timezones0.put("Pacific/Easter", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-5000 * 3600, "America/Grand_Turk",
|
|
|
|
Calendar.APRIL, 1, Calendar.SUNDAY, 0 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 0 * 3600);
|
|
|
|
timezones0.put("America/Grand_Turk", tz);
|
|
|
|
timezones0.put("America/Havana", tz);
|
|
|
|
tz = new SimpleTimeZone(-5000 * 3600, "EST5");
|
|
|
|
timezones0.put("EST5", tz);
|
|
|
|
timezones0.put("IET", tz);
|
|
|
|
timezones0.put("America/Bogota", tz);
|
|
|
|
timezones0.put("America/Cayman", tz);
|
|
|
|
timezones0.put("America/Eirunepe", tz);
|
|
|
|
timezones0.put("America/Guayaquil", tz);
|
|
|
|
timezones0.put("America/Indiana/Indianapolis", tz);
|
|
|
|
timezones0.put("America/Indiana/Knox", tz);
|
|
|
|
timezones0.put("America/Indiana/Marengo", tz);
|
|
|
|
timezones0.put("America/Indiana/Vevay", tz);
|
|
|
|
timezones0.put("America/Indianapolis", tz);
|
|
|
|
timezones0.put("America/Iqaluit", tz);
|
|
|
|
timezones0.put("America/Jamaica", tz);
|
|
|
|
timezones0.put("America/Lima", tz);
|
|
|
|
timezones0.put("America/Panama", tz);
|
|
|
|
timezones0.put("America/Pangnirtung", tz);
|
|
|
|
timezones0.put("America/Port-au-Prince", tz);
|
|
|
|
timezones0.put("America/Porto_Acre", tz);
|
|
|
|
timezones0.put("America/Rankin_Inlet", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-5000 * 3600, "EST",
|
|
|
|
Calendar.APRIL, 1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("EST", tz);
|
|
|
|
timezones0.put("EST5EDT", tz);
|
|
|
|
timezones0.put("America/Detroit", tz);
|
|
|
|
timezones0.put("America/Kentucky/Louisville", tz);
|
|
|
|
timezones0.put("America/Kentucky/Monticello", tz);
|
|
|
|
timezones0.put("America/Louisville", tz);
|
|
|
|
timezones0.put("America/Montreal", tz);
|
|
|
|
timezones0.put("America/Nassau", tz);
|
|
|
|
timezones0.put("America/New_York", tz);
|
|
|
|
timezones0.put("America/Nipigon", tz);
|
|
|
|
timezones0.put("America/Thunder_Bay", tz);
|
|
|
|
tz = new SimpleTimeZone(-4000 * 3600, "PRT");
|
|
|
|
timezones0.put("PRT", tz);
|
|
|
|
timezones0.put("America/Anguilla", tz);
|
|
|
|
timezones0.put("America/Antigua", tz);
|
|
|
|
timezones0.put("America/Aruba", tz);
|
|
|
|
timezones0.put("America/Barbados", tz);
|
|
|
|
timezones0.put("America/Boa_Vista", tz);
|
|
|
|
timezones0.put("America/Caracas", tz);
|
|
|
|
timezones0.put("America/Curacao", tz);
|
|
|
|
timezones0.put("America/Dominica", tz);
|
|
|
|
timezones0.put("America/Grenada", tz);
|
|
|
|
timezones0.put("America/Guadeloupe", tz);
|
|
|
|
timezones0.put("America/Guyana", tz);
|
|
|
|
timezones0.put("America/La_Paz", tz);
|
|
|
|
timezones0.put("America/Manaus", tz);
|
|
|
|
timezones0.put("America/Martinique", tz);
|
|
|
|
timezones0.put("America/Montserrat", tz);
|
|
|
|
timezones0.put("America/Port_of_Spain", tz);
|
|
|
|
timezones0.put("America/Porto_Velho", tz);
|
|
|
|
timezones0.put("America/Puerto_Rico", tz);
|
|
|
|
timezones0.put("America/Santo_Domingo", tz);
|
|
|
|
timezones0.put("America/St_Kitts", tz);
|
|
|
|
timezones0.put("America/St_Lucia", tz);
|
|
|
|
timezones0.put("America/St_Thomas", tz);
|
|
|
|
timezones0.put("America/St_Vincent", tz);
|
|
|
|
timezones0.put("America/Tortola", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-4000 * 3600, "America/Asuncion",
|
|
|
|
Calendar.OCTOBER, 1, Calendar.SUNDAY, 0 * 3600,
|
|
|
|
Calendar.FEBRUARY, -1, Calendar.SUNDAY, 0 * 3600);
|
|
|
|
timezones0.put("America/Asuncion", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-4000 * 3600, "America/Cuiaba",
|
|
|
|
Calendar.OCTOBER, 2, Calendar.SUNDAY, 0 * 3600,
|
|
|
|
Calendar.FEBRUARY, 3, Calendar.SUNDAY, 0 * 3600);
|
|
|
|
timezones0.put("America/Cuiaba", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-4000 * 3600, "America/Goose_Bay",
|
|
|
|
Calendar.APRIL, 1, Calendar.SUNDAY, 60000,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 60000);
|
|
|
|
timezones0.put("America/Goose_Bay", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-4000 * 3600, "America/Glace_Bay",
|
|
|
|
Calendar.APRIL, 1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("America/Glace_Bay", tz);
|
|
|
|
timezones0.put("America/Halifax", tz);
|
|
|
|
timezones0.put("America/Thule", tz);
|
|
|
|
timezones0.put("Atlantic/Bermuda", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-4000 * 3600, "America/Santiago",
|
|
|
|
Calendar.OCTOBER, 9, -Calendar.SUNDAY, 0 * 3600,
|
|
|
|
Calendar.MARCH, 9, -Calendar.SUNDAY, 0 * 3600);
|
|
|
|
timezones0.put("America/Santiago", tz);
|
|
|
|
timezones0.put("Antarctica/Palmer", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-4000 * 3600, "Atlantic/Stanley",
|
|
|
|
Calendar.SEPTEMBER, 2, Calendar.SUNDAY, 0 * 3600,
|
|
|
|
Calendar.APRIL, 16, -Calendar.SUNDAY, 0 * 3600);
|
|
|
|
timezones0.put("Atlantic/Stanley", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-3500 * 3600, "CNT",
|
|
|
|
Calendar.APRIL, 1, Calendar.SUNDAY, 60000,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 60000);
|
|
|
|
timezones0.put("CNT", tz);
|
|
|
|
timezones0.put("America/St_Johns", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-3000 * 3600, "America/Araguaina",
|
|
|
|
Calendar.OCTOBER, 2, Calendar.SUNDAY, 0 * 3600,
|
|
|
|
Calendar.FEBRUARY, 3, Calendar.SUNDAY, 0 * 3600);
|
|
|
|
timezones0.put("America/Araguaina", tz);
|
|
|
|
timezones0.put("America/Sao_Paulo", tz);
|
|
|
|
tz = new SimpleTimeZone(-3000 * 3600, "AGT");
|
|
|
|
timezones0.put("AGT", tz);
|
|
|
|
timezones0.put("America/Belem", tz);
|
|
|
|
timezones0.put("America/Buenos_Aires", tz);
|
|
|
|
timezones0.put("America/Catamarca", tz);
|
|
|
|
timezones0.put("America/Cayenne", tz);
|
|
|
|
timezones0.put("America/Cordoba", tz);
|
|
|
|
timezones0.put("America/Fortaleza", tz);
|
|
|
|
timezones0.put("America/Jujuy", tz);
|
|
|
|
timezones0.put("America/Maceio", tz);
|
|
|
|
timezones0.put("America/Mendoza", tz);
|
|
|
|
timezones0.put("America/Montevideo", tz);
|
|
|
|
timezones0.put("America/Paramaribo", tz);
|
|
|
|
timezones0.put("America/Recife", tz);
|
|
|
|
timezones0.put("America/Rosario", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-3000 * 3600, "America/Godthab",
|
|
|
|
Calendar.MARCH, 30, -Calendar.SATURDAY, 22000 * 3600,
|
|
|
|
Calendar.OCTOBER, 30, -Calendar.SATURDAY, 22000 * 3600);
|
|
|
|
timezones0.put("America/Godthab", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-3000 * 3600, "America/Miquelon",
|
|
|
|
Calendar.APRIL, 1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("America/Miquelon", tz);
|
|
|
|
tz = new SimpleTimeZone(-2000 * 3600, "America/Noronha");
|
|
|
|
timezones0.put("America/Noronha", tz);
|
|
|
|
timezones0.put("Atlantic/South_Georgia", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(-1000 * 3600, "America/Scoresbysund",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 0 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 0 * 3600);
|
|
|
|
timezones0.put("America/Scoresbysund", tz);
|
|
|
|
timezones0.put("Atlantic/Azores", tz);
|
|
|
|
tz = new SimpleTimeZone(-1000 * 3600, "Atlantic/Cape_Verde");
|
|
|
|
timezones0.put("Atlantic/Cape_Verde", tz);
|
|
|
|
timezones0.put("Atlantic/Jan_Mayen", tz);
|
|
|
|
tz = new SimpleTimeZone(0 * 3600, "GMT");
|
|
|
|
timezones0.put("GMT", tz);
|
|
|
|
timezones0.put("UTC", tz);
|
|
|
|
timezones0.put("Africa/Abidjan", tz);
|
|
|
|
timezones0.put("Africa/Accra", tz);
|
|
|
|
timezones0.put("Africa/Bamako", tz);
|
|
|
|
timezones0.put("Africa/Banjul", tz);
|
|
|
|
timezones0.put("Africa/Bissau", tz);
|
|
|
|
timezones0.put("Africa/Casablanca", tz);
|
|
|
|
timezones0.put("Africa/Conakry", tz);
|
|
|
|
timezones0.put("Africa/Dakar", tz);
|
|
|
|
timezones0.put("Africa/El_Aaiun", tz);
|
|
|
|
timezones0.put("Africa/Freetown", tz);
|
|
|
|
timezones0.put("Africa/Lome", tz);
|
|
|
|
timezones0.put("Africa/Monrovia", tz);
|
|
|
|
timezones0.put("Africa/Nouakchott", tz);
|
|
|
|
timezones0.put("Africa/Ouagadougou", tz);
|
|
|
|
timezones0.put("Africa/Sao_Tome", tz);
|
|
|
|
timezones0.put("Africa/Timbuktu", tz);
|
|
|
|
timezones0.put("Atlantic/Reykjavik", tz);
|
|
|
|
timezones0.put("Atlantic/St_Helena", tz);
|
|
|
|
timezones0.put("Europe/Belfast", tz);
|
|
|
|
timezones0.put("Europe/Dublin", tz);
|
|
|
|
timezones0.put("Europe/London", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(0 * 3600, "WET",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 1000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 1000 * 3600);
|
|
|
|
timezones0.put("WET", tz);
|
|
|
|
timezones0.put("Atlantic/Canary", tz);
|
|
|
|
timezones0.put("Atlantic/Faeroe", tz);
|
|
|
|
timezones0.put("Atlantic/Madeira", tz);
|
|
|
|
timezones0.put("Europe/Lisbon", tz);
|
|
|
|
tz = new SimpleTimeZone(1000 * 3600, "Africa/Algiers");
|
|
|
|
timezones0.put("Africa/Algiers", tz);
|
|
|
|
timezones0.put("Africa/Bangui", tz);
|
|
|
|
timezones0.put("Africa/Brazzaville", tz);
|
|
|
|
timezones0.put("Africa/Douala", tz);
|
|
|
|
timezones0.put("Africa/Kinshasa", tz);
|
|
|
|
timezones0.put("Africa/Lagos", tz);
|
|
|
|
timezones0.put("Africa/Libreville", tz);
|
|
|
|
timezones0.put("Africa/Luanda", tz);
|
|
|
|
timezones0.put("Africa/Malabo", tz);
|
|
|
|
timezones0.put("Africa/Ndjamena", tz);
|
|
|
|
timezones0.put("Africa/Niamey", tz);
|
|
|
|
timezones0.put("Africa/Porto-Novo", tz);
|
|
|
|
timezones0.put("Africa/Tunis", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(1000 * 3600, "Africa/Windhoek",
|
|
|
|
Calendar.SEPTEMBER, 1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.APRIL, 1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("Africa/Windhoek", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(1000 * 3600, "CET",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("CET", tz);
|
|
|
|
timezones0.put("ECT", tz);
|
|
|
|
timezones0.put("MET", tz);
|
|
|
|
timezones0.put("Africa/Ceuta", tz);
|
|
|
|
timezones0.put("Arctic/Longyearbyen", tz);
|
|
|
|
timezones0.put("Europe/Amsterdam", tz);
|
|
|
|
timezones0.put("Europe/Andorra", tz);
|
|
|
|
timezones0.put("Europe/Belgrade", tz);
|
|
|
|
timezones0.put("Europe/Berlin", tz);
|
|
|
|
timezones0.put("Europe/Bratislava", tz);
|
|
|
|
timezones0.put("Europe/Brussels", tz);
|
|
|
|
timezones0.put("Europe/Budapest", tz);
|
|
|
|
timezones0.put("Europe/Copenhagen", tz);
|
|
|
|
timezones0.put("Europe/Gibraltar", tz);
|
|
|
|
timezones0.put("Europe/Ljubljana", tz);
|
|
|
|
timezones0.put("Europe/Luxembourg", tz);
|
|
|
|
timezones0.put("Europe/Madrid", tz);
|
|
|
|
timezones0.put("Europe/Malta", tz);
|
|
|
|
timezones0.put("Europe/Monaco", tz);
|
|
|
|
timezones0.put("Europe/Oslo", tz);
|
|
|
|
timezones0.put("Europe/Paris", tz);
|
|
|
|
timezones0.put("Europe/Prague", tz);
|
|
|
|
timezones0.put("Europe/Rome", tz);
|
|
|
|
timezones0.put("Europe/San_Marino", tz);
|
|
|
|
timezones0.put("Europe/Sarajevo", tz);
|
|
|
|
timezones0.put("Europe/Skopje", tz);
|
|
|
|
timezones0.put("Europe/Stockholm", tz);
|
|
|
|
timezones0.put("Europe/Tirane", tz);
|
|
|
|
timezones0.put("Europe/Vaduz", tz);
|
|
|
|
timezones0.put("Europe/Vatican", tz);
|
|
|
|
timezones0.put("Europe/Vienna", tz);
|
|
|
|
timezones0.put("Europe/Warsaw", tz);
|
|
|
|
timezones0.put("Europe/Zagreb", tz);
|
|
|
|
timezones0.put("Europe/Zurich", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(2000 * 3600, "ART",
|
|
|
|
Calendar.APRIL, -1, Calendar.FRIDAY, 0 * 3600,
|
|
|
|
Calendar.SEPTEMBER, -1, Calendar.THURSDAY, 23000 * 3600);
|
|
|
|
timezones0.put("ART", tz);
|
|
|
|
timezones0.put("Africa/Cairo", tz);
|
|
|
|
tz = new SimpleTimeZone(2000 * 3600, "CAT");
|
|
|
|
timezones0.put("CAT", tz);
|
|
|
|
timezones0.put("Africa/Blantyre", tz);
|
|
|
|
timezones0.put("Africa/Bujumbura", tz);
|
|
|
|
timezones0.put("Africa/Gaborone", tz);
|
|
|
|
timezones0.put("Africa/Harare", tz);
|
|
|
|
timezones0.put("Africa/Johannesburg", tz);
|
|
|
|
timezones0.put("Africa/Kigali", tz);
|
|
|
|
timezones0.put("Africa/Lubumbashi", tz);
|
|
|
|
timezones0.put("Africa/Lusaka", tz);
|
|
|
|
timezones0.put("Africa/Maputo", tz);
|
|
|
|
timezones0.put("Africa/Maseru", tz);
|
|
|
|
timezones0.put("Africa/Mbabane", tz);
|
|
|
|
timezones0.put("Africa/Tripoli", tz);
|
|
|
|
timezones0.put("Europe/Riga", tz);
|
|
|
|
timezones0.put("Europe/Tallinn", tz);
|
|
|
|
timezones0.put("Europe/Vilnius", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(2000 * 3600, "Asia/Amman",
|
|
|
|
Calendar.MARCH, -1, Calendar.THURSDAY, 0 * 3600,
|
|
|
|
Calendar.SEPTEMBER, -1, Calendar.THURSDAY, 0 * 3600);
|
|
|
|
timezones0.put("Asia/Amman", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(2000 * 3600, "Asia/Beirut",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 0 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 0 * 3600);
|
|
|
|
timezones0.put("Asia/Beirut", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(2000 * 3600, "Asia/Damascus",
|
|
|
|
Calendar.APRIL, 1, 0, 0 * 3600,
|
|
|
|
Calendar.OCTOBER, 1, 0, 0 * 3600);
|
|
|
|
timezones0.put("Asia/Damascus", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(2000 * 3600, "Asia/Gaza",
|
|
|
|
Calendar.APRIL, 3, Calendar.FRIDAY, 0 * 3600,
|
|
|
|
Calendar.OCTOBER, 3, Calendar.FRIDAY, 0 * 3600);
|
|
|
|
timezones0.put("Asia/Gaza", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(2000 * 3600, "Asia/Jerusalem",
|
|
|
|
Calendar.APRIL, 1, 0, 1000 * 3600,
|
|
|
|
Calendar.OCTOBER, 1, 0, 1000 * 3600);
|
|
|
|
timezones0.put("Asia/Jerusalem", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(2000 * 3600, "EET",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 3000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 3000 * 3600);
|
|
|
|
timezones0.put("EET", tz);
|
|
|
|
timezones0.put("Asia/Istanbul", tz);
|
|
|
|
timezones0.put("Asia/Nicosia", tz);
|
|
|
|
timezones0.put("Europe/Athens", tz);
|
|
|
|
timezones0.put("Europe/Bucharest", tz);
|
|
|
|
timezones0.put("Europe/Chisinau", tz);
|
|
|
|
timezones0.put("Europe/Helsinki", tz);
|
|
|
|
timezones0.put("Europe/Istanbul", tz);
|
|
|
|
timezones0.put("Europe/Kiev", tz);
|
|
|
|
timezones0.put("Europe/Nicosia", tz);
|
|
|
|
timezones0.put("Europe/Simferopol", tz);
|
|
|
|
timezones0.put("Europe/Sofia", tz);
|
|
|
|
timezones0.put("Europe/Uzhgorod", tz);
|
|
|
|
timezones0.put("Europe/Zaporozhye", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(2000 * 3600, "Europe/Kaliningrad",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("Europe/Kaliningrad", tz);
|
|
|
|
timezones0.put("Europe/Minsk", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(3000 * 3600, "Asia/Baghdad",
|
|
|
|
Calendar.APRIL, 1, 0, 3000 * 3600,
|
|
|
|
Calendar.OCTOBER, 1, 0, 3000 * 3600);
|
|
|
|
timezones0.put("Asia/Baghdad", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(3000 * 3600, "Europe/Moscow",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("Europe/Moscow", tz);
|
|
|
|
timezones0.put("Europe/Tiraspol", tz);
|
|
|
|
tz = new SimpleTimeZone(3000 * 3600, "EAT");
|
|
|
|
timezones0.put("EAT", tz);
|
|
|
|
timezones0.put("Africa/Addis_Ababa", tz);
|
|
|
|
timezones0.put("Africa/Asmera", tz);
|
|
|
|
timezones0.put("Africa/Dar_es_Salaam", tz);
|
|
|
|
timezones0.put("Africa/Djibouti", tz);
|
|
|
|
timezones0.put("Africa/Kampala", tz);
|
|
|
|
timezones0.put("Africa/Khartoum", tz);
|
|
|
|
timezones0.put("Africa/Mogadishu", tz);
|
|
|
|
timezones0.put("Africa/Nairobi", tz);
|
|
|
|
timezones0.put("Antarctica/Syowa", tz);
|
|
|
|
timezones0.put("Asia/Aden", tz);
|
|
|
|
timezones0.put("Asia/Bahrain", tz);
|
|
|
|
timezones0.put("Asia/Kuwait", tz);
|
|
|
|
timezones0.put("Asia/Qatar", tz);
|
|
|
|
timezones0.put("Asia/Riyadh", tz);
|
|
|
|
timezones0.put("Indian/Antananarivo", tz);
|
|
|
|
timezones0.put("Indian/Comoro", tz);
|
|
|
|
timezones0.put("Indian/Mayotte", tz);
|
|
|
|
tz = new SimpleTimeZone(3500 * 3600, "Asia/Tehran");
|
|
|
|
timezones0.put("Asia/Tehran", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(4000 * 3600, "Asia/Baku",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 1000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 1000 * 3600);
|
|
|
|
timezones0.put("Asia/Baku", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(4000 * 3600, "Asia/Aqtau",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 0 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 0 * 3600);
|
|
|
|
timezones0.put("Asia/Aqtau", tz);
|
|
|
|
timezones0.put("Asia/Tbilisi", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(4000 * 3600, "Asia/Yerevan",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("Asia/Yerevan", tz);
|
|
|
|
timezones0.put("Europe/Samara", tz);
|
|
|
|
tz = new SimpleTimeZone(4000 * 3600, "NET");
|
|
|
|
timezones0.put("NET", tz);
|
|
|
|
timezones0.put("Asia/Dubai", tz);
|
|
|
|
timezones0.put("Asia/Muscat", tz);
|
|
|
|
timezones0.put("Indian/Mahe", tz);
|
|
|
|
timezones0.put("Indian/Mauritius", tz);
|
|
|
|
timezones0.put("Indian/Reunion", tz);
|
|
|
|
tz = new SimpleTimeZone(4500 * 3600, "Asia/Kabul");
|
|
|
|
timezones0.put("Asia/Kabul", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(5000 * 3600, "Asia/Aqtobe",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 0 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 0 * 3600);
|
|
|
|
timezones0.put("Asia/Aqtobe", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(5000 * 3600, "Asia/Bishkek",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2500 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2500 * 3600);
|
|
|
|
timezones0.put("Asia/Bishkek", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(5000 * 3600, "Asia/Yekaterinburg",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("Asia/Yekaterinburg", tz);
|
|
|
|
tz = new SimpleTimeZone(5000 * 3600, "PLT");
|
|
|
|
timezones0.put("PLT", tz);
|
|
|
|
timezones0.put("Asia/Ashgabat", tz);
|
|
|
|
timezones0.put("Asia/Dushanbe", tz);
|
|
|
|
timezones0.put("Asia/Karachi", tz);
|
|
|
|
timezones0.put("Asia/Samarkand", tz);
|
|
|
|
timezones0.put("Asia/Tashkent", tz);
|
|
|
|
timezones0.put("Indian/Chagos", tz);
|
|
|
|
timezones0.put("Indian/Kerguelen", tz);
|
|
|
|
timezones0.put("Indian/Maldives", tz);
|
|
|
|
tz = new SimpleTimeZone(5500 * 3600, "IST");
|
|
|
|
timezones0.put("IST", tz);
|
|
|
|
timezones0.put("Asia/Calcutta", tz);
|
|
|
|
tz = new SimpleTimeZone(5750 * 3600, "Asia/Katmandu");
|
|
|
|
timezones0.put("Asia/Katmandu", tz);
|
|
|
|
tz = new SimpleTimeZone(6000 * 3600, "BST");
|
|
|
|
timezones0.put("BST", tz);
|
|
|
|
timezones0.put("Antarctica/Mawson", tz);
|
|
|
|
timezones0.put("Asia/Colombo", tz);
|
|
|
|
timezones0.put("Asia/Dhaka", tz);
|
|
|
|
timezones0.put("Asia/Thimphu", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(6000 * 3600, "Asia/Almaty",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 0 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 0 * 3600);
|
|
|
|
timezones0.put("Asia/Almaty", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(6000 * 3600, "Asia/Novosibirsk",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("Asia/Novosibirsk", tz);
|
|
|
|
timezones0.put("Asia/Omsk", tz);
|
|
|
|
tz = new SimpleTimeZone(6500 * 3600, "Asia/Rangoon");
|
|
|
|
timezones0.put("Asia/Rangoon", tz);
|
|
|
|
timezones0.put("Indian/Cocos", tz);
|
|
|
|
tz = new SimpleTimeZone(7000 * 3600, "VST");
|
|
|
|
timezones0.put("VST", tz);
|
|
|
|
timezones0.put("Antarctica/Davis", tz);
|
|
|
|
timezones0.put("Asia/Bangkok", tz);
|
|
|
|
timezones0.put("Asia/Hovd", tz);
|
|
|
|
timezones0.put("Asia/Jakarta", tz);
|
|
|
|
timezones0.put("Asia/Phnom_Penh", tz);
|
|
|
|
timezones0.put("Asia/Saigon", tz);
|
|
|
|
timezones0.put("Asia/Vientiane", tz);
|
|
|
|
timezones0.put("Indian/Christmas", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(7000 * 3600, "Asia/Krasnoyarsk",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("Asia/Krasnoyarsk", tz);
|
|
|
|
tz = new SimpleTimeZone(8000 * 3600, "CTT");
|
|
|
|
timezones0.put("CTT", tz);
|
|
|
|
timezones0.put("Antarctica/Casey", tz);
|
|
|
|
timezones0.put("Asia/Brunei", tz);
|
|
|
|
timezones0.put("Asia/Chungking", tz);
|
|
|
|
timezones0.put("Asia/Harbin", tz);
|
|
|
|
timezones0.put("Asia/Hong_Kong", tz);
|
|
|
|
timezones0.put("Asia/Kashgar", tz);
|
|
|
|
timezones0.put("Asia/Kuala_Lumpur", tz);
|
|
|
|
timezones0.put("Asia/Kuching", tz);
|
|
|
|
timezones0.put("Asia/Macao", tz);
|
|
|
|
timezones0.put("Asia/Manila", tz);
|
|
|
|
timezones0.put("Asia/Shanghai", tz);
|
|
|
|
timezones0.put("Asia/Singapore", tz);
|
|
|
|
timezones0.put("Asia/Taipei", tz);
|
|
|
|
timezones0.put("Asia/Ujung_Pandang", tz);
|
|
|
|
timezones0.put("Asia/Ulaanbaatar", tz);
|
|
|
|
timezones0.put("Asia/Urumqi", tz);
|
|
|
|
timezones0.put("Australia/Perth", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(8000 * 3600, "Asia/Irkutsk",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("Asia/Irkutsk", tz);
|
|
|
|
tz = new SimpleTimeZone(9000 * 3600, "JST");
|
|
|
|
timezones0.put("JST", tz);
|
|
|
|
timezones0.put("Asia/Dili", tz);
|
|
|
|
timezones0.put("Asia/Jayapura", tz);
|
|
|
|
timezones0.put("Asia/Pyongyang", tz);
|
|
|
|
timezones0.put("Asia/Seoul", tz);
|
|
|
|
timezones0.put("Asia/Tokyo", tz);
|
|
|
|
timezones0.put("Pacific/Palau", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(9000 * 3600, "Asia/Yakutsk",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("Asia/Yakutsk", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(9500 * 3600, "Australia/Adelaide",
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("Australia/Adelaide", tz);
|
|
|
|
timezones0.put("Australia/Broken_Hill", tz);
|
|
|
|
tz = new SimpleTimeZone(9500 * 3600, "ACT");
|
|
|
|
timezones0.put("ACT", tz);
|
|
|
|
timezones0.put("Australia/Darwin", tz);
|
|
|
|
tz = new SimpleTimeZone(10000 * 3600, "Antarctica/DumontDUrville");
|
|
|
|
timezones0.put("Antarctica/DumontDUrville", tz);
|
|
|
|
timezones0.put("Australia/Brisbane", tz);
|
|
|
|
timezones0.put("Australia/Lindeman", tz);
|
|
|
|
timezones0.put("Pacific/Guam", tz);
|
|
|
|
timezones0.put("Pacific/Port_Moresby", tz);
|
|
|
|
timezones0.put("Pacific/Saipan", tz);
|
|
|
|
timezones0.put("Pacific/Truk", tz);
|
|
|
|
timezones0.put("Pacific/Yap", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(10000 * 3600, "Asia/Vladivostok",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("Asia/Vladivostok", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(10000 * 3600, "Australia/Hobart",
|
|
|
|
Calendar.OCTOBER, 1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("Australia/Hobart", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(10000 * 3600, "AET",
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("AET", tz);
|
|
|
|
timezones0.put("Australia/Melbourne", tz);
|
|
|
|
timezones0.put("Australia/Sydney", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(10500 * 3600, "Australia/Lord_Howe",
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2000 * 3600, 500 * 3600);
|
|
|
|
timezones0.put("Australia/Lord_Howe", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(11000 * 3600, "Asia/Magadan",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("Asia/Magadan", tz);
|
|
|
|
tz = new SimpleTimeZone(11000 * 3600, "SST");
|
|
|
|
timezones0.put("SST", tz);
|
|
|
|
timezones0.put("Pacific/Efate", tz);
|
|
|
|
timezones0.put("Pacific/Guadalcanal", tz);
|
|
|
|
timezones0.put("Pacific/Kosrae", tz);
|
|
|
|
timezones0.put("Pacific/Noumea", tz);
|
|
|
|
timezones0.put("Pacific/Ponape", tz);
|
|
|
|
tz = new SimpleTimeZone(11500 * 3600, "Pacific/Norfolk");
|
|
|
|
timezones0.put("Pacific/Norfolk", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(12000 * 3600, "NST",
|
|
|
|
Calendar.OCTOBER, 1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.MARCH, 3, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("NST", tz);
|
|
|
|
timezones0.put("Antarctica/McMurdo", tz);
|
|
|
|
timezones0.put("Antarctica/South_Pole", tz);
|
|
|
|
timezones0.put("Pacific/Auckland", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(12000 * 3600, "Asia/Anadyr",
|
|
|
|
Calendar.MARCH, -1, Calendar.SUNDAY, 2000 * 3600,
|
|
|
|
Calendar.OCTOBER, -1, Calendar.SUNDAY, 2000 * 3600);
|
|
|
|
timezones0.put("Asia/Anadyr", tz);
|
|
|
|
timezones0.put("Asia/Kamchatka", tz);
|
|
|
|
tz = new SimpleTimeZone(12000 * 3600, "Pacific/Fiji");
|
|
|
|
timezones0.put("Pacific/Fiji", tz);
|
|
|
|
timezones0.put("Pacific/Funafuti", tz);
|
|
|
|
timezones0.put("Pacific/Kwajalein", tz);
|
|
|
|
timezones0.put("Pacific/Majuro", tz);
|
|
|
|
timezones0.put("Pacific/Nauru", tz);
|
|
|
|
timezones0.put("Pacific/Tarawa", tz);
|
|
|
|
timezones0.put("Pacific/Wake", tz);
|
|
|
|
timezones0.put("Pacific/Wallis", tz);
|
|
|
|
tz = new SimpleTimeZone
|
|
|
|
(12750 * 3600, "Pacific/Chatham",
|
|
|
|
Calendar.OCTOBER, 1, Calendar.SUNDAY, 2750 * 3600,
|
|
|
|
Calendar.MARCH, 3, Calendar.SUNDAY, 2750 * 3600);
|
|
|
|
timezones0.put("Pacific/Chatham", tz);
|
|
|
|
tz = new SimpleTimeZone(13000 * 3600, "Pacific/Enderbury");
|
|
|
|
timezones0.put("Pacific/Enderbury", tz);
|
|
|
|
timezones0.put("Pacific/Tongatapu", tz);
|
|
|
|
tz = new SimpleTimeZone(14000 * 3600, "Pacific/Kiritimati");
|
|
|
|
timezones0.put("Pacific/Kiritimati", tz);
|
|
|
|
}
|
|
|
|
return timezones0;
|
2000-11-28 04:09:22 +01:00
|
|
|
}
|
|
|
|
|
2003-09-18 08:34:00 +02:00
|
|
|
|
2002-05-13 22:10:37 +02:00
|
|
|
/* This method returns us a time zone id string which is in the
|
|
|
|
form <standard zone name><GMT offset><daylight time zone name>.
|
|
|
|
The GMT offset is in seconds, except where it is evenly divisible
|
|
|
|
by 3600, then it is in hours. If the zone does not observe
|
|
|
|
daylight time, then the daylight zone name is omitted. Examples:
|
|
|
|
in Chicago, the timezone would be CST6CDT. In Indianapolis
|
|
|
|
(which does not have Daylight Savings Time) the string would
|
|
|
|
be EST5
|
|
|
|
*/
|
|
|
|
private static native String getDefaultTimeZoneId();
|
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* Gets the time zone offset, for current date, modified in case of
|
|
|
|
* daylight savings. This is the offset to add to UTC to get the local
|
|
|
|
* time.
|
|
|
|
* @param era the era of the given date
|
|
|
|
* @param year the year of the given date
|
|
|
|
* @param month the month of the given date, 0 for January.
|
|
|
|
* @param day the day of month
|
|
|
|
* @param dayOfWeek the day of week
|
|
|
|
* @param milliseconds the millis in the day (in local standard time)
|
|
|
|
* @return the time zone offset in milliseconds.
|
|
|
|
*/
|
|
|
|
public abstract int getOffset(int era, int year, int month,
|
|
|
|
int day, int dayOfWeek, int milliseconds);
|
|
|
|
|
2003-12-18 17:43:02 +01:00
|
|
|
/**
|
|
|
|
* Get the time zone offset for the specified date, modified in case of
|
|
|
|
* daylight savings. This is the offset to add to UTC to get the local
|
|
|
|
* time.
|
|
|
|
* @param date the date represented in millisecends
|
|
|
|
* since January 1, 1970 00:00:00 GMT.
|
|
|
|
* @since 1.4
|
|
|
|
*/
|
|
|
|
public int getOffset(long date)
|
|
|
|
{
|
|
|
|
return (inDaylightTime(new Date(date))
|
|
|
|
? getRawOffset() + getDSTSavings()
|
|
|
|
: getRawOffset());
|
|
|
|
}
|
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* Gets the time zone offset, ignoring daylight savings. This is
|
|
|
|
* the offset to add to UTC to get the local time.
|
|
|
|
* @return the time zone offset in milliseconds.
|
|
|
|
*/
|
|
|
|
public abstract int getRawOffset();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the time zone offset, ignoring daylight savings. This is
|
|
|
|
* the offset to add to UTC to get the local time.
|
|
|
|
* @param offsetMillis the time zone offset to GMT.
|
|
|
|
*/
|
|
|
|
public abstract void setRawOffset(int offsetMillis);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the identifier of this time zone. For instance, PST for
|
|
|
|
* Pacific Standard Time.
|
|
|
|
* @returns the ID of this time zone.
|
|
|
|
*/
|
|
|
|
public String getID()
|
1999-04-07 16:42:40 +02:00
|
|
|
{
|
2000-11-28 04:09:22 +01:00
|
|
|
return ID;
|
1999-04-07 16:42:40 +02:00
|
|
|
}
|
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* Sets the identifier of this time zone. For instance, PST for
|
|
|
|
* Pacific Standard Time.
|
|
|
|
* @param id the new time zone ID.
|
|
|
|
*/
|
|
|
|
public void setID(String id)
|
|
|
|
{
|
|
|
|
this.ID = id;
|
|
|
|
}
|
1999-04-07 16:42:40 +02:00
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* This method returns a string name of the time zone suitable
|
|
|
|
* for displaying to the user. The string returned will be the long
|
|
|
|
* description of the timezone in the current locale. The name
|
|
|
|
* displayed will assume daylight savings time is not in effect.
|
|
|
|
*
|
|
|
|
* @return The name of the time zone.
|
|
|
|
*/
|
|
|
|
public final String getDisplayName()
|
1999-04-07 16:42:40 +02:00
|
|
|
{
|
2000-11-28 04:09:22 +01:00
|
|
|
return (getDisplayName(false, LONG, Locale.getDefault()));
|
1999-04-07 16:42:40 +02:00
|
|
|
}
|
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* This method returns a string name of the time zone suitable
|
|
|
|
* for displaying to the user. The string returned will be the long
|
|
|
|
* description of the timezone in the specified locale. The name
|
|
|
|
* displayed will assume daylight savings time is not in effect.
|
|
|
|
*
|
|
|
|
* @param locale The locale for this timezone name.
|
|
|
|
*
|
|
|
|
* @return The name of the time zone.
|
|
|
|
*/
|
|
|
|
public final String getDisplayName(Locale locale)
|
1999-04-07 16:42:40 +02:00
|
|
|
{
|
2000-11-28 04:09:22 +01:00
|
|
|
return (getDisplayName(false, LONG, locale));
|
1999-04-07 16:42:40 +02:00
|
|
|
}
|
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* This method returns a string name of the time zone suitable
|
|
|
|
* for displaying to the user. The string returned will be of the
|
|
|
|
* specified type in the current locale.
|
|
|
|
*
|
|
|
|
* @param dst Whether or not daylight savings time is in effect.
|
|
|
|
* @param style <code>LONG</code> for a long name, <code>SHORT</code> for
|
|
|
|
* a short abbreviation.
|
|
|
|
*
|
|
|
|
* @return The name of the time zone.
|
|
|
|
*/
|
|
|
|
public final String getDisplayName(boolean dst, int style)
|
|
|
|
{
|
|
|
|
return (getDisplayName(dst, style, Locale.getDefault()));
|
|
|
|
}
|
1999-04-07 16:42:40 +02:00
|
|
|
|
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* This method returns a string name of the time zone suitable
|
|
|
|
* for displaying to the user. The string returned will be of the
|
|
|
|
* specified type in the specified locale.
|
|
|
|
*
|
|
|
|
* @param dst Whether or not daylight savings time is in effect.
|
|
|
|
* @param style <code>LONG</code> for a long name, <code>SHORT</code> for
|
|
|
|
* a short abbreviation.
|
|
|
|
* @param locale The locale for this timezone name.
|
|
|
|
*
|
|
|
|
* @return The name of the time zone.
|
|
|
|
*/
|
|
|
|
public String getDisplayName(boolean dst, int style, Locale locale)
|
1999-04-07 16:42:40 +02:00
|
|
|
{
|
2000-11-28 04:09:22 +01:00
|
|
|
DateFormatSymbols dfs;
|
|
|
|
try
|
1999-09-24 21:12:23 +02:00
|
|
|
{
|
2000-11-28 04:09:22 +01:00
|
|
|
dfs = new DateFormatSymbols(locale);
|
1999-09-24 21:12:23 +02:00
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
// The format of the value returned is defined by us.
|
|
|
|
String[][]zoneinfo = dfs.getZoneStrings();
|
|
|
|
for (int i = 0; i < zoneinfo.length; i++)
|
|
|
|
{
|
|
|
|
if (zoneinfo[i][0].equals(getID()))
|
|
|
|
{
|
|
|
|
if (!dst)
|
|
|
|
{
|
|
|
|
if (style == SHORT)
|
|
|
|
return (zoneinfo[i][2]);
|
|
|
|
else
|
|
|
|
return (zoneinfo[i][1]);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if (style == SHORT)
|
|
|
|
return (zoneinfo[i][4]);
|
|
|
|
else
|
|
|
|
return (zoneinfo[i][3]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (MissingResourceException e)
|
1999-09-24 21:12:23 +02:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
return getDefaultDisplayName(dst);
|
1999-04-07 16:42:40 +02:00
|
|
|
}
|
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
private String getDefaultDisplayName(boolean dst)
|
1999-09-24 21:12:23 +02:00
|
|
|
{
|
2000-11-28 04:09:22 +01:00
|
|
|
int offset = getRawOffset();
|
|
|
|
if (dst && this instanceof SimpleTimeZone)
|
|
|
|
{
|
|
|
|
// ugly, but this is a design failure of the API:
|
|
|
|
// getDisplayName takes a dst parameter even though
|
|
|
|
// TimeZone knows nothing about daylight saving offsets.
|
|
|
|
offset += ((SimpleTimeZone) this).getDSTSavings();
|
|
|
|
}
|
|
|
|
|
|
|
|
StringBuffer sb = new StringBuffer(9);
|
|
|
|
sb.append("GMT");
|
|
|
|
sb.append(offset >= 0 ? '+' : '-');
|
|
|
|
|
|
|
|
offset = Math.abs(offset) / (1000 * 60);
|
|
|
|
int hours = offset / 60;
|
|
|
|
int minutes = offset % 60;
|
|
|
|
|
2000-12-28 06:55:56 +01:00
|
|
|
sb.append((char) ('0' + hours / 10)).append((char) ('0' + hours % 10));
|
|
|
|
sb.append(':');
|
|
|
|
sb.append((char) ('0' + minutes / 10)).append((char) ('0' + minutes % 10));
|
2000-11-28 04:09:22 +01:00
|
|
|
return sb.toString();
|
1999-04-07 16:42:40 +02:00
|
|
|
}
|
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* Returns true, if this time zone uses Daylight Savings Time.
|
|
|
|
*/
|
|
|
|
public abstract boolean useDaylightTime();
|
1999-09-24 21:12:23 +02:00
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* Returns true, if the given date is in Daylight Savings Time in this
|
|
|
|
* time zone.
|
|
|
|
* @param date the given Date.
|
|
|
|
*/
|
|
|
|
public abstract boolean inDaylightTime(Date date);
|
|
|
|
|
2002-09-25 23:10:21 +02:00
|
|
|
/**
|
|
|
|
* Gets the daylight savings offset. This is a positive offset in
|
|
|
|
* milliseconds with respect to standard time. Typically this
|
|
|
|
* is one hour, but for some time zones this may be half an our.
|
|
|
|
* <p>The default implementation returns 3600000 milliseconds
|
|
|
|
* (one hour) if the time zone uses daylight savings time
|
|
|
|
* (as specified by {@link #useDaylightTime()}), otherwise
|
|
|
|
* it returns 0.
|
|
|
|
* @return the daylight savings offset in milliseconds.
|
|
|
|
* @since 1.4
|
|
|
|
*/
|
|
|
|
public int getDSTSavings ()
|
|
|
|
{
|
|
|
|
return useDaylightTime () ? 3600000 : 0;
|
|
|
|
}
|
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* Gets the TimeZone for the given ID.
|
|
|
|
* @param ID the time zone identifier.
|
|
|
|
* @return The time zone for the identifier or GMT, if no such time
|
|
|
|
* zone exists.
|
|
|
|
*/
|
|
|
|
// FIXME: XXX: JCL indicates this and other methods are synchronized.
|
|
|
|
public static TimeZone getTimeZone(String ID)
|
|
|
|
{
|
|
|
|
// First check timezones hash
|
2003-09-18 08:34:00 +02:00
|
|
|
TimeZone tz = (TimeZone) timezones().get(ID);
|
2000-11-28 04:09:22 +01:00
|
|
|
if (tz != null)
|
1999-09-24 21:12:23 +02:00
|
|
|
{
|
2000-11-28 04:09:22 +01:00
|
|
|
if (tz.getID().equals(ID))
|
|
|
|
return tz;
|
|
|
|
|
|
|
|
// We always return a timezone with the requested ID.
|
|
|
|
// This is the same behaviour as with JDK1.2.
|
|
|
|
tz = (TimeZone) tz.clone();
|
|
|
|
tz.setID(ID);
|
|
|
|
// We also save the alias, so that we return the same
|
|
|
|
// object again if getTimeZone is called with the same
|
|
|
|
// alias.
|
2003-09-18 08:34:00 +02:00
|
|
|
timezones().put(ID, tz);
|
2000-11-28 04:09:22 +01:00
|
|
|
return tz;
|
1999-09-24 21:12:23 +02:00
|
|
|
}
|
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
// See if the ID is really a GMT offset form.
|
|
|
|
// Note that GMT is in the table so we know it is different.
|
|
|
|
if (ID.startsWith("GMT"))
|
1999-09-24 21:12:23 +02:00
|
|
|
{
|
2000-11-28 04:09:22 +01:00
|
|
|
int pos = 3;
|
|
|
|
int offset_direction = 1;
|
1999-09-24 21:12:23 +02:00
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
if (ID.charAt(pos) == '-')
|
|
|
|
{
|
|
|
|
offset_direction = -1;
|
|
|
|
pos++;
|
|
|
|
}
|
|
|
|
else if (ID.charAt(pos) == '+')
|
|
|
|
{
|
|
|
|
pos++;
|
|
|
|
}
|
1999-04-07 16:42:40 +02:00
|
|
|
|
|
|
|
try
|
|
|
|
{
|
2000-11-28 04:09:22 +01:00
|
|
|
int hour, minute;
|
|
|
|
|
|
|
|
String offset_str = ID.substring(pos);
|
|
|
|
int idx = offset_str.indexOf(":");
|
|
|
|
if (idx != -1)
|
|
|
|
{
|
|
|
|
hour = Integer.parseInt(offset_str.substring(0, idx));
|
|
|
|
minute = Integer.parseInt(offset_str.substring(idx + 1));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
int offset_length = offset_str.length();
|
|
|
|
if (offset_length <= 2)
|
|
|
|
{
|
|
|
|
// Only hour
|
|
|
|
hour = Integer.parseInt(offset_str);
|
|
|
|
minute = 0;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// hour and minute, not separated by colon
|
|
|
|
hour = Integer.parseInt
|
|
|
|
(offset_str.substring(0, offset_length - 2));
|
|
|
|
minute = Integer.parseInt
|
|
|
|
(offset_str.substring(offset_length - 2));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return new SimpleTimeZone((hour * (60 * 60 * 1000) +
|
|
|
|
minute * (60 * 1000))
|
|
|
|
* offset_direction, ID);
|
1999-04-07 16:42:40 +02:00
|
|
|
}
|
2000-11-28 04:09:22 +01:00
|
|
|
catch (NumberFormatException e)
|
1999-04-07 16:42:40 +02:00
|
|
|
{
|
|
|
|
}
|
|
|
|
}
|
2000-11-28 04:09:22 +01:00
|
|
|
|
|
|
|
// Finally, return GMT per spec
|
|
|
|
return getTimeZone("GMT");
|
1999-04-07 16:42:40 +02:00
|
|
|
}
|
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* Gets the available IDs according to the given time zone
|
|
|
|
* offset.
|
|
|
|
* @param rawOffset the given time zone GMT offset.
|
|
|
|
* @return An array of IDs, where the time zone has the specified GMT
|
|
|
|
* offset. For example <code>{"Phoenix", "Denver"}</code>, since both have
|
|
|
|
* GMT-07:00, but differ in daylight savings behaviour.
|
|
|
|
*/
|
|
|
|
public static String[] getAvailableIDs(int rawOffset)
|
1999-04-07 16:42:40 +02:00
|
|
|
{
|
2000-11-28 04:09:22 +01:00
|
|
|
int count = 0;
|
2003-09-18 08:34:00 +02:00
|
|
|
Iterator iter = timezones().entrySet().iterator();
|
2000-11-28 04:09:22 +01:00
|
|
|
while (iter.hasNext())
|
|
|
|
{
|
|
|
|
// Don't iterate the values, since we want to count
|
|
|
|
// doubled values (aliases)
|
|
|
|
Map.Entry entry = (Map.Entry) iter.next();
|
|
|
|
if (((TimeZone) entry.getValue()).getRawOffset() == rawOffset)
|
|
|
|
count++;
|
|
|
|
}
|
|
|
|
|
|
|
|
String[] ids = new String[count];
|
|
|
|
count = 0;
|
2003-09-18 08:34:00 +02:00
|
|
|
iter = timezones().entrySet().iterator();
|
2000-11-28 04:09:22 +01:00
|
|
|
while (iter.hasNext())
|
|
|
|
{
|
|
|
|
Map.Entry entry = (Map.Entry) iter.next();
|
|
|
|
if (((TimeZone) entry.getValue()).getRawOffset() == rawOffset)
|
|
|
|
ids[count++] = (String) entry.getKey();
|
|
|
|
}
|
|
|
|
return ids;
|
1999-04-07 16:42:40 +02:00
|
|
|
}
|
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* Gets all available IDs.
|
|
|
|
* @return An array of all supported IDs.
|
|
|
|
*/
|
|
|
|
public static String[] getAvailableIDs()
|
|
|
|
{
|
|
|
|
return (String[])
|
2003-09-18 08:34:00 +02:00
|
|
|
timezones().keySet().toArray(new String[timezones().size()]);
|
2000-11-28 04:09:22 +01:00
|
|
|
}
|
1999-04-07 16:42:40 +02:00
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* Returns the time zone under which the host is running. This
|
|
|
|
* can be changed with setDefault.
|
|
|
|
* @return the time zone for this host.
|
|
|
|
* @see #setDefault
|
|
|
|
*/
|
|
|
|
public static TimeZone getDefault()
|
1999-04-07 16:42:40 +02:00
|
|
|
{
|
2003-09-18 08:34:00 +02:00
|
|
|
return defaultZone();
|
1999-04-07 16:42:40 +02:00
|
|
|
}
|
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
public static void setDefault(TimeZone zone)
|
2000-02-03 19:26:51 +01:00
|
|
|
{
|
2003-09-18 08:34:00 +02:00
|
|
|
defaultZone0 = zone;
|
2000-02-03 19:26:51 +01:00
|
|
|
}
|
1999-09-24 21:12:23 +02:00
|
|
|
|
2000-11-28 04:09:22 +01:00
|
|
|
/**
|
|
|
|
* Test if the other time zone uses the same rule and only
|
|
|
|
* possibly differs in ID. This implementation for this particular
|
|
|
|
* class will return true if the raw offsets are identical. Subclasses
|
|
|
|
* should override this method if they use daylight savings.
|
|
|
|
* @return true if this zone has the same raw offset
|
|
|
|
*/
|
|
|
|
public boolean hasSameRules(TimeZone other)
|
1999-09-24 21:12:23 +02:00
|
|
|
{
|
2000-11-28 04:09:22 +01:00
|
|
|
return other.getRawOffset() == getRawOffset();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a clone of this object. I can't imagine, why this is
|
|
|
|
* useful for a time zone.
|
|
|
|
*/
|
|
|
|
public Object clone()
|
1999-09-24 21:12:23 +02:00
|
|
|
{
|
2000-11-28 04:09:22 +01:00
|
|
|
try
|
|
|
|
{
|
|
|
|
return super.clone();
|
|
|
|
}
|
|
|
|
catch (CloneNotSupportedException ex)
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
1999-04-07 16:42:40 +02:00
|
|
|
}
|