mirror of
https://github.com/php/php-src.git
synced 2025-08-16 05:58:45 +02:00
Merge branch 'PHP-7.4' into PHP-8.0
* PHP-7.4: Fix #79908: json_encode encodes negative zero as int
This commit is contained in:
commit
1ba190bdb3
3 changed files with 17 additions and 1 deletions
3
NEWS
3
NEWS
|
@ -23,6 +23,9 @@ PHP NEWS
|
|||
. Fixed bug #68471 (IntlDateFormatter fails for "GMT+00:00" timezone). (cmb)
|
||||
. Fixed bug #74264 (grapheme_strrpos() broken for negative offsets). (cmb)
|
||||
|
||||
- JSON:
|
||||
. Fixed bug #79908 (json_encode encodes negative zero as int). (cmb)
|
||||
|
||||
- OpenSSL:
|
||||
. Fixed bug #52093 (openssl_csr_sign truncates $serial). (cmb)
|
||||
|
||||
|
|
|
@ -102,7 +102,8 @@ static inline void php_json_encode_double(smart_str *buf, double d, int options)
|
|||
|
||||
php_gcvt(d, (int)PG(serialize_precision), '.', 'e', num);
|
||||
len = strlen(num);
|
||||
if (options & PHP_JSON_PRESERVE_ZERO_FRACTION && strchr(num, '.') == NULL && len < PHP_DOUBLE_MAX_LENGTH - 2) {
|
||||
if ((options & PHP_JSON_PRESERVE_ZERO_FRACTION && strchr(num, '.') == NULL && len < PHP_DOUBLE_MAX_LENGTH - 2)
|
||||
|| (UNEXPECTED(len == 2 && num[0] == '-' && num[1] == '0'))) {
|
||||
num[len++] = '.';
|
||||
num[len++] = '0';
|
||||
num[len] = '\0';
|
||||
|
|
12
ext/json/tests/bug79908.phpt
Normal file
12
ext/json/tests/bug79908.phpt
Normal file
|
@ -0,0 +1,12 @@
|
|||
--TEST--
|
||||
Bug #79908 (json_encode encodes negative zero as int)
|
||||
--SKIPIF--
|
||||
<?php
|
||||
if (!extension_loaded('json')) die("skip json extension not available");
|
||||
?>
|
||||
--FILE--
|
||||
<?php
|
||||
var_dump(json_encode(-0.));
|
||||
?>
|
||||
--EXPECT--
|
||||
string(4) "-0.0"
|
Loading…
Add table
Add a link
Reference in a new issue