mirror of
https://github.com/php/php-src.git
synced 2026-04-16 20:41:18 +02:00
Julian days < 347998 denote invalid Jewish calendar dates, so cal_from_jd($jd, CAL_JEWISH) and jdmonthname($jd, CAL_MONTH_JEWISH) should actually fail. For BC we don't yet let them though, but we fix the OOB read that happens in this case, and we also adjust cal_from_jd()'s return value to have empty strings for "abbrevdayname" and "dayname" instead of "Sun"/ "Sunday" and NULL for "dow" instead of 0, which doesn't make any sense.
33 lines
571 B
PHP
33 lines
571 B
PHP
--TEST--
|
|
Bug #71894 (AddressSanitizer: global-buffer-overflow in zif_cal_from_jd)
|
|
--SKIPIF--
|
|
<?php
|
|
if (!extension_loaded('calendar')) die('skip ext/calendar required');
|
|
?>
|
|
--FILE--
|
|
<?php
|
|
var_dump(cal_from_jd(347997, CAL_JEWISH));
|
|
var_dump(jdmonthname(347997,CAL_MONTH_JEWISH));?>
|
|
--EXPECT--
|
|
array(9) {
|
|
["date"]=>
|
|
string(5) "0/0/0"
|
|
["month"]=>
|
|
int(0)
|
|
["day"]=>
|
|
int(0)
|
|
["year"]=>
|
|
int(0)
|
|
["dow"]=>
|
|
NULL
|
|
["abbrevdayname"]=>
|
|
string(0) ""
|
|
["dayname"]=>
|
|
string(0) ""
|
|
["abbrevmonth"]=>
|
|
string(0) ""
|
|
["monthname"]=>
|
|
string(0) ""
|
|
}
|
|
string(0) ""
|