mirror of
https://github.com/php/php-src.git
synced 2025-08-15 21:48:51 +02:00
Set UNION bit for internal class union return type
Fixes assertion failure reported in: https://github.com/php/php-src/pull/7115#issuecomment-882580767
This commit is contained in:
parent
a4db74364d
commit
084d49a262
2 changed files with 26 additions and 18 deletions
|
@ -2806,6 +2806,7 @@ ZEND_API zend_result zend_register_functions(zend_class_entry *scope, const zend
|
|||
zend_type_list *list = malloc(ZEND_TYPE_LIST_SIZE(num_types));
|
||||
list->num_types = num_types;
|
||||
ZEND_TYPE_SET_LIST(new_arg_info[i].type, list);
|
||||
ZEND_TYPE_FULL_MASK(new_arg_info[i].type) |= _ZEND_TYPE_UNION_BIT;
|
||||
|
||||
const char *start = class_name;
|
||||
uint32_t j = 0;
|
||||
|
|
|
@ -12,29 +12,24 @@ class MyDateTimeZone extends DateTimeZone
|
|||
}
|
||||
}
|
||||
|
||||
$methodInfo = new ReflectionMethod(DateTimeZone::class, 'listIdentifiers');
|
||||
|
||||
var_dump($methodInfo->hasReturnType());
|
||||
var_dump($methodInfo->hasTentativeReturnType());
|
||||
var_dump($methodInfo->getReturnType());
|
||||
var_dump((string) $methodInfo->getTentativeReturnType());
|
||||
var_dump((string) $methodInfo);
|
||||
echo "\n";
|
||||
|
||||
$methodInfo = new ReflectionMethod(MyDateTimeZone::class, 'listIdentifiers');
|
||||
|
||||
function printInfo(ReflectionMethod $methodInfo) {
|
||||
var_dump($methodInfo->hasReturnType());
|
||||
var_dump($methodInfo->hasTentativeReturnType());
|
||||
var_dump((string) $methodInfo->getReturnType());
|
||||
var_dump($methodInfo->getTentativeReturnType());
|
||||
var_dump((string) $methodInfo->getTentativeReturnType());
|
||||
var_dump((string) $methodInfo);
|
||||
echo "\n";
|
||||
}
|
||||
|
||||
printInfo(new ReflectionMethod(DateTimeZone::class, 'listIdentifiers'));
|
||||
printInfo(new ReflectionMethod(MyDateTimeZone::class, 'listIdentifiers'));
|
||||
printInfo(new ReflectionMethod(FileSystemIterator::class, 'current'));
|
||||
|
||||
?>
|
||||
--EXPECTF--
|
||||
bool(false)
|
||||
bool(true)
|
||||
NULL
|
||||
string(0) ""
|
||||
string(5) "array"
|
||||
string(%d) "Method [ <internal:date> static public method listIdentifiers ] {
|
||||
|
||||
|
@ -49,7 +44,7 @@ string(%d) "Method [ <internal:date> static public method listIdentifiers ] {
|
|||
bool(true)
|
||||
bool(false)
|
||||
string(6) "string"
|
||||
NULL
|
||||
string(0) ""
|
||||
string(%d) "Method [ <user, overwrites DateTimeZone, prototype DateTimeZone> static public method listIdentifiers ] {
|
||||
@@ %s
|
||||
|
||||
|
@ -60,3 +55,15 @@ string(%d) "Method [ <user, overwrites DateTimeZone, prototype DateTimeZone> sta
|
|||
- Return [ string ]
|
||||
}
|
||||
"
|
||||
|
||||
bool(false)
|
||||
bool(true)
|
||||
string(0) ""
|
||||
string(37) "SplFileInfo|FilesystemIterator|string"
|
||||
string(191) "Method [ <internal:SPL, overwrites DirectoryIterator, prototype Iterator> public method current ] {
|
||||
|
||||
- Parameters [0] {
|
||||
}
|
||||
- Tentative return [ SplFileInfo|FilesystemIterator|string ]
|
||||
}
|
||||
"
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue