]> granicus.if.org Git - php/commitdiff
Fixed var_dump() crash when there is recursion.
authorYasuo Ohgaki <yohgaki@php.net>
Thu, 14 Mar 2002 09:36:13 +0000 (09:36 +0000)
committerYasuo Ohgaki <yohgaki@php.net>
Thu, 14 Mar 2002 09:36:13 +0000 (09:36 +0000)
# Since I said it's easy to fix :)

ext/standard/var.c

index 65fa4e94315f36d35ba64bbc6e3172b71da68303..3604d74b0c1006f90c33b8c7390d75eb84a31c4c 100644 (file)
@@ -60,6 +60,7 @@ static int php_array_element_dump(zval **zv, int num_args, va_list args, zend_ha
 void php_var_dump(zval **struc, int level TSRMLS_DC)
 {
        HashTable *myht;
+       zend_object *object = NULL;
 
        if (level > 1) {
                php_printf("%*c", level - 1, ' ');
@@ -85,13 +86,31 @@ void php_var_dump(zval **struc, int level TSRMLS_DC)
                break;
        case IS_ARRAY:
                myht = Z_ARRVAL_PP(struc);
+               if (++((*struc)->value.ht->nApplyCount) > 1) {
+                       PUTS("*RECURSION*\n");
+                       (*struc)->value.ht->nApplyCount = 0;
+                       break;
+               }
                php_printf("%sarray(%d) {\n", COMMON, zend_hash_num_elements(myht));
                goto head_done;
        case IS_OBJECT:
+               object = Z_OBJ_PP(struc);
+               if (++object->properties->nApplyCount > 1) {
+                       PUTS("*RECURSION*\n");
+                       object->properties->nApplyCount = 0;
+                       return;
+               }
                myht = Z_OBJPROP_PP(struc);
                php_printf("%sobject(%s)(%d) {\n", COMMON, Z_OBJCE_PP(struc)->name, zend_hash_num_elements(myht));
 head_done:
+               myht = Z_ARRVAL_PP(struc);
                zend_hash_apply_with_arguments(myht, (apply_func_args_t) php_array_element_dump, 1, level);
+               if (Z_TYPE_PP(struc) == IS_ARRAY) {
+                       (*struc)->value.ht->nApplyCount--;
+               }
+               else {
+                       object->properties->nApplyCount--;
+               }
                if (level > 1) {
                        php_printf("%*c", level-1, ' ');
                }