mirror of
https://github.com/php/php-src.git
synced 2025-01-10 13:03:54 +08:00
Better fix for #45622 (patch by robinf at php do net)
This commit is contained in:
parent
d2eb7e4601
commit
c176114acb
@ -749,12 +749,12 @@ static int spl_array_has_property(zval *object, zval *member, int has_set_exists
|
||||
{
|
||||
spl_array_object *intern = (spl_array_object*)zend_object_store_get_object(object TSRMLS_CC);
|
||||
|
||||
if (std_object_handlers.has_property(object, member, has_set_exists TSRMLS_CC)) {
|
||||
return 1;
|
||||
} else if ((intern->ar_flags & SPL_ARRAY_ARRAY_AS_PROPS) != 0) {
|
||||
if ((intern->ar_flags & SPL_ARRAY_ARRAY_AS_PROPS) != 0
|
||||
&& !std_object_handlers.has_property(object, member, 2 TSRMLS_CC)) {
|
||||
return spl_array_has_dimension(object, member, has_set_exists TSRMLS_CC);
|
||||
}
|
||||
return 0;
|
||||
return std_object_handlers.has_property(object, member, has_set_exists TSRMLS_CC);
|
||||
|
||||
} /* }}} */
|
||||
|
||||
static void spl_array_unset_property(zval *object, zval *member TSRMLS_DC) /* {{{ */
|
||||
|
@ -143,11 +143,8 @@ object(UsesMagic)#2 (2) {
|
||||
}
|
||||
|
||||
--> isset existent, non-existent and dynamic:
|
||||
In UsesMagic::__isset(a)
|
||||
bool(true)
|
||||
In UsesMagic::__isset(nonexistent)
|
||||
bool(false)
|
||||
In UsesMagic::__isset(dynamic)
|
||||
bool(true)
|
||||
Original wrapped object:
|
||||
object(C)#1 (5) {
|
||||
|
33
ext/spl/tests/bug45622b.phpt
Normal file
33
ext/spl/tests/bug45622b.phpt
Normal file
@ -0,0 +1,33 @@
|
||||
--TEST--
|
||||
Ensure fix to bug45622 doesn't cause __isset() to be called when ArrayObject::ARRAY_AS_PROPS is used.
|
||||
--FILE--
|
||||
<?php
|
||||
class UsesMagic extends ArrayObject {
|
||||
function __get($n) { echo "In " . __METHOD__ . "!\n"; }
|
||||
function __set($n, $v) { echo "In " . __METHOD__ . "!\n"; }
|
||||
function __isset($n) { echo "In " . __METHOD__ . "!\n"; }
|
||||
function __unset($n) { echo "In " . __METHOD__ . "!\n"; }
|
||||
}
|
||||
$ao = new UsesMagic(array(), ArrayObject::ARRAY_AS_PROPS);
|
||||
|
||||
echo "Doesn't trigger __get.\n";
|
||||
echo $ao->prop1;
|
||||
|
||||
echo "Doesn't trigger __set.\n";
|
||||
$ao->prop2 = 'foo';
|
||||
|
||||
echo "Doesn't trigger __unset.\n";
|
||||
unset($ao->prop3);
|
||||
|
||||
echo "Shouldn't trigger __isset.\n";
|
||||
isset($ao->prop4);
|
||||
?>
|
||||
--EXPECTF--
|
||||
Doesn't trigger __get.
|
||||
|
||||
Notice: Undefined index: prop1 in %s on line 11
|
||||
Doesn't trigger __set.
|
||||
Doesn't trigger __unset.
|
||||
|
||||
Notice: Undefined index: prop3 in %s on line 17
|
||||
Shouldn't trigger __isset.
|
Loading…
Reference in New Issue
Block a user