summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Zend/tests/exception_during_by_reference_magic_get.phpt23
-rw-r--r--Zend/zend_execute.c4
2 files changed, 27 insertions, 0 deletions
diff --git a/Zend/tests/exception_during_by_reference_magic_get.phpt b/Zend/tests/exception_during_by_reference_magic_get.phpt
new file mode 100644
index 0000000000..5732e8cc5a
--- /dev/null
+++ b/Zend/tests/exception_during_by_reference_magic_get.phpt
@@ -0,0 +1,23 @@
+--TEST--
+Exception thrown by __get() during =& assignment
+--FILE--
+<?php
+
+class Test {
+ private $x;
+ public function &__get($name) {
+ throw new Exception("Foobar");
+ }
+}
+
+$test = new Test;
+$y = 5;
+try {
+ $test->x =& $y;
+} catch (Exception $e) {
+ echo $e->getMessage(), "\n";
+}
+
+?>
+--EXPECT--
+Foobar
diff --git a/Zend/zend_execute.c b/Zend/zend_execute.c
index c5b502501e..6a6ad61094 100644
--- a/Zend/zend_execute.c
+++ b/Zend/zend_execute.c
@@ -2872,6 +2872,10 @@ static zend_always_inline void zend_fetch_property_address(zval *result, zval *c
}
return;
}
+ if (UNEXPECTED(EG(exception))) {
+ ZVAL_ERROR(result);
+ return;
+ }
} else if (UNEXPECTED(Z_ISERROR_P(ptr))) {
ZVAL_ERROR(result);
return;