mirror of
https://github.com/php/php-src.git
synced 2025-08-16 14:08:47 +02:00
var_dump(): Don't skip recursion detection on first level
This is confusing. The current output doesn't make it clear that we're in fact recursing to the top-level structure. Closes GH-5171.
This commit is contained in:
parent
9e5650265c
commit
ae6f45ad45
13 changed files with 23 additions and 164 deletions
|
@ -13,10 +13,6 @@ $a = null;
|
||||||
?>
|
?>
|
||||||
--EXPECT--
|
--EXPECT--
|
||||||
array(3) {
|
array(3) {
|
||||||
[0]=>
|
|
||||||
int(2)
|
|
||||||
[1]=>
|
|
||||||
&array(3) {
|
|
||||||
[0]=>
|
[0]=>
|
||||||
int(2)
|
int(2)
|
||||||
[1]=>
|
[1]=>
|
||||||
|
@ -24,13 +20,3 @@ array(3) {
|
||||||
[2]=>
|
[2]=>
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
}
|
}
|
||||||
[2]=>
|
|
||||||
&array(3) {
|
|
||||||
[0]=>
|
|
||||||
int(2)
|
|
||||||
[1]=>
|
|
||||||
*RECURSION*
|
|
||||||
[2]=>
|
|
||||||
*RECURSION*
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -47,11 +47,8 @@ array(1) {
|
||||||
["this"]=>
|
["this"]=>
|
||||||
object(foo)#%d (1) {
|
object(foo)#%d (1) {
|
||||||
["a"]=>
|
["a"]=>
|
||||||
array(1) {
|
|
||||||
[0]=>
|
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
int(1)
|
int(1)
|
||||||
|
|
|
@ -14,9 +14,6 @@ foreach (($a = array('a' => array('a' => &$a))) as $a) {
|
||||||
?>
|
?>
|
||||||
--EXPECT--
|
--EXPECT--
|
||||||
array(1) {
|
array(1) {
|
||||||
["a"]=>
|
|
||||||
&array(1) {
|
|
||||||
["a"]=>
|
["a"]=>
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
|
@ -13,11 +13,8 @@ echo "ok\n"
|
||||||
?>
|
?>
|
||||||
--EXPECT--
|
--EXPECT--
|
||||||
array(1) {
|
array(1) {
|
||||||
[0]=>
|
|
||||||
&array(1) {
|
|
||||||
[0]=>
|
[0]=>
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
}
|
}
|
||||||
}
|
|
||||||
int(1)
|
int(1)
|
||||||
ok
|
ok
|
||||||
|
|
|
@ -14,12 +14,9 @@ echo "ok\n"
|
||||||
?>
|
?>
|
||||||
--EXPECT--
|
--EXPECT--
|
||||||
array(1) {
|
array(1) {
|
||||||
[0]=>
|
|
||||||
&array(1) {
|
|
||||||
[0]=>
|
[0]=>
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
}
|
}
|
||||||
}
|
|
||||||
int(0)
|
int(0)
|
||||||
int(1)
|
int(1)
|
||||||
ok
|
ok
|
||||||
|
|
|
@ -14,11 +14,8 @@ echo "ok\n"
|
||||||
?>
|
?>
|
||||||
--EXPECT--
|
--EXPECT--
|
||||||
array(1) {
|
array(1) {
|
||||||
[0]=>
|
|
||||||
&array(1) {
|
|
||||||
[0]=>
|
[0]=>
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
}
|
}
|
||||||
}
|
|
||||||
int(1)
|
int(1)
|
||||||
ok
|
ok
|
||||||
|
|
|
@ -24,12 +24,9 @@ echo "Done\n";
|
||||||
?>
|
?>
|
||||||
--EXPECTF--
|
--EXPECTF--
|
||||||
array(1) {
|
array(1) {
|
||||||
[0]=>
|
|
||||||
&array(1) {
|
|
||||||
[0]=>
|
[0]=>
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
bool(false)
|
bool(false)
|
||||||
int(6)
|
int(6)
|
||||||
|
|
|
@ -40,16 +40,6 @@ array(4) {
|
||||||
Warning: mb_convert_variables(): %s on line %d
|
Warning: mb_convert_variables(): %s on line %d
|
||||||
bool(false)
|
bool(false)
|
||||||
array(5) {
|
array(5) {
|
||||||
[0]=>
|
|
||||||
string(21) "日本語テキスト"
|
|
||||||
[1]=>
|
|
||||||
string(21) "日本語テキスト"
|
|
||||||
[2]=>
|
|
||||||
string(21) "日本語テキスト"
|
|
||||||
[3]=>
|
|
||||||
string(21) "日本語テキスト"
|
|
||||||
[4]=>
|
|
||||||
&array(5) {
|
|
||||||
[0]=>
|
[0]=>
|
||||||
string(21) "日本語テキスト"
|
string(21) "日本語テキスト"
|
||||||
[1]=>
|
[1]=>
|
||||||
|
@ -61,4 +51,3 @@ array(5) {
|
||||||
[4]=>
|
[4]=>
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
|
@ -31,14 +31,6 @@ string(2) "v1"
|
||||||
string(2) "v2"
|
string(2) "v2"
|
||||||
string(2) "v1"
|
string(2) "v1"
|
||||||
array(4) {
|
array(4) {
|
||||||
["k1"]=>
|
|
||||||
&string(2) "v1"
|
|
||||||
["k2"]=>
|
|
||||||
string(2) "v2"
|
|
||||||
[0]=>
|
|
||||||
&string(2) "v1"
|
|
||||||
[1]=>
|
|
||||||
&array(4) {
|
|
||||||
["k1"]=>
|
["k1"]=>
|
||||||
&string(2) "v1"
|
&string(2) "v1"
|
||||||
["k2"]=>
|
["k2"]=>
|
||||||
|
@ -48,7 +40,6 @@ array(4) {
|
||||||
[1]=>
|
[1]=>
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
}
|
}
|
||||||
}
|
|
||||||
array(4) {
|
array(4) {
|
||||||
["k1"]=>
|
["k1"]=>
|
||||||
array(1) {
|
array(1) {
|
||||||
|
@ -84,14 +75,6 @@ string(2) "v1"
|
||||||
string(2) "v2"
|
string(2) "v2"
|
||||||
string(2) "v1"
|
string(2) "v1"
|
||||||
array(4) {
|
array(4) {
|
||||||
["k1"]=>
|
|
||||||
&string(2) "v1"
|
|
||||||
["k2"]=>
|
|
||||||
string(2) "v2"
|
|
||||||
[0]=>
|
|
||||||
&string(2) "v1"
|
|
||||||
[1]=>
|
|
||||||
&array(4) {
|
|
||||||
["k1"]=>
|
["k1"]=>
|
||||||
&string(2) "v1"
|
&string(2) "v1"
|
||||||
["k2"]=>
|
["k2"]=>
|
||||||
|
@ -101,7 +84,6 @@ array(4) {
|
||||||
[1]=>
|
[1]=>
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
}
|
}
|
||||||
}
|
|
||||||
array(4) {
|
array(4) {
|
||||||
[0]=>
|
[0]=>
|
||||||
array(1) {
|
array(1) {
|
||||||
|
@ -134,14 +116,6 @@ array(4) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
array(4) {
|
array(4) {
|
||||||
["k1"]=>
|
|
||||||
&string(2) "v1"
|
|
||||||
["k2"]=>
|
|
||||||
string(2) "v2"
|
|
||||||
[0]=>
|
|
||||||
&string(2) "v1"
|
|
||||||
[1]=>
|
|
||||||
&array(4) {
|
|
||||||
["k1"]=>
|
["k1"]=>
|
||||||
&string(2) "v1"
|
&string(2) "v1"
|
||||||
["k2"]=>
|
["k2"]=>
|
||||||
|
@ -151,7 +125,6 @@ array(4) {
|
||||||
[1]=>
|
[1]=>
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
}
|
}
|
||||||
}
|
|
||||||
array(4) {
|
array(4) {
|
||||||
[0]=>
|
[0]=>
|
||||||
array(2) {
|
array(2) {
|
||||||
|
|
|
@ -25,16 +25,6 @@ echo "Done";
|
||||||
--EXPECT--
|
--EXPECT--
|
||||||
*** Testing natcasesort() : usage variations ***
|
*** Testing natcasesort() : usage variations ***
|
||||||
array(5) {
|
array(5) {
|
||||||
[0]=>
|
|
||||||
int(1)
|
|
||||||
[1]=>
|
|
||||||
float(3)
|
|
||||||
[2]=>
|
|
||||||
string(4) "zero"
|
|
||||||
[3]=>
|
|
||||||
string(1) "2"
|
|
||||||
[4]=>
|
|
||||||
&array(5) {
|
|
||||||
[0]=>
|
[0]=>
|
||||||
int(1)
|
int(1)
|
||||||
[1]=>
|
[1]=>
|
||||||
|
@ -46,17 +36,8 @@ array(5) {
|
||||||
[4]=>
|
[4]=>
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
}
|
}
|
||||||
}
|
|
||||||
bool(true)
|
bool(true)
|
||||||
array(5) {
|
array(5) {
|
||||||
[0]=>
|
|
||||||
int(1)
|
|
||||||
[3]=>
|
|
||||||
string(1) "2"
|
|
||||||
[1]=>
|
|
||||||
float(3)
|
|
||||||
[4]=>
|
|
||||||
&array(5) {
|
|
||||||
[0]=>
|
[0]=>
|
||||||
int(1)
|
int(1)
|
||||||
[3]=>
|
[3]=>
|
||||||
|
@ -68,7 +49,4 @@ array(5) {
|
||||||
[2]=>
|
[2]=>
|
||||||
string(4) "zero"
|
string(4) "zero"
|
||||||
}
|
}
|
||||||
[2]=>
|
|
||||||
string(4) "zero"
|
|
||||||
}
|
|
||||||
Done
|
Done
|
||||||
|
|
|
@ -54,8 +54,6 @@ echo "Done";
|
||||||
--EXPECT--
|
--EXPECT--
|
||||||
--- 1 refs container:
|
--- 1 refs container:
|
||||||
array(3) {
|
array(3) {
|
||||||
[0]=>
|
|
||||||
&array(3) {
|
|
||||||
[0]=>
|
[0]=>
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
[1]=>
|
[1]=>
|
||||||
|
@ -63,11 +61,6 @@ array(3) {
|
||||||
[2]=>
|
[2]=>
|
||||||
int(1)
|
int(1)
|
||||||
}
|
}
|
||||||
[1]=>
|
|
||||||
int(1)
|
|
||||||
[2]=>
|
|
||||||
int(1)
|
|
||||||
}
|
|
||||||
string(56) "a:3:{i:0;a:3:{i:0;R:2;i:1;i:1;i:2;i:1;}i:1;i:1;i:2;i:1;}"
|
string(56) "a:3:{i:0;a:3:{i:0;R:2;i:1;i:1;i:2;i:1;}i:1;i:1;i:2;i:1;}"
|
||||||
array(3) {
|
array(3) {
|
||||||
[0]=>
|
[0]=>
|
||||||
|
@ -112,8 +105,6 @@ array(3) {
|
||||||
|
|
||||||
--- 1,2 ref container:
|
--- 1,2 ref container:
|
||||||
array(3) {
|
array(3) {
|
||||||
[0]=>
|
|
||||||
&array(3) {
|
|
||||||
[0]=>
|
[0]=>
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
[1]=>
|
[1]=>
|
||||||
|
@ -121,18 +112,6 @@ array(3) {
|
||||||
[2]=>
|
[2]=>
|
||||||
int(1)
|
int(1)
|
||||||
}
|
}
|
||||||
[1]=>
|
|
||||||
&array(3) {
|
|
||||||
[0]=>
|
|
||||||
*RECURSION*
|
|
||||||
[1]=>
|
|
||||||
*RECURSION*
|
|
||||||
[2]=>
|
|
||||||
int(1)
|
|
||||||
}
|
|
||||||
[2]=>
|
|
||||||
int(1)
|
|
||||||
}
|
|
||||||
string(56) "a:3:{i:0;a:3:{i:0;R:2;i:1;R:2;i:2;i:1;}i:1;R:2;i:2;i:1;}"
|
string(56) "a:3:{i:0;a:3:{i:0;R:2;i:1;R:2;i:2;i:1;}i:1;R:2;i:2;i:1;}"
|
||||||
array(3) {
|
array(3) {
|
||||||
[0]=>
|
[0]=>
|
||||||
|
@ -184,8 +163,6 @@ array(3) {
|
||||||
|
|
||||||
--- 1,2,3 ref container:
|
--- 1,2,3 ref container:
|
||||||
array(3) {
|
array(3) {
|
||||||
[0]=>
|
|
||||||
&array(3) {
|
|
||||||
[0]=>
|
[0]=>
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
[1]=>
|
[1]=>
|
||||||
|
@ -193,25 +170,6 @@ array(3) {
|
||||||
[2]=>
|
[2]=>
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
}
|
}
|
||||||
[1]=>
|
|
||||||
&array(3) {
|
|
||||||
[0]=>
|
|
||||||
*RECURSION*
|
|
||||||
[1]=>
|
|
||||||
*RECURSION*
|
|
||||||
[2]=>
|
|
||||||
*RECURSION*
|
|
||||||
}
|
|
||||||
[2]=>
|
|
||||||
&array(3) {
|
|
||||||
[0]=>
|
|
||||||
*RECURSION*
|
|
||||||
[1]=>
|
|
||||||
*RECURSION*
|
|
||||||
[2]=>
|
|
||||||
*RECURSION*
|
|
||||||
}
|
|
||||||
}
|
|
||||||
string(56) "a:3:{i:0;a:3:{i:0;R:2;i:1;R:2;i:2;R:2;}i:1;R:2;i:2;R:2;}"
|
string(56) "a:3:{i:0;a:3:{i:0;R:2;i:1;R:2;i:2;R:2;}i:1;R:2;i:2;R:2;}"
|
||||||
array(3) {
|
array(3) {
|
||||||
[0]=>
|
[0]=>
|
||||||
|
|
|
@ -435,16 +435,9 @@ array(3) {
|
||||||
[0]=>
|
[0]=>
|
||||||
int(1)
|
int(1)
|
||||||
[1]=>
|
[1]=>
|
||||||
&array(3) {
|
|
||||||
[0]=>
|
|
||||||
int(1)
|
|
||||||
[1]=>
|
|
||||||
int(1)
|
|
||||||
[2]=>
|
|
||||||
*RECURSION*
|
*RECURSION*
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
string(74) "a:3:{i:0;i:1;i:1;i:1;i:2;a:2:{i:0;i:1;i:1;a:3:{i:0;i:1;i:1;i:1;i:2;R:4;}}}"
|
string(74) "a:3:{i:0;i:1;i:1;i:1;i:2;a:2:{i:0;i:1;i:1;a:3:{i:0;i:1;i:1;i:1;i:2;R:4;}}}"
|
||||||
array(3) {
|
array(3) {
|
||||||
[0]=>
|
[0]=>
|
||||||
|
|
|
@ -123,7 +123,7 @@ again:
|
||||||
break;
|
break;
|
||||||
case IS_ARRAY:
|
case IS_ARRAY:
|
||||||
myht = Z_ARRVAL_P(struc);
|
myht = Z_ARRVAL_P(struc);
|
||||||
if (level > 1 && !(GC_FLAGS(myht) & GC_IMMUTABLE)) {
|
if (!(GC_FLAGS(myht) & GC_IMMUTABLE)) {
|
||||||
if (GC_IS_RECURSIVE(myht)) {
|
if (GC_IS_RECURSIVE(myht)) {
|
||||||
PUTS("*RECURSION*\n");
|
PUTS("*RECURSION*\n");
|
||||||
return;
|
return;
|
||||||
|
@ -136,7 +136,7 @@ again:
|
||||||
ZEND_HASH_FOREACH_KEY_VAL_IND(myht, num, key, val) {
|
ZEND_HASH_FOREACH_KEY_VAL_IND(myht, num, key, val) {
|
||||||
php_array_element_dump(val, num, key, level);
|
php_array_element_dump(val, num, key, level);
|
||||||
} ZEND_HASH_FOREACH_END();
|
} ZEND_HASH_FOREACH_END();
|
||||||
if (level > 1 && !(GC_FLAGS(myht) & GC_IMMUTABLE)) {
|
if (!(GC_FLAGS(myht) & GC_IMMUTABLE)) {
|
||||||
GC_UNPROTECT_RECURSION(myht);
|
GC_UNPROTECT_RECURSION(myht);
|
||||||
}
|
}
|
||||||
if (level > 1) {
|
if (level > 1) {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue