summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--NEWS1
-rw-r--r--Zend/tests/bug80391.phpt23
-rw-r--r--Zend/zend_inheritance.c4
3 files changed, 28 insertions, 0 deletions
diff --git a/NEWS b/NEWS
index a3923e6972..bd3a10adfa 100644
--- a/NEWS
+++ b/NEWS
@@ -6,6 +6,7 @@ PHP NEWS
. Fixed bug #80345 (PHPIZE configuration has outdated PHP_RELEASE_VERSION).
(cmb)
. Fixed bug #72964 (White space not unfolded for CC/Bcc headers). (cmb)
+ . Fixed bug #80391 (Iterable not covariant to mixed). (Nikita)
- Tidy:
. Fixed bug #77594 (ob_tidyhandler is never reset). (cmb)
diff --git a/Zend/tests/bug80391.phpt b/Zend/tests/bug80391.phpt
new file mode 100644
index 0000000000..f483ed80fc
--- /dev/null
+++ b/Zend/tests/bug80391.phpt
@@ -0,0 +1,23 @@
+--TEST--
+Iterable not covariant to mixed
+--FILE--
+<?php
+
+class A {
+ public function method1(): mixed {}
+ public function method2(): array|object {}
+ public function method3(iterable $x) {}
+ public function method4(iterable $x) {}
+}
+
+class B extends A {
+ public function method1(): iterable {}
+ public function method2(): iterable {}
+ public function method3(mixed $x) {}
+ public function method4(array|object $x) {}
+}
+
+?>
+===DONE===
+--EXPECT--
+===DONE===
diff --git a/Zend/zend_inheritance.c b/Zend/zend_inheritance.c
index 7401456d8f..882738b758 100644
--- a/Zend/zend_inheritance.c
+++ b/Zend/zend_inheritance.c
@@ -323,6 +323,10 @@ static zend_bool unlinked_instanceof(zend_class_entry *ce1, zend_class_entry *ce
static zend_bool zend_type_contains_traversable(zend_type type) {
zend_type *single_type;
+ if (ZEND_TYPE_FULL_MASK(type) & MAY_BE_OBJECT) {
+ return 1;
+ }
+
ZEND_TYPE_FOREACH(type, single_type) {
if (ZEND_TYPE_HAS_NAME(*single_type)
&& zend_string_equals_literal_ci(ZEND_TYPE_NAME(*single_type), "Traversable")) {