mirror of
https://github.com/php/php-src.git
synced 2024-10-17 06:22:53 +00:00
f01c842ef6
# I don't feel like discussing this issue anymore - maybe we need to find # a way of returning proxies to get the requested behavior back - i'll give # it a try for PHP 5.2. So long we'll have to stay with the original # decision that we don't support references at all with ArrayAccess.
60 lines
1.3 KiB
PHP
Executable File
60 lines
1.3 KiB
PHP
Executable File
--TEST--
|
|
ZE2 ArrayAccess and ASSIGN_OP operators (.=)
|
|
--FILE--
|
|
<?php
|
|
|
|
class Peoples implements ArrayAccess {
|
|
public $person;
|
|
|
|
function __construct() {
|
|
$this->person = array(array('name'=>'Foo'));
|
|
}
|
|
|
|
function offsetExists($index) {
|
|
return array_key_exists($this->person, $index);
|
|
}
|
|
|
|
function offsetGet($index) {
|
|
return $this->person[$index];
|
|
}
|
|
|
|
function offsetSet($index, $value) {
|
|
$this->person[$index] = $value;
|
|
}
|
|
|
|
function offsetUnset($index) {
|
|
unset($this->person[$index]);
|
|
}
|
|
}
|
|
|
|
$people = new Peoples;
|
|
|
|
var_dump($people->person[0]['name']);
|
|
$people->person[0]['name'] = $people->person[0]['name'] . 'Bar';
|
|
var_dump($people->person[0]['name']);
|
|
$people->person[0]['name'] .= 'Baz';
|
|
var_dump($people->person[0]['name']);
|
|
|
|
echo "===ArrayOverloading===\n";
|
|
|
|
$people = new Peoples;
|
|
|
|
var_dump($people[0]['name']);
|
|
$people[0]['name'] = 'FooBar';
|
|
var_dump($people[0]['name']);
|
|
$people[0]['name'] = $people->person[0]['name'] . 'Bar';
|
|
var_dump($people[0]['name']);
|
|
$people[0]['name'] .= 'Baz';
|
|
var_dump($people[0]['name']);
|
|
|
|
?>
|
|
===DONE===
|
|
--EXPECTF--
|
|
string(3) "Foo"
|
|
string(6) "FooBar"
|
|
string(9) "FooBarBaz"
|
|
===ArrayOverloading===
|
|
string(3) "Foo"
|
|
|
|
Fatal error: Objects used as arrays in post/pre increment/decrement must return values by reference in %sarray_access_008.php on line %d
|