]> granicus.if.org Git - php/commitdiff
- Fixed bug #49585 (date_format buffer not long enough for >4 digit years).
authorDerick Rethans <derick@php.net>
Wed, 10 Feb 2010 16:55:40 +0000 (16:55 +0000)
committerDerick Rethans <derick@php.net>
Wed, 10 Feb 2010 16:55:40 +0000 (16:55 +0000)
#- Was already partly fixed with my previous commit.

NEWS
ext/date/php_date.c
ext/date/tests/bug49585.phpt [new file with mode: 0644]

diff --git a/NEWS b/NEWS
index a7b28a220e4f82620dba3701865062733172ebae..63ae97d2726fa170544d0320f02f2e3c6af64c88 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -27,6 +27,8 @@ PHP                                                                        NEWS
   (Jani)
 - Fixed bug #50940 (Custom content-length set incorrectly in Apache SAPIs).
   (Brian France, Rasmus)
+- Fixed bug #50930 (Wrong date by php_date.c patch with ancient gcc/glibc
+  versions). (Derick)
 - Fixed bug #50907 (X-PHP-Originating-Script adding two new lines in *NIX).
   (Ilia)
 - Fixed bug #50859 (build fails with openssl 1.0 due to md2 deprecation).   
@@ -59,6 +61,8 @@ PHP                                                                        NEWS
 - Fixed bug #50576 (XML_OPTION_SKIP_TAGSTART option has no effect). (Pierrick)
 - Fixed bug #50416 (PROCEDURE db.myproc can't return a result set in the given
   context). (Andrey)
+- Fixed bug #49585 (date_format buffer not long enough for >4 digit years).
+  (Derick, Adam)
 - Fixed bug #49560 (oci8: using LOBs causes slow PHP shutdown). (Oracle Corp.)
 - Fixed bug #49463 (setAttributeNS fails setting default namespace). (Rob)
 - Fixed bug #48811 (Directives in PATH section do not get applied to
index 6626ad62f804826305c57de6e17feda1aa12a5d6..d48f32f12c0f9af0681dc0ec5b2b28edfe888828 100644 (file)
@@ -1120,7 +1120,7 @@ static char *date_format(char *format, int format_len, timelib_time *t, int loca
                        case 'Z': length = slprintf(buffer, 32, "%d", localtime ? offset->offset : 0); break;
 
                        /* full date/time */
-                       case 'c': length = slprintf(buffer, 32, "%04d-%02d-%02dT%02d:%02d:%02d%c%02d:%02d",
+                       case 'c': length = slprintf(buffer, 96, "%04d-%02d-%02dT%02d:%02d:%02d%c%02d:%02d",
                                                                        (int) t->y, (int) t->m, (int) t->d,
                                                                                        (int) t->h, (int) t->i, (int) t->s,
                                                                                        localtime ? ((offset->offset < 0) ? '-' : '+') : '+',
diff --git a/ext/date/tests/bug49585.phpt b/ext/date/tests/bug49585.phpt
new file mode 100644 (file)
index 0000000..2ec1424
--- /dev/null
@@ -0,0 +1,16 @@
+--TEST--
+Bug #49585 (date_format buffer not long enough for >4 digit years)
+--FILE--
+<?php
+date_default_timezone_set('UTC');
+
+$date = new DateTime('-1500-01-01');
+var_dump($date->format('r'));
+
+$date->setDate(-2147483648, 1, 1);
+var_dump($date->format('r'));
+var_dump($date->format('c'));
+--EXPECT--
+string(32) "Sat, 01 Jan -1500 00:00:00 +0000"
+string(42) "Unknown, 01 Jan -2147483648 00:00:00 +0000"
+string(32) "-2147483648-01-01T00:00:00+00:00"