mirror of
https://github.com/php/php-src.git
synced 2024-12-13 20:05:26 +08:00
a9e6667817
We already detect the case where we're entirely outside a class -- now also check whether there actually is a parent. This is a minor BC break, in that code that was never executed might have previously contained an invalid parent:: reference without generating an error.
57 lines
1.1 KiB
PHP
57 lines
1.1 KiB
PHP
--TEST--
|
|
Bug #75573 (Segmentation fault in 7.1.12 and 7.0.26)
|
|
--FILE--
|
|
<?php
|
|
|
|
class A
|
|
{
|
|
var $_stdObject;
|
|
function &__get($property)
|
|
{
|
|
if (isset($this->_stdObject->{$property})) {
|
|
$retval =& $this->_stdObject->{$property};
|
|
return $retval;
|
|
} else {
|
|
return NULL;
|
|
}
|
|
}
|
|
function &__set($property, $value)
|
|
{
|
|
return $this->_stdObject->{$property} = $value;
|
|
}
|
|
function __isset($property_name)
|
|
{
|
|
return isset($this->_stdObject->{$property_name});
|
|
}
|
|
}
|
|
|
|
class B extends A
|
|
{
|
|
function &__get($property)
|
|
{
|
|
if (isset($this->settings) && isset($this->settings[$property])) {
|
|
$retval =& $this->settings[$property];
|
|
return $retval;
|
|
} else {
|
|
return parent::__get($property);
|
|
}
|
|
}
|
|
}
|
|
|
|
$b = new B();
|
|
$b->settings = [ "foo" => "bar", "name" => "abc" ];
|
|
var_dump($b->name);
|
|
var_dump($b->settings);
|
|
?>
|
|
--EXPECTF--
|
|
Warning: Creating default object from empty value in %sbug75573.php on line %d
|
|
|
|
Notice: Only variable references should be returned by reference in %sbug75573.php on line %d
|
|
string(3) "abc"
|
|
array(2) {
|
|
["foo"]=>
|
|
string(3) "bar"
|
|
["name"]=>
|
|
string(3) "abc"
|
|
}
|