dmitry Fri Mar 10 08:43:14 2006 UTC Modified files: /php-src/ext/standard var.c Log: Fixed debug_zval_dump() to support private and protected members http://cvs.php.net/viewcvs.cgi/php-src/ext/standard/var.c?r1=1.223&r2=1.224&diff_format=u Index: php-src/ext/standard/var.c diff -u php-src/ext/standard/var.c:1.223 php-src/ext/standard/var.c:1.224 --- php-src/ext/standard/var.c:1.223 Thu Mar 2 13:12:45 2006 +++ php-src/ext/standard/var.c Fri Mar 10 08:43:14 2006 @@ -18,7 +18,7 @@ +----------------------------------------------------------------------+ */ -/* $Id: var.c,v 1.223 2006/03/02 13:12:45 dmitry Exp $ */ +/* $Id: var.c,v 1.224 2006/03/10 08:43:14 dmitry Exp $ */ @@ -338,12 +338,46 @@ return 0; } +static int zval_object_property_dump(zval **zv, int num_args, va_list args, zend_hash_key *hash_key) +{ + int level; + zstr prop_name, class_name; + int verbose; + TSRMLS_FETCH(); + + level = va_arg(args, int); + verbose = va_arg(args, int); + + if (hash_key->nKeyLength ==0 ) { /* numeric key */ + php_printf("%*c[%ld]=>\n", level + 1, ' ', hash_key->h); + } else { /* string key */ + int is_unicode = hash_key->type == IS_UNICODE; + + zend_u_unmangle_property_name(hash_key->type, hash_key->arKey, &class_name, &prop_name); + php_printf("%*c[", level + 1, ' '); + + if (class_name.s) { + if (class_name.s[0]=='*') { + php_printf("%s\"%R\":protected", is_unicode ? "u" : "", hash_key->type, prop_name); + } else { + php_printf("%s\"%R\":%s\"%R\":private", is_unicode ? "u" : "", hash_key->type, prop_name, is_unicode ? "u" : "", hash_key->type, class_name); + } + } else { + php_printf("%s\"%R\"", is_unicode ? "u" : "", hash_key->type, prop_name); + } + ZEND_PUTS("]=>\n"); + } + php_debug_zval_dump(zv, level + 2, 1 TSRMLS_CC); + return 0; +} + PHPAPI void php_debug_zval_dump(zval **struc, int level, int verbose TSRMLS_DC) { HashTable *myht = NULL; zstr class_name; zend_uint class_name_len; zend_class_entry *ce; + int (*zval_element_dump_func)(zval**, int, va_list, zend_hash_key*); if (level > 1) { php_printf("%*c", level - 1, ' '); @@ -379,6 +413,7 @@ return; } php_printf("%sarray(%d) refcount(%u){\n", COMMON, zend_hash_num_elements(myht), Z_REFCOUNT_PP(struc)); + zval_element_dump_func = zval_array_element_dump; goto head_done; case IS_OBJECT: myht = Z_OBJPROP_PP(struc); @@ -390,9 +425,10 @@ Z_OBJ_HANDLER(**struc, get_class_name)(*struc, &class_name, &class_name_len, 0 TSRMLS_CC); php_printf("%sobject(%v)#%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.v); + zval_element_dump_func = zval_object_property_dump; head_done: if (myht) { - zend_hash_apply_with_arguments(myht, (apply_func_args_t) zval_array_element_dump, 1, level, (Z_TYPE_PP(struc) == IS_ARRAY ? 0 : 1)); + 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 (level > 1) { php_printf("%*c", level-1, ' ');
-- PHP CVS Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php