summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNikita Popov <nikita.ppv@gmail.com>2017-04-02 13:30:35 +0200
committerNikita Popov <nikita.ppv@gmail.com>2017-04-02 13:30:35 +0200
commitfe46a7da78f037fe032f27c9b65667c675a6dd8d (patch)
tree4662162b129fd6e15e57de8ea1e25f41de2e1a6c
parentc8034514edadbafc4376f107e2a4ba52b7b17ff4 (diff)
downloadphp-git-fe46a7da78f037fe032f27c9b65667c675a6dd8d.tar.gz
Fixed bug #74340
-rw-r--r--NEWS4
-rw-r--r--Zend/tests/bug74340.phpt30
-rw-r--r--Zend/zend_object_handlers.c2
3 files changed, 35 insertions, 1 deletions
diff --git a/NEWS b/NEWS
index 635a51b835..f92417a2a9 100644
--- a/NEWS
+++ b/NEWS
@@ -2,6 +2,10 @@ PHP NEWS
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
?? ??? 2017, PHP 7.1.5
+- Core:
+ . Fixed bug #74340 (Magic function __get has different behavior in php 7.1.x).
+ (Nikita)
+
- GD:
. Fixed bug #74343 (compile fails on solaris 11 with system gd2 library).
(krakjoe)
diff --git a/Zend/tests/bug74340.phpt b/Zend/tests/bug74340.phpt
new file mode 100644
index 0000000000..f266dcc236
--- /dev/null
+++ b/Zend/tests/bug74340.phpt
@@ -0,0 +1,30 @@
+--TEST--
+Bug #74340: Magic function __get has different behavior in php 7.1.x
+--FILE--
+<?php
+class Test
+{
+ public function __get($var)
+ {
+ static $first = true;
+ echo '__get '.$var.PHP_EOL;
+ if ($first) {
+ $first = false;
+ $this->$var;
+ $this->{$var.'2'};
+ $this->$var;
+ }
+ }
+}
+
+$test = new Test;
+$test->test;
+
+?>
+--EXPECTF--
+__get test
+
+Notice: Undefined property: Test::$test in %s on line %d
+__get test2
+
+Notice: Undefined property: Test::$test in %s on line %d
diff --git a/Zend/zend_object_handlers.c b/Zend/zend_object_handlers.c
index 9a01bcf89d..c75a59e036 100644
--- a/Zend/zend_object_handlers.c
+++ b/Zend/zend_object_handlers.c
@@ -545,7 +545,7 @@ ZEND_API uint32_t *zend_get_property_guard(zend_object *zobj, zend_string *membe
ALLOC_HASHTABLE(guards);
zend_hash_init(guards, 8, NULL, zend_property_guard_dtor, 0);
/* mark pointer as "special" using low bit */
- zend_hash_add_new_ptr(guards, member,
+ zend_hash_add_new_ptr(guards, str,
(void*)(((zend_uintptr_t)&zv->u2.property_guard) | 1));
zend_string_release(Z_STR_P(zv));
ZVAL_ARR(zv, guards);