summaryrefslogtreecommitdiff
path: root/ext/standard/var.c
diff options
context:
space:
mode:
authorDerick Rethans <derick@php.net>2002-03-14 18:41:35 +0000
committerDerick Rethans <derick@php.net>2002-03-14 18:41:35 +0000
commit7935e737499718eeaa7e1e6b6114e9fc15c45c61 (patch)
treed2367eb9855c55b648696971dd793f47d28e80cb /ext/standard/var.c
parent7b3660c6e8ec661177ceedbf5b111cbc769f04bf (diff)
downloadphp-git-7935e737499718eeaa7e1e6b6114e9fc15c45c61.tar.gz
- Fix bug #16078
Diffstat (limited to 'ext/standard/var.c')
-rw-r--r--ext/standard/var.c35
1 files changed, 29 insertions, 6 deletions
diff --git a/ext/standard/var.c b/ext/standard/var.c
index b13cbf554c..515bb388a4 100644
--- a/ext/standard/var.c
+++ b/ext/standard/var.c
@@ -271,6 +271,21 @@ static int php_array_element_export(zval **zv, int num_args, va_list args, zend_
return 0;
}
+static int php_object_element_export(zval **zv, int num_args, va_list args, zend_hash_key *hash_key)
+{
+ int level;
+ TSRMLS_FETCH();
+
+ level = va_arg(args, int);
+
+ if (hash_key->nKeyLength != 0) {
+ php_printf("%*cvar $%s = ", level + 1, ' ', hash_key->arKey);
+ }
+ php_var_export(zv, level + 2 TSRMLS_CC);
+ PUTS (";\n");
+ return 0;
+}
+
void php_var_export(zval **struc, int level TSRMLS_DC)
{
HashTable *myht;
@@ -299,20 +314,28 @@ void php_var_export(zval **struc, int level TSRMLS_DC)
break;
case IS_ARRAY:
myht = Z_ARRVAL_PP(struc);
- goto head_done;
- case IS_OBJECT:
- myht = Z_OBJPROP_PP(struc);
-head_done:
if (level > 1) {
php_printf("\n%*c", level - 1, ' ');
}
PUTS ("array (\n");
zend_hash_apply_with_arguments(myht, (apply_func_args_t) php_array_element_export, 1, level);
if (level > 1) {
- php_printf("%*c", level-1, ' ');
+ php_printf("%*c", level - 1, ' ');
}
PUTS(")");
break;
+ case IS_OBJECT:
+ myht = Z_OBJPROP_PP(struc);
+ if (level > 1) {
+ php_printf("\n%*c", level - 1, ' ');
+ }
+ php_printf ("class %s {\n", ((*struc)->value.obj.ce)->name);
+ zend_hash_apply_with_arguments(myht, (apply_func_args_t) php_object_element_export, 1, level);
+ if (level > 1) {
+ php_printf("%*c", level - 1, ' ');
+ }
+ PUTS("}");
+ break;
default:
PUTS ("NULL");
break;
@@ -323,7 +346,7 @@ head_done:
/* {{{ proto mixed var_export(mixed var [, bool return])
- Outputs or returns a string representation of avariable */
+ Outputs or returns a string representation of a variable */
PHP_FUNCTION(var_export)
{
zval *var;