helly Sun Jun 19 20:19:18 2005 EDT Added files: /php-src/ext/spl/tests array_017.phpt
Modified files: /php-src/ext/spl spl_array.c Log: - Fix handling of ArrayObject/ArrayIterator flags and provide test
http://cvs.php.net/diff.php/php-src/ext/spl/spl_array.c?r1=1.68&r2=1.69&ty=u Index: php-src/ext/spl/spl_array.c diff -u php-src/ext/spl/spl_array.c:1.68 php-src/ext/spl/spl_array.c:1.69 --- php-src/ext/spl/spl_array.c:1.68 Tue May 24 13:59:42 2005 +++ php-src/ext/spl/spl_array.c Sun Jun 19 20:19:18 2005 @@ -16,7 +16,7 @@ +----------------------------------------------------------------------+ */ -/* $Id: spl_array.c,v 1.68 2005/05/24 17:59:42 helly Exp $ */ +/* $Id: spl_array.c,v 1.69 2005/06/20 00:19:18 helly Exp $ */ #ifdef HAVE_CONFIG_H # include "config.h" @@ -145,6 +145,7 @@ #define SPL_ARRAY_ARRAY_AS_PROPS 0x00000002 #define SPL_ARRAY_IS_REF 0x01000000 #define SPL_ARRAY_IS_SELF 0x02000000 +#define SPL_ARRAY_USE_OTHER 0x04000000 #define SPL_ARRAY_INT_MASK 0xFF000000 #define SPL_ARRAY_CLONE_MASK 0x03000003 @@ -160,8 +161,11 @@ zend_function * fptr_offset_del; } spl_array_object; -static inline HashTable *spl_array_get_hash_table(spl_array_object* intern TSRMLS_DC) { - if ((intern->ar_flags & (SPL_ARRAY_STD_PROP_LIST|SPL_ARRAY_IS_SELF)) != 0) { +static inline HashTable *spl_array_get_hash_table(spl_array_object* intern, int check_std_props TSRMLS_DC) { + if ((intern->ar_flags & SPL_ARRAY_USE_OTHER) && (check_std_props == 0 || (intern->ar_flags & SPL_ARRAY_STD_PROP_LIST) == 0)) { + spl_array_object *other = (spl_array_object*)zend_object_store_get_object(intern->array TSRMLS_CC); + return spl_array_get_hash_table(other, check_std_props TSRMLS_CC); + } else if ((intern->ar_flags & ((check_std_props ? SPL_ARRAY_STD_PROP_LIST : 0) | SPL_ARRAY_IS_SELF)) != 0) { return intern->std.properties; } else { return HASH_OF(intern->array); @@ -170,7 +174,7 @@ SPL_API int spl_hash_verify_pos(spl_array_object * intern TSRMLS_DC) /* {{{ */ { - HashTable *ht = spl_array_get_hash_table(intern TSRMLS_CC); + HashTable *ht = spl_array_get_hash_table(intern, 0 TSRMLS_CC); Bucket *p; /* IS_CONSISTENT(ht);*/ @@ -184,7 +188,7 @@ p = p->pListNext; } /* HASH_UNPROTECT_RECURSION(ht); */ - zend_hash_internal_pointer_reset_ex(spl_array_get_hash_table(intern TSRMLS_CC), &intern->pos); + zend_hash_internal_pointer_reset_ex(spl_array_get_hash_table(intern, 0 TSRMLS_CC), &intern->pos); return FAILURE; } /* }}} */ @@ -204,7 +208,7 @@ /* }}} */ /* {{{ spl_array_object_new */ -static zend_object_value spl_array_object_new_ex(zend_class_entry *class_type, spl_array_object **obj, spl_array_object *orig TSRMLS_DC) +static zend_object_value spl_array_object_new_ex(zend_class_entry *class_type, spl_array_object **obj, zval *orig TSRMLS_DC) { zend_object_value retval; spl_array_object *intern; @@ -223,10 +227,12 @@ intern->ar_flags = 0; if (orig) { - intern->array = orig->array; + spl_array_object *other = (spl_array_object*)zend_object_store_get_object(orig TSRMLS_CC); + + intern->array = orig; ZVAL_ADDREF(intern->array); intern->ar_flags &= ~ SPL_ARRAY_CLONE_MASK; - intern->ar_flags |= (orig->ar_flags & SPL_ARRAY_CLONE_MASK) | SPL_ARRAY_IS_REF; + intern->ar_flags |= (other->ar_flags & SPL_ARRAY_CLONE_MASK) | SPL_ARRAY_IS_REF | SPL_ARRAY_USE_OTHER; } else { MAKE_STD_ZVAL(intern->array); array_init(intern->array); @@ -266,7 +272,7 @@ intern->fptr_offset_del = NULL; } } - zend_hash_internal_pointer_reset_ex(spl_array_get_hash_table(intern TSRMLS_CC), &intern->pos); + zend_hash_internal_pointer_reset_ex(spl_array_get_hash_table(intern, 0 TSRMLS_CC), &intern->pos); return retval; } /* }}} */ @@ -289,7 +295,7 @@ spl_array_object *intern; old_object = zend_objects_get_address(zobject TSRMLS_CC); - new_obj_val = spl_array_object_new_ex(old_object->ce, &intern, (spl_array_object*)old_object TSRMLS_CC); + new_obj_val = spl_array_object_new_ex(old_object->ce, &intern, zobject TSRMLS_CC); new_object = &intern->std; zend_objects_clone_members(new_object, new_obj_val, old_object, handle TSRMLS_CC); @@ -311,7 +317,7 @@ switch(Z_TYPE_P(offset)) { case IS_STRING: - if (zend_symtable_find(spl_array_get_hash_table(intern TSRMLS_CC), Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1, (void **) &retval) == FAILURE) { + if (zend_symtable_find(spl_array_get_hash_table(intern, 0 TSRMLS_CC), Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1, (void **) &retval) == FAILURE) { zend_error(E_NOTICE, "Undefined index: %s", Z_STRVAL_P(offset)); return &EG(uninitialized_zval_ptr); } else { @@ -326,7 +332,7 @@ } else { index = Z_LVAL_P(offset); } - if (zend_hash_index_find(spl_array_get_hash_table(intern TSRMLS_CC), index, (void **) &retval) == FAILURE) { + if (zend_hash_index_find(spl_array_get_hash_table(intern, 0 TSRMLS_CC), index, (void **) &retval) == FAILURE) { zend_error(E_NOTICE, "Undefined offset: %ld", Z_LVAL_P(offset)); return &EG(uninitialized_zval_ptr); } else { @@ -369,13 +375,13 @@ if (!offset) { value->refcount++; - zend_hash_next_index_insert(spl_array_get_hash_table(intern TSRMLS_CC), (void**)&value, sizeof(void*), NULL); + zend_hash_next_index_insert(spl_array_get_hash_table(intern, 0 TSRMLS_CC), (void**)&value, sizeof(void*), NULL); return; } switch(Z_TYPE_P(offset)) { case IS_STRING: value->refcount++; - zend_symtable_update(spl_array_get_hash_table(intern TSRMLS_CC), Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1, (void**)&value, sizeof(void*), NULL); + zend_symtable_update(spl_array_get_hash_table(intern, 0 TSRMLS_CC), Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1, (void**)&value, sizeof(void*), NULL); return; case IS_DOUBLE: case IS_RESOURCE: @@ -387,7 +393,7 @@ index = Z_LVAL_P(offset); } value->refcount++; - zend_hash_index_update(spl_array_get_hash_table(intern TSRMLS_CC), index, (void**)&value, sizeof(void*), NULL); + zend_hash_index_update(spl_array_get_hash_table(intern, 0 TSRMLS_CC), index, (void**)&value, sizeof(void*), NULL); return; default: zend_error(E_WARNING, "Illegal offset type"); @@ -413,12 +419,12 @@ switch(Z_TYPE_P(offset)) { case IS_STRING: - if (spl_array_get_hash_table(intern TSRMLS_CC) == &EG(symbol_table)) { + if (spl_array_get_hash_table(intern, 0 TSRMLS_CC) == &EG(symbol_table)) { if (zend_delete_global_variable(Z_STRVAL_P(offset), Z_STRLEN_P(offset) TSRMLS_CC)) { zend_error(E_NOTICE,"Undefined index: %s", Z_STRVAL_P(offset)); } } else { - if (zend_symtable_del(spl_array_get_hash_table(intern TSRMLS_CC), Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1) == FAILURE) { + if (zend_symtable_del(spl_array_get_hash_table(intern, 0 TSRMLS_CC), Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1) == FAILURE) { zend_error(E_NOTICE,"Undefined index: %s", Z_STRVAL_P(offset)); } } @@ -432,7 +438,7 @@ } else { index = Z_LVAL_P(offset); } - if (zend_hash_index_del(spl_array_get_hash_table(intern TSRMLS_CC), index) == FAILURE) { + if (zend_hash_index_del(spl_array_get_hash_table(intern, 0 TSRMLS_CC), index) == FAILURE) { zend_error(E_NOTICE,"Undefined offset: %ld", Z_LVAL_P(offset)); } break; @@ -466,7 +472,7 @@ switch(Z_TYPE_P(offset)) { case IS_STRING: - return zend_symtable_exists(spl_array_get_hash_table(intern TSRMLS_CC), Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1); + return zend_symtable_exists(spl_array_get_hash_table(intern, 0 TSRMLS_CC), Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1); case IS_DOUBLE: case IS_RESOURCE: case IS_BOOL: @@ -476,7 +482,7 @@ } else { index = Z_LVAL_P(offset); } - return zend_hash_index_exists(spl_array_get_hash_table(intern TSRMLS_CC), index); + return zend_hash_index_exists(spl_array_get_hash_table(intern, 0 TSRMLS_CC), index); default: zend_error(E_WARNING, "Illegal offset type"); } @@ -529,7 +535,7 @@ void spl_array_iterator_append(zval *object, zval *append_value TSRMLS_DC) /* {{{ */ { spl_array_object *intern = (spl_array_object*)zend_object_store_get_object(object TSRMLS_CC); - HashTable *aht = spl_array_get_hash_table(intern TSRMLS_CC); + HashTable *aht = spl_array_get_hash_table(intern, 0 TSRMLS_CC); if (!aht) { php_error_docref(NULL TSRMLS_CC, E_NOTICE, "Array was modified outside object and is no longer an array"); @@ -580,14 +586,14 @@ spl_array_object *intern = (spl_array_object*)zend_object_store_get_object(object TSRMLS_CC); array_init(return_value); - zend_hash_copy(HASH_OF(return_value), spl_array_get_hash_table(intern TSRMLS_CC), (copy_ctor_func_t) zval_add_ref, &tmp, sizeof(zval*)); + zend_hash_copy(HASH_OF(return_value), spl_array_get_hash_table(intern, 0 TSRMLS_CC), (copy_ctor_func_t) zval_add_ref, &tmp, sizeof(zval*)); } /* }}} */ static HashTable *spl_array_get_properties(zval *object TSRMLS_DC) /* {{{ */ { spl_array_object *intern = (spl_array_object*)zend_object_store_get_object(object TSRMLS_CC); - return spl_array_get_hash_table(intern TSRMLS_CC); + return spl_array_get_hash_table(intern, 1 TSRMLS_CC); } /* }}} */ static zval *spl_array_read_property(zval *object, zval *member, int type TSRMLS_DC) /* {{{ */ @@ -657,7 +663,7 @@ char *string_key; uint string_length; ulong num_key; - HashTable *aht = spl_array_get_hash_table(intern TSRMLS_CC); + HashTable *aht = spl_array_get_hash_table(intern, 0 TSRMLS_CC); if (Z_TYPE_P(intern->array) == IS_OBJECT) { do { @@ -680,7 +686,7 @@ static int spl_array_next(spl_array_object *intern TSRMLS_DC) /* {{{ */ { - HashTable *aht = spl_array_get_hash_table(intern TSRMLS_CC); + HashTable *aht = spl_array_get_hash_table(intern, 0 TSRMLS_CC); if ((intern->ar_flags & SPL_ARRAY_IS_REF) && spl_hash_verify_pos(intern TSRMLS_CC) == FAILURE) { php_error_docref(NULL TSRMLS_CC, E_NOTICE, "Array was modified outside object and internal position is no longer valid"); @@ -715,7 +721,7 @@ { spl_array_it *iterator = (spl_array_it *)iter; spl_array_object *object = iterator->object; - HashTable *aht = spl_array_get_hash_table(object TSRMLS_CC); + HashTable *aht = spl_array_get_hash_table(object, 0 TSRMLS_CC); if (!aht) { php_error_docref(NULL TSRMLS_CC, E_NOTICE, "ArrayIterator::valid(): Array was modified outside object and is no longer an array"); @@ -735,7 +741,7 @@ { spl_array_it *iterator = (spl_array_it *)iter; spl_array_object *object = iterator->object; - HashTable *aht = spl_array_get_hash_table(object TSRMLS_CC); + HashTable *aht = spl_array_get_hash_table(object, 0 TSRMLS_CC); if (zend_hash_get_current_data_ex(aht, (void**)data, &object->pos) == FAILURE) { *data = NULL; @@ -747,7 +753,7 @@ { spl_array_it *iterator = (spl_array_it *)iter; spl_array_object *object = iterator->object; - HashTable *aht = spl_array_get_hash_table(object TSRMLS_CC); + HashTable *aht = spl_array_get_hash_table(object, 0 TSRMLS_CC); if (!aht) { php_error_docref(NULL TSRMLS_CC, E_NOTICE, "ArrayIterator::current(): Array was modified outside object and is no longer an array"); @@ -768,7 +774,7 @@ spl_array_it *iterator = (spl_array_it *)iter; spl_array_object *object = iterator->object; - HashTable *aht = spl_array_get_hash_table(object TSRMLS_CC); + HashTable *aht = spl_array_get_hash_table(object, 0 TSRMLS_CC); if (!aht) { php_error_docref(NULL TSRMLS_CC, E_NOTICE, "ArrayIterator::current(): Array was modified outside object and is no longer an array"); @@ -785,7 +791,7 @@ static void spl_array_rewind(spl_array_object *intern TSRMLS_DC) /* {{{ */ { - HashTable *aht = spl_array_get_hash_table(intern TSRMLS_CC); + HashTable *aht = spl_array_get_hash_table(intern, 0 TSRMLS_CC); if (!aht) { php_error_docref(NULL TSRMLS_CC, E_NOTICE, "ArrayIterator::rewind(): Array was modified outside object and is no longer an array"); @@ -852,10 +858,17 @@ return; } + ar_flags &= ~SPL_ARRAY_INT_MASK; + if (Z_TYPE_P(array) == IS_OBJECT && (Z_OBJ_HT_P(array) == &spl_handler_ArrayObject || Z_OBJ_HT_P(array) == &spl_handler_ArrayIterator)) { - spl_array_object *other = (spl_array_object*)zend_object_store_get_object(array TSRMLS_CC); zval_ptr_dtor(&intern->array); - intern->array = other->array; + if (ZEND_NUM_ARGS() == 1) + { + spl_array_object *other = (spl_array_object*)zend_object_store_get_object(array TSRMLS_CC); + ar_flags = other->ar_flags & ~SPL_ARRAY_INT_MASK; + } + ar_flags |= SPL_ARRAY_USE_OTHER; + intern->array = array; } else { if (Z_TYPE_P(array) != IS_OBJECT && Z_TYPE_P(array) != IS_ARRAY) { php_set_error_handling(EH_NORMAL, NULL TSRMLS_CC); @@ -870,7 +883,7 @@ } else { intern->ar_flags &= ~SPL_ARRAY_IS_SELF; } - intern->ar_flags |= ar_flags & ~SPL_ARRAY_INT_MASK; + intern->ar_flags |= ar_flags; ZVAL_ADDREF(intern->array); spl_array_rewind(intern TSRMLS_CC); @@ -914,15 +927,20 @@ spl_array_object *intern = (spl_array_object*)zend_object_store_get_object(object TSRMLS_CC); array_init(return_value); - zend_hash_copy(HASH_OF(return_value), spl_array_get_hash_table(intern TSRMLS_CC), (copy_ctor_func_t) zval_add_ref, &tmp, sizeof(zval*)); + zend_hash_copy(HASH_OF(return_value), spl_array_get_hash_table(intern, 0 TSRMLS_CC), (copy_ctor_func_t) zval_add_ref, &tmp, sizeof(zval*)); if (ZEND_NUM_ARGS() > 1 || zend_get_parameters_ex(1, &array) == FAILURE) { WRONG_PARAM_COUNT; } - if (Z_TYPE_PP(array) == IS_OBJECT && (Z_OBJ_HT_PP(array) == &spl_handler_ArrayObject || Z_OBJ_HT_PP(array) == &spl_handler_ArrayIterator)) { + if (Z_TYPE_PP(array) == IS_OBJECT && intern == (spl_array_object*)zend_object_store_get_object(object TSRMLS_CC)) + { + zval_ptr_dtor(&intern->array); + array = &object; + intern->array = object; + } else if (Z_TYPE_PP(array) == IS_OBJECT && (Z_OBJ_HT_PP(array) == &spl_handler_ArrayObject || Z_OBJ_HT_PP(array) == &spl_handler_ArrayIterator)) { spl_array_object *other = (spl_array_object*)zend_object_store_get_object(*array TSRMLS_CC); zval_ptr_dtor(&intern->array); - intern->array = other->array; + intern->array = other->array; } else { if (Z_TYPE_PP(array) != IS_OBJECT && !HASH_OF(*array)) { zend_throw_exception(spl_ce_InvalidArgumentException, "Passed variable is not an array or object, using empty array instead", 0 TSRMLS_CC); @@ -949,7 +967,7 @@ zval *object = getThis(); spl_array_object *intern = (spl_array_object*)zend_object_store_get_object(object TSRMLS_CC); spl_array_object *iterator; - HashTable *aht = spl_array_get_hash_table(intern TSRMLS_CC); + HashTable *aht = spl_array_get_hash_table(intern, 0 TSRMLS_CC); if (!aht) { php_error_docref(NULL TSRMLS_CC, E_NOTICE, "Array was modified outside object and is no longer an array"); @@ -957,7 +975,7 @@ } return_value->type = IS_OBJECT; - return_value->value.obj = spl_array_object_new_ex(spl_ce_ArrayIterator, &iterator, intern TSRMLS_CC); + return_value->value.obj = spl_array_object_new_ex(spl_ce_ArrayIterator, &iterator, object TSRMLS_CC); return_value->refcount = 1; return_value->is_ref = 1; } @@ -981,7 +999,7 @@ long opos, position; zval *object = getThis(); spl_array_object *intern = (spl_array_object*)zend_object_store_get_object(object TSRMLS_CC); - HashTable *aht = spl_array_get_hash_table(intern TSRMLS_CC); + HashTable *aht = spl_array_get_hash_table(intern, 0 TSRMLS_CC); int result; if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "l", &position) == FAILURE) { @@ -1014,7 +1032,7 @@ int spl_array_object_count_elements(zval *object, long *count TSRMLS_DC) /* {{{ */ { spl_array_object *intern = (spl_array_object*)zend_object_store_get_object(object TSRMLS_CC); - HashTable *aht = spl_array_get_hash_table(intern TSRMLS_CC); + HashTable *aht = spl_array_get_hash_table(intern, 0 TSRMLS_CC); HashPosition pos; if (!aht) { @@ -1058,7 +1076,7 @@ zval *object = getThis(); spl_array_object *intern = (spl_array_object*)zend_object_store_get_object(object TSRMLS_CC); zval **entry; - HashTable *aht = spl_array_get_hash_table(intern TSRMLS_CC); + HashTable *aht = spl_array_get_hash_table(intern, 0 TSRMLS_CC); if (!aht) { php_error_docref(NULL TSRMLS_CC, E_NOTICE, "Array was modified outside object and is no longer an array"); @@ -1086,7 +1104,7 @@ char *string_key; uint string_length; ulong num_key; - HashTable *aht = spl_array_get_hash_table(intern TSRMLS_CC); + HashTable *aht = spl_array_get_hash_table(intern, 0 TSRMLS_CC); if (!aht) { php_error_docref(NULL TSRMLS_CC, E_NOTICE, "Array was modified outside object and is no longer an array"); @@ -1117,7 +1135,7 @@ { zval *object = getThis(); spl_array_object *intern = (spl_array_object*)zend_object_store_get_object(object TSRMLS_CC); - HashTable *aht = spl_array_get_hash_table(intern TSRMLS_CC); + HashTable *aht = spl_array_get_hash_table(intern, 0 TSRMLS_CC); if (!aht) { php_error_docref(NULL TSRMLS_CC, E_NOTICE, "Array was modified outside object and is no longer an array"); @@ -1134,7 +1152,7 @@ { zval *object = getThis(); spl_array_object *intern = (spl_array_object*)zend_object_store_get_object(object TSRMLS_CC); - HashTable *aht = spl_array_get_hash_table(intern TSRMLS_CC); + HashTable *aht = spl_array_get_hash_table(intern, 0 TSRMLS_CC); if (!aht) { php_error_docref(NULL TSRMLS_CC, E_NOTICE, "Array was modified outside object and is no longer an array"); http://cvs.php.net/co.php/php-src/ext/spl/tests/array_017.phpt?r=1.1&p=1 Index: php-src/ext/spl/tests/array_017.phpt +++ php-src/ext/spl/tests/array_017.phpt --TEST-- SPL: ArrayObject::exchangeArray($this) --SKIPIF-- <?php if (!extension_loaded("spl")) print "skip"; ?> --FILE-- <?php class ArrayIteratorEx extends ArrayIterator { public $pub2 = 1; protected $pro2 = 2; private $pri2 = 3; function __construct($ar, $flags = 0) { echo __METHOD__ . "()\n"; parent::__construct($ar, $flags); $this->imp2 = 4; } function dump() { echo __METHOD__ . "()\n"; var_dump(array('Flags'=>$this->getFlags() ,'OVars'=>get_object_vars($this) ,'$this'=>$this)); } function setFlags($flags) { echo __METHOD__ . "($flags)\n"; ArrayObject::setFlags($flags); } } class ArrayObjectEx extends ArrayObject { public $pub1 = 1; protected $pro1 = 2; private $pri1 = 3; function __construct($ar = array(), $flags = 0) { echo __METHOD__ . "()\n"; parent::__construct($ar, $flags); $this->imp1 = 4; } function exchange() { echo __METHOD__ . "()\n"; $this->exchangeArray($this); } function dump() { echo __METHOD__ . "()\n"; var_dump(array('Flags'=>$this->getFlags() ,'OVars'=>get_object_vars($this) ,'$this'=>$this)); } function show() { echo __METHOD__ . "()\n"; foreach($this as $n => $v) { var_dump(array($n => $v)); } } function setFlags($flags) { echo __METHOD__ . "($flags)\n"; ArrayObject::setFlags($flags); } function getIterator() { echo __METHOD__ . "()\n"; $it = new ArrayIteratorEx($this, $this->getFlags()); $it->dyn2 = 5; $it->dump(); return $it; } } function check($obj, $flags) { echo "===CHECK===\n"; $obj->setFlags($flags); $obj->dump(); $obj->show(); echo "===FOREACH===\n"; $it = $obj->getIterator(); foreach($it as $n => $v) { var_dump(array($n => $v)); } echo "===PROPERTY===\n"; var_dump($obj->pub1); var_dump(isset($obj->a)); $obj->setFlags($flags | 2); var_dump($obj->pub1); var_dump(isset($obj->a)); var_dump($it->pub2); var_dump(isset($it->pub1)); $it->setFlags($flags | 2); var_dump($it->pub2); var_dump(isset($it->pub1)); } $obj = new ArrayObjectEx(array(0=>1,'a'=>25, 'pub1'=>42), 0); $obj->dyn1 = 5; check($obj, 0); check($obj, 1); echo "#####EXCHANGE#####\n"; $obj->exchange(); check($obj, 0); check($obj, 1); ?> ===DONE=== <?php exit(0); ?> --EXPECTF-- ArrayObjectEx::__construct() ===CHECK=== ArrayObjectEx::setFlags(0) ArrayObjectEx::dump() array(3) { ["Flags"]=> int(0) ["OVars"]=> array(2) { ["a"]=> int(25) ["pub1"]=> int(42) } ["$this"]=> object(ArrayObjectEx)#1 (3) { [0]=> int(1) ["a"]=> int(25) ["pub1"]=> int(42) } } ArrayObjectEx::show() ArrayObjectEx::getIterator() ArrayIteratorEx::__construct() ArrayIteratorEx::dump() array(3) { ["Flags"]=> int(0) ["OVars"]=> array(2) { ["a"]=> int(25) ["pub1"]=> int(42) } ["$this"]=> object(ArrayIteratorEx)#2 (3) { [0]=> int(1) ["a"]=> int(25) ["pub1"]=> int(42) } } array(1) { [0]=> int(1) } array(1) { ["a"]=> int(25) } array(1) { ["pub1"]=> int(42) } ===FOREACH=== ArrayObjectEx::getIterator() ArrayIteratorEx::__construct() ArrayIteratorEx::dump() array(3) { ["Flags"]=> int(0) ["OVars"]=> array(2) { ["a"]=> int(25) ["pub1"]=> int(42) } ["$this"]=> object(ArrayIteratorEx)#3 (3) { [0]=> int(1) ["a"]=> int(25) ["pub1"]=> int(42) } } array(1) { [0]=> int(1) } array(1) { ["a"]=> int(25) } array(1) { ["pub1"]=> int(42) } ===PROPERTY=== int(1) bool(false) ArrayObjectEx::setFlags(2) int(1) bool(true) int(1) bool(false) ArrayIteratorEx::setFlags(2) int(1) bool(true) ===CHECK=== ArrayObjectEx::setFlags(1) ArrayObjectEx::dump() array(3) { ["Flags"]=> int(1) ["OVars"]=> array(5) { ["pub1"]=> int(1) ["pro1"]=> int(2) ["pri1"]=> int(3) ["imp1"]=> int(4) ["dyn1"]=> int(5) } ["$this"]=> object(ArrayObjectEx)#1 (5) { ["pub1"]=> int(1) ["pro1:protected"]=> int(2) ["pri1:private"]=> int(3) ["imp1"]=> int(4) ["dyn1"]=> int(5) } } ArrayObjectEx::show() ArrayObjectEx::getIterator() ArrayIteratorEx::__construct() ArrayIteratorEx::dump() array(3) { ["Flags"]=> int(1) ["OVars"]=> array(5) { ["pub2"]=> int(1) ["pro2"]=> int(2) ["pri2"]=> int(3) ["imp2"]=> int(4) ["dyn2"]=> int(5) } ["$this"]=> object(ArrayIteratorEx)#3 (5) { ["pub2"]=> int(1) ["pro2:protected"]=> int(2) ["pri2:private"]=> int(3) ["imp2"]=> int(4) ["dyn2"]=> int(5) } } array(1) { [0]=> int(1) } array(1) { ["a"]=> int(25) } array(1) { ["pub1"]=> int(42) } ===FOREACH=== ArrayObjectEx::getIterator() ArrayIteratorEx::__construct() ArrayIteratorEx::dump() array(3) { ["Flags"]=> int(1) ["OVars"]=> array(5) { ["pub2"]=> int(1) ["pro2"]=> int(2) ["pri2"]=> int(3) ["imp2"]=> int(4) ["dyn2"]=> int(5) } ["$this"]=> object(ArrayIteratorEx)#2 (5) { ["pub2"]=> int(1) ["pro2:protected"]=> int(2) ["pri2:private"]=> int(3) ["imp2"]=> int(4) ["dyn2"]=> int(5) } } array(1) { [0]=> int(1) } array(1) { ["a"]=> int(25) } array(1) { ["pub1"]=> int(42) } ===PROPERTY=== int(1) bool(false) ArrayObjectEx::setFlags(3) int(1) bool(true) int(1) bool(false) ArrayIteratorEx::setFlags(3) int(1) bool(true) #####EXCHANGE##### ArrayObjectEx::exchange() ===CHECK=== ArrayObjectEx::setFlags(0) ArrayObjectEx::dump() array(3) { ["Flags"]=> int(0) ["OVars"]=> array(5) { ["pub1"]=> int(1) ["pro1"]=> int(2) ["pri1"]=> int(3) ["imp1"]=> int(4) ["dyn1"]=> int(5) } ["$this"]=> object(ArrayObjectEx)#1 (5) { ["pub1"]=> int(1) ["pro1:protected"]=> int(2) ["pri1:private"]=> int(3) ["imp1"]=> int(4) ["dyn1"]=> int(5) } } ArrayObjectEx::show() ArrayObjectEx::getIterator() ArrayIteratorEx::__construct() ArrayIteratorEx::dump() array(3) { ["Flags"]=> int(0) ["OVars"]=> array(4) { ["pub1"]=> int(1) ["pro1"]=> int(2) ["imp1"]=> int(4) ["dyn1"]=> int(5) } ["$this"]=> object(ArrayIteratorEx)#2 (5) { ["pub1"]=> int(1) ["pro1:protected"]=> int(2) ["pri1:private"]=> int(3) ["imp1"]=> int(4) ["dyn1"]=> int(5) } } array(1) { ["pub1"]=> int(1) } array(1) { ["imp1"]=> int(4) } array(1) { ["dyn1"]=> int(5) } ===FOREACH=== ArrayObjectEx::getIterator() ArrayIteratorEx::__construct() ArrayIteratorEx::dump() array(3) { ["Flags"]=> int(0) ["OVars"]=> array(4) { ["pub1"]=> int(1) ["pro1"]=> int(2) ["imp1"]=> int(4) ["dyn1"]=> int(5) } ["$this"]=> object(ArrayIteratorEx)#3 (5) { ["pub1"]=> int(1) ["pro1:protected"]=> int(2) ["pri1:private"]=> int(3) ["imp1"]=> int(4) ["dyn1"]=> int(5) } } array(1) { ["pub1"]=> int(1) } array(1) { ["imp1"]=> int(4) } array(1) { ["dyn1"]=> int(5) } ===PROPERTY=== int(1) bool(false) ArrayObjectEx::setFlags(2) int(1) bool(false) int(1) bool(false) ArrayIteratorEx::setFlags(2) int(1) bool(true) ===CHECK=== ArrayObjectEx::setFlags(1) ArrayObjectEx::dump() array(3) { ["Flags"]=> int(1) ["OVars"]=> array(5) { ["pub1"]=> int(1) ["pro1"]=> int(2) ["pri1"]=> int(3) ["imp1"]=> int(4) ["dyn1"]=> int(5) } ["$this"]=> object(ArrayObjectEx)#1 (5) { ["pub1"]=> int(1) ["pro1:protected"]=> int(2) ["pri1:private"]=> int(3) ["imp1"]=> int(4) ["dyn1"]=> int(5) } } ArrayObjectEx::show() ArrayObjectEx::getIterator() ArrayIteratorEx::__construct() ArrayIteratorEx::dump() array(3) { ["Flags"]=> int(1) ["OVars"]=> array(5) { ["pub2"]=> int(1) ["pro2"]=> int(2) ["pri2"]=> int(3) ["imp2"]=> int(4) ["dyn2"]=> int(5) } ["$this"]=> object(ArrayIteratorEx)#3 (5) { ["pub2"]=> int(1) ["pro2:protected"]=> int(2) ["pri2:private"]=> int(3) ["imp2"]=> int(4) ["dyn2"]=> int(5) } } array(1) { ["pub1"]=> int(1) } array(1) { ["imp1"]=> int(4) } array(1) { ["dyn1"]=> int(5) } ===FOREACH=== ArrayObjectEx::getIterator() ArrayIteratorEx::__construct() ArrayIteratorEx::dump() array(3) { ["Flags"]=> int(1) ["OVars"]=> array(5) { ["pub2"]=> int(1) ["pro2"]=> int(2) ["pri2"]=> int(3) ["imp2"]=> int(4) ["dyn2"]=> int(5) } ["$this"]=> object(ArrayIteratorEx)#2 (5) { ["pub2"]=> int(1) ["pro2:protected"]=> int(2) ["pri2:private"]=> int(3) ["imp2"]=> int(4) ["dyn2"]=> int(5) } } array(1) { ["pub1"]=> int(1) } array(1) { ["imp1"]=> int(4) } array(1) { ["dyn1"]=> int(5) } ===PROPERTY=== int(1) bool(false) ArrayObjectEx::setFlags(3) int(1) bool(false) int(1) bool(false) ArrayIteratorEx::setFlags(3) int(1) bool(true) ===DONE===
-- PHP CVS Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php