]> granicus.if.org Git - php/commitdiff
Fix bug #71525
authorSean DuBois <sean@siobud.com>
Thu, 4 Feb 2016 21:13:57 +0000 (15:13 -0600)
committerAnatol Belski <ab@php.net>
Mon, 15 Feb 2016 07:19:07 +0000 (08:19 +0100)
timelib_time->timelib_rel_time is mutated by date_modify, and because it is never zero'ed out
it latters causes other date operations to fail (like date_date_set)

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

index 2c548ae6f472677d165545ac5ac474baf9a05ce7..2fe78a0e69fbd8c08e24cfeaf75887a847486344 100644 (file)
@@ -3054,6 +3054,7 @@ static int php_date_modify(zval *object, char *modify, size_t modify_len) /* {{{
        timelib_update_ts(dateobj->time, NULL);
        timelib_update_from_sse(dateobj->time);
        dateobj->time->have_relative = 0;
+       memset(&dateobj->time->relative, 0, sizeof(dateobj->time->relative));
 
        return 1;
 } /* }}} */
diff --git a/ext/date/tests/bug71525.phpt b/ext/date/tests/bug71525.phpt
new file mode 100644 (file)
index 0000000..dadf926
--- /dev/null
@@ -0,0 +1,18 @@
+--TEST--
+Bug #71525 (Calls to date_modify will mutate timelib_rel_time, causing date_date_set issues)
+--FILE--
+<?php
+$date = new DateTime('2011-12-25 00:00:00');
+$date->modify('first day of next month');
+$date->setDate('2012', '1', '29');
+var_dump($date);
+
+--EXPECTF--
+object(DateTime)#%d (3) {
+  ["date"]=>
+  string(26) "2012-01-29 00:00:00.000000"
+  ["timezone_type"]=>
+  int(3)
+  ["timezone"]=>
+  string(3) "UTC"
+}