c2c-oerpscenario team mailing list archive
-
c2c-oerpscenario team
-
Mailing list archive
-
Message #20130
[Bug 742439] Re: Timezone as three-letter-acronym is ambigous, should be ISO standardized
It may be useful to also have
time.daylight: Nonzero if a DST timezone is defined.
and
time.altzone: The offset of the local DST timezone, in seconds west of UTC, if one is defined. This is negative if the local DST timezone is east of UTC (as in Western Europe, including the UK). Only use this if daylight is nonzero.
--
You received this bug notification because you are a member of C2C
OERPScenario, which is subscribed to the OpenERP Project Group.
https://bugs.launchpad.net/bugs/742439
Title:
Timezone as three-letter-acronym is ambigous, should be ISO
standardized
Status in OpenERP Server:
New
Bug description:
We encountered a bug while writing Date via xmlrpc from Java to OpenERP, and found that it looks like https://bugs.launchpad.net/openobject-server/+bug/397294 is our problem.
There, it's suggested to use String instead of DateTime. I found the DEFAULT_SERVER_DATETIME_FORMAT constant in server/tools/misc.py, and I use a request to common/timezone_get to get the timezone.
But that is text, like "CET".
I looked for getting a numeric timezone for easier calculations, or at list of timezone identifiers, and found the following information:
The traditional alphabetical time zone names and their abbreviations are not standardized. There are over 300 of them, with many time zones having multiple names. Also, the abbreviations do not always have 3 letters.
ISO-8601, the norm for date and time zone formats, does not use names and abbrevations at all. The ISO format indicates the geographical position by numerical combinations.
Time zone are written as offset from UTC in the format ±[hh]:[mm], ±[hh][mm], or ±[hh]. So if the time being described is one hour ahead of UTC (such as the time in Berlin during the winter), the zone designator would be "+01:00", "+0100", or simply "+01".
(Java Doc:) For compatibility with JDK 1.1.x, some other three-letter
time zone IDs (such as "PST", "CTT", "AST") are also supported.
However, their use is deprecated because the same abbreviation is
often used for multiple time zones (for example, "CST" could be U.S.
"Central Standard Time" and "China Standard Time"), and the Java
platform can then only recognize one of them.
A xmlrpc call to common/timezone_get returns pythons time.tzname[0], the name of the local non-DST timezone.
As noted above, this is not standardized and ambigous.
I propose adding (for backward compatibility) a second return value, pythons time.timezone: The offset of the local (non-DST) timezone, in seconds west of UTC (negative in most of Western Europe, positive in the US, zero in the UK).
This is easily compatible to ISO-8601 syntax and can directly be used for calculations.
References