ID: 42842 User updated by: giewont at gmail dot com Reported By: giewont at gmail dot com Status: Suspended Bug Type: Date/time related Operating System: Windows NT 5.1 build 2600 PHP Version: 5.2.4 New Comment:
OK, but what do you need to store? The dst always changes on last saturday of march and october, that's all you have to know. So please tell me what is longer than signed int and have to be stored in timezone's database to support dst change after 2038? And if you can, tell me please what is stored in this database (or tell me where can i read about it?). Previous Comments: ------------------------------------------------------------------------ [2007-10-20 15:04:49] [EMAIL PROTECTED] This is not something I can fix - the timezone database simply doesn't have the resolution to store anything outside of the signed integer range for now. Luckily they are working on extending this - if that makes it into the database, I can fix this. ------------------------------------------------------------------------ [2007-10-04 09:59:13] giewont at gmail dot com OK, but Y2038 problem is not the same as daylight saving time whith doesn't work after 2038. DateTime Object is supposed to by a wrapper around 64bit int and it should work after 2038. And it work, because i can set dates after 2038 for example 2040, but the bug is that when i set timezone to 'Europe/Warsaw' and the date is set to summer eg. 05.May the GMT offset should be +2h not +1h. the daylight saving time works properly to 2038, and it should work after 2038 when i use DateTime. the Y2038 problem touches mktime but shouldnt cause any errors in DateTime ------------------------------------------------------------------------ [2007-10-04 03:41:43] judas dot iscariote at gmail dot com Please read http://en.wikipedia.org/wiki/Year_2038_problem to know the cause. ------------------------------------------------------------------------ [2007-10-03 16:01:14] giewont at gmail dot com Description: ------------ When I create DateTime object using UTC and then switch to timezone with DST eg. 'Europe/Warsaw' and i set Year to any after 2038 the DST doesn't work. like below: in may Warsaw is in GMT+2 time zone so when i set UTC time to 12:00:00 time in Warsaw should be 02:00:00 (14:00:00) Reproduce code: --------------- date_default_timezone_set('Europe/Warsaw'); $gmt = timezone_open('UTC'); $eu = timezone_open('Europe/Warsaw'); $date = new DateTime('2040-05-05 12:00:00', $gmt); echo $date->format('d-m-Y h:i:s') . '(' . $date->getTimezone()->getName() . ')<br>'; $date->setTimezone($eu); echo $date->format('d-m-Y h:i:s') . '(' . $date->getTimezone()->getName() . ')<br>'; $date->setTimezone($gmt); $date = new DateTime('2000-05-05 12:00:00', $gmt); echo $date->format('d-m-Y h:i:s') . '(' . $date->getTimezone()->getName() . ')<br>'; $date->setTimezone($eu); echo $date->format('d-m-Y h:i:s') . '(' . $date->getTimezone()->getName() . ')<br>'; $date->setTimezone($gmt); Expected result: ---------------- 05-05-2040 12:00:00(UTC) 05-05-2040 02:00:00(Europe/Warsaw) 05-05-2000 12:00:00(UTC) 05-05-2000 02:00:00(Europe/Warsaw) Actual result: -------------- 05-05-2040 12:00:00(UTC) 05-05-2040 01:00:00(Europe/Warsaw) 05-05-2000 12:00:00(UTC) 05-05-2000 02:00:00(Europe/Warsaw) ------------------------------------------------------------------------ -- Edit this bug report at http://bugs.php.net/?id=42842&edit=1