]> granicus.if.org Git - php/commitdiff
- MFH: Fixed a bug in formatting timestamps when DST is active in the default
authorDerick Rethans <derick@php.net>
Mon, 31 Mar 2008 09:12:15 +0000 (09:12 +0000)
committerDerick Rethans <derick@php.net>
Mon, 31 Mar 2008 09:12:15 +0000 (09:12 +0000)
  timezone.

ext/date/php_date.c
ext/date/tests/timestamp-in-dst.phpt [new file with mode: 0644]

index 031cf1cf6be000d2c398493cf50d6838aa42157b..f1a72e1f986d9ff402840ec2a0c7aea55eaa26d2 100644 (file)
@@ -746,9 +746,9 @@ static char *date_format(char *format, int format_len, timelib_time *t, int loca
                        offset->abbr = strdup(t->tz_abbr);
                } else if (t->zone_type == TIMELIB_ZONETYPE_OFFSET) {
                        offset = timelib_time_offset_ctor();
-                       offset->offset = (t->z - (t->dst * 60)) * -60;
+                       offset->offset = (t->z) * -60;
                        offset->leap_secs = 0;
-                       offset->is_dst = t->dst;
+                       offset->is_dst = 0;
                        offset->abbr = malloc(9); /* GMT±xxxx\0 */
                        snprintf(offset->abbr, 9, "GMT%c%02d%02d", 
                                                  localtime ? ((offset->offset < 0) ? '-' : '+') : '+',
diff --git a/ext/date/tests/timestamp-in-dst.phpt b/ext/date/tests/timestamp-in-dst.phpt
new file mode 100644 (file)
index 0000000..5b66351
--- /dev/null
@@ -0,0 +1,11 @@
+--TEST--
+Format timestamp in DST test
+--INI--
+date.timezone=CEST
+--FILE--
+<?php
+error_reporting(E_ALL); // hide e_strict warning about timezones
+var_dump( date_create( '@1202996091' )->format( 'c' ) );
+?>
+--EXPECT--
+string(25) "2008-02-14T13:34:51+00:00"