From 6a7f43cfa007b1550eae91f885b64fa0a16b11eb Mon Sep 17 00:00:00 2001 From: Antony Dovgal Date: Mon, 13 Nov 2006 19:32:43 +0000 Subject: [PATCH] improve the fix and the test --- ext/filter/filter.c | 6 ++++-- ext/filter/tests/039.phpt | 37 +++++++++++++++++++++++++++++++++++++ 2 files changed, 41 insertions(+), 2 deletions(-) diff --git a/ext/filter/filter.c b/ext/filter/filter.c index 56f2c27818..0fc5cc01a6 100644 --- a/ext/filter/filter.c +++ b/ext/filter/filter.c @@ -615,14 +615,16 @@ static void php_filter_array_handler(zval *input, zval **op, zval *return_value zval **tmp, **arg_elm; if (!op) { - SEPARATE_ZVAL(&input); + zval_dtor(return_value); *return_value = *input; zval_copy_ctor(return_value); + INIT_PZVAL(return_value); php_filter_call(&return_value, FILTER_DEFAULT, NULL, 0, FILTER_REQUIRE_ARRAY TSRMLS_CC); } else if (Z_TYPE_PP(op) == IS_LONG) { - SEPARATE_ZVAL(&input); + zval_dtor(return_value); *return_value = *input; zval_copy_ctor(return_value); + INIT_PZVAL(return_value); php_filter_call(&return_value, Z_LVAL_PP(op), NULL, 0, FILTER_REQUIRE_ARRAY TSRMLS_CC); } else if (Z_TYPE_PP(op) == IS_ARRAY) { array_init(return_value); diff --git a/ext/filter/tests/039.phpt b/ext/filter/tests/039.phpt index 7a3ac9346f..8b2d31e213 100644 --- a/ext/filter/tests/039.phpt +++ b/ext/filter/tests/039.phpt @@ -28,6 +28,19 @@ var_dump(filter_var_array(array("var_name"=>""), array("var_name"=>-1))); var_dump(filter_var_array(array("var_name"=>""), array("var_name"=>-1, "asdas"=>"asdasd", "qwe"=>"rty", ""=>""))); var_dump(filter_var_array(array("asdas"=>"text"), array("var_name"=>-1, "asdas"=>"asdasd", "qwe"=>"rty", ""=>""))); + +$a = array(""=>""); $b = -1; +var_dump(filter_var_array($a, $b)); +var_dump($a, $b); + +$a = array(""=>""); $b = 100000; +var_dump(filter_var_array($a, $b)); +var_dump($a, $b); + +$a = array(""=>""); $b = ""; +var_dump(filter_var_array($a, $b)); +var_dump($a, $b); + echo "Done\n"; ?> --EXPECTF-- @@ -99,4 +112,28 @@ array(4) { [""]=> NULL } +array(1) { + [""]=> + string(0) "" +} +array(1) { + [""]=> + string(0) "" +} +int(-1) +array(1) { + [""]=> + string(0) "" +} +array(1) { + [""]=> + string(0) "" +} +int(100000) +bool(false) +array(1) { + [""]=> + string(0) "" +} +string(0) "" Done -- 2.50.1