mirror of
https://github.com/php/php-src.git
synced 2025-08-15 13:38:49 +02: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 changed files with 18 additions and 3 deletions
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…
Add table
Add a link
Reference in a new issue