mirror of
https://github.com/php/php-src.git
synced 2026-03-24 00:02:20 +01:00
Merge branch 'PHP-8.4'
* PHP-8.4: Fix GH-18695: float numbers zero fraction is now preserved in zend_ast_export() (#18699)
This commit is contained in:
2
NEWS
2
NEWS
@@ -53,6 +53,8 @@ PHP NEWS
|
||||
evaluation) and GH-18464 (Recursion protection for deprecation constants not
|
||||
released on bailout). (DanielEScherzer and ilutov)
|
||||
. Fixed AST printing for immediately invoked Closure. (Dmitrii Derepko)
|
||||
. Fixed GH-18695 (zend_ast_export() - float number is not preserved).
|
||||
(Oleg Efimov)
|
||||
|
||||
- Curl:
|
||||
. Added curl_multi_get_handles(). (timwolla)
|
||||
|
||||
26
Zend/tests/ast/ast_serialize_floats.phpt
Normal file
26
Zend/tests/ast/ast_serialize_floats.phpt
Normal file
@@ -0,0 +1,26 @@
|
||||
--TEST--
|
||||
Serialization of floats are correct
|
||||
--INI--
|
||||
zend.assertions=1
|
||||
--FILE--
|
||||
<?php
|
||||
try {
|
||||
assert(!is_float(0.0));
|
||||
} catch (AssertionError $e) {
|
||||
echo 'assert(): ', $e->getMessage(), ' failed', PHP_EOL;
|
||||
}
|
||||
try {
|
||||
assert(!is_float(1.1));
|
||||
} catch (AssertionError $e) {
|
||||
echo 'assert(): ', $e->getMessage(), ' failed', PHP_EOL;
|
||||
}
|
||||
try {
|
||||
assert(!is_float(1234.5678));
|
||||
} catch (AssertionError $e) {
|
||||
echo 'assert(): ', $e->getMessage(), ' failed', PHP_EOL;
|
||||
}
|
||||
?>
|
||||
--EXPECT--
|
||||
assert(): assert(!is_float(0.0)) failed
|
||||
assert(): assert(!is_float(1.1)) failed
|
||||
assert(): assert(!is_float(1234.5678)) failed
|
||||
@@ -1820,7 +1820,7 @@ static ZEND_COLD void zend_ast_export_zval(smart_str *str, zval *zv, int priorit
|
||||
break;
|
||||
case IS_DOUBLE:
|
||||
smart_str_append_double(
|
||||
str, Z_DVAL_P(zv), (int) EG(precision), /* zero_fraction */ false);
|
||||
str, Z_DVAL_P(zv), (int) EG(precision), /* zero_fraction */ true);
|
||||
break;
|
||||
case IS_STRING:
|
||||
smart_str_appendc(str, '\'');
|
||||
|
||||
Reference in New Issue
Block a user