mirror of
https://github.com/php/php-src.git
synced 2024-11-27 03:44:07 +08:00
Merge branch 'PHP-8.1' into PHP-8.2
* PHP-8.1: Fix GH-9905: constant() behaves inconsistent when class is undefined
This commit is contained in:
commit
4b1feda574
4
NEWS
4
NEWS
@ -2,6 +2,10 @@ PHP NEWS
|
||||
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||
?? ??? ????, PHP 8.2.1
|
||||
|
||||
- Core:
|
||||
. Fixed bug GH-9905 (constant() behaves inconsistent when class is undefined).
|
||||
(cmb)
|
||||
|
||||
27 Nov 2022, PHP 8.2.0
|
||||
|
||||
- CLI:
|
||||
|
@ -525,7 +525,7 @@ PHP_FUNCTION(constant)
|
||||
ZEND_PARSE_PARAMETERS_END();
|
||||
|
||||
scope = zend_get_executed_scope();
|
||||
c = zend_get_constant_ex(const_name, scope, 0);
|
||||
c = zend_get_constant_ex(const_name, scope, ZEND_FETCH_CLASS_EXCEPTION);
|
||||
if (!c) {
|
||||
RETURN_THROWS();
|
||||
}
|
||||
|
12
ext/standard/tests/general_functions/gh9905.phpt
Normal file
12
ext/standard/tests/general_functions/gh9905.phpt
Normal file
@ -0,0 +1,12 @@
|
||||
--TEST--
|
||||
GH-9905 (constant() behaves inconsistent when class is undefined)
|
||||
--FILE--
|
||||
<?php
|
||||
try {
|
||||
\constant("\NonExistantClass::non_existant_constant");
|
||||
} catch (\Throwable|\Error|\Exception $e) {
|
||||
echo($e->getMessage());
|
||||
}
|
||||
?>
|
||||
--EXPECT--
|
||||
Class "NonExistantClass" not found
|
@ -21,5 +21,4 @@ try {
|
||||
?>
|
||||
--EXPECTF--
|
||||
define(): Argument #1 ($constant_name) cannot be a class constant
|
||||
|
||||
Fatal error: Class "" not found in %s on line %d
|
||||
Class "" not found
|
||||
|
Loading…
Reference in New Issue
Block a user