helly Thu Nov 1 16:54:43 2007 UTC Modified files: (Branch: PHP_5_3) /php-src/ext/standard var.c Log: - MFH missing get_debug_info piece http://cvs.php.net/viewvc.cgi/php-src/ext/standard/var.c?r1=1.203.2.7.2.18.2.2&r2=1.203.2.7.2.18.2.3&diff_format=u Index: php-src/ext/standard/var.c diff -u php-src/ext/standard/var.c:1.203.2.7.2.18.2.2 php-src/ext/standard/var.c:1.203.2.7.2.18.2.3 --- php-src/ext/standard/var.c:1.203.2.7.2.18.2.2 Thu Oct 11 01:03:03 2007 +++ php-src/ext/standard/var.c Thu Nov 1 16:54:43 2007 @@ -18,9 +18,7 @@ +----------------------------------------------------------------------+ */ -/* $Id: var.c,v 1.203.2.7.2.18.2.2 2007/10/11 01:03:03 helly Exp $ */ - - +/* $Id: var.c,v 1.203.2.7.2.18.2.3 2007/11/01 16:54:43 helly Exp $ */ /* {{{ includes */ @@ -258,6 +256,7 @@ zend_uint class_name_len; zend_class_entry *ce; int (*zval_element_dump_func)(zval**, int, va_list, zend_hash_key*); + int is_temp = 0; if (level > 1) { php_printf("%*c", level - 1, ' '); @@ -274,8 +273,7 @@ php_printf("%slong(%ld) refcount(%u)\n", COMMON, Z_LVAL_PP(struc), Z_REFCOUNT_PP(struc)); break; case IS_DOUBLE: - php_printf("%sdouble(%.*G) refcount(%u)\n", COMMON, (int) EG(precision), Z_DVAL_PP(struc), -Z_REFCOUNT_PP(struc)); + php_printf("%sdouble(%.*G) refcount(%u)\n", COMMON, (int) EG(precision), Z_DVAL_PP(struc), Z_REFCOUNT_PP(struc)); break; case IS_STRING: php_printf("%sstring(%d) \"", COMMON, Z_STRLEN_PP(struc)); @@ -292,19 +290,23 @@ zval_element_dump_func = zval_array_element_dump; goto head_done; case IS_OBJECT: - myht = Z_OBJPROP_PP(struc); + myht = Z_OBJDEBUG_PP(struc, is_temp); if (myht && myht->nApplyCount > 1) { PUTS("*RECURSION*\n"); return; } - ce = Z_OBJCE(**struc); - Z_OBJ_HANDLER(**struc, get_class_name)(*struc, &class_name, &class_name_len, 0 TSRMLS_CC); + ce = Z_OBJCE_PP(struc); + Z_OBJ_HANDLER_PP(struc, get_class_name)(*struc, &class_name, &class_name_len, 0 TSRMLS_CC); php_printf("%sobject(%s)#%d (%d) refcount(%u){\n", COMMON, class_name, Z_OBJ_HANDLE_PP(struc), myht ? zend_hash_num_elements(myht) : 0, Z_REFCOUNT_PP(struc)); efree(class_name); zval_element_dump_func = zval_object_property_dump; head_done: if (myht) { zend_hash_apply_with_arguments(myht, (apply_func_args_t) zval_element_dump_func, 1, level, (Z_TYPE_PP(struc) == IS_ARRAY ? 0 : 1)); + if (is_temp) { + zend_hash_destroy(myht); + efree(myht); + } } if (level > 1) { php_printf("%*c", level-1, ' ');
-- PHP CVS Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php