summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNikita Popov <nikita.ppv@gmail.com>2019-10-23 12:19:33 +0200
committerNikita Popov <nikita.ppv@gmail.com>2019-10-23 12:21:30 +0200
commitf8413887816c4cecda75e6ae59dc3d1a74bb4f77 (patch)
tree0110dc425e392ce567ce68c4884ead277773060d
parent3157173b28735ebd8f1bd620c8672558d7b70c74 (diff)
downloadphp-git-f8413887816c4cecda75e6ae59dc3d1a74bb4f77.tar.gz
Don't autoload when checking property types
Noticed while working on union types: We do not load argument and return types during type checks, but we do load property types. I'm normalizing the behavior towards the existing status quo (not loading), though we may consider loading everywhere (all types, and instanceof) in order to properly support class aliases.
-rw-r--r--Zend/tests/type_declarations/typed_properties_class_loading.phpt51
-rw-r--r--Zend/zend_execute.c2
2 files changed, 52 insertions, 1 deletions
diff --git a/Zend/tests/type_declarations/typed_properties_class_loading.phpt b/Zend/tests/type_declarations/typed_properties_class_loading.phpt
new file mode 100644
index 0000000000..0612624454
--- /dev/null
+++ b/Zend/tests/type_declarations/typed_properties_class_loading.phpt
@@ -0,0 +1,51 @@
+--TEST--
+Typed properties do not invoke the autoloader
+--FILE--
+<?php
+
+class Test {
+ public X $propX;
+ public ?Y $propY;
+}
+
+spl_autoload_register(function($class) {
+ echo "Loading $class\n";
+});
+
+$test = new Test;
+try {
+ $test->propX = new stdClass;
+} catch (TypeError $e) {
+ echo $e->getMessage(), "\n";
+}
+
+if (true) {
+ class X {}
+}
+
+$test->propX = new X;
+var_dump($test->propX);
+
+$test->propY = null;
+$r =& $test->propY;
+try {
+ $test->propY = new stdClass;
+} catch (TypeError $e) {
+ echo $e->getMessage(), "\n";
+}
+
+if (true) {
+ class Y {}
+}
+
+$r = new Y;
+var_dump($test->propY);
+
+?>
+--EXPECT--
+Typed property Test::$propX must be an instance of X, stdClass used
+object(X)#3 (0) {
+}
+Typed property Test::$propY must be an instance of Y or null, stdClass used
+object(Y)#4 (0) {
+}
diff --git a/Zend/zend_execute.c b/Zend/zend_execute.c
index 04aa3fee6e..5407d89680 100644
--- a/Zend/zend_execute.c
+++ b/Zend/zend_execute.c
@@ -941,7 +941,7 @@ static zend_bool zend_resolve_class_type(zend_type *type, zend_class_entry *self
}
ce = self_ce->parent;
} else {
- ce = zend_lookup_class(name);
+ ce = zend_lookup_class_ex(name, NULL, ZEND_FETCH_CLASS_NO_AUTOLOAD);
if (UNEXPECTED(!ce)) {
return 0;
}