lstrojny Wed Aug 20 20:35:16 2008 UTC
Added files:
/php-src/ext/standard/tests/array array_reduce.phpt
Modified files:
/php-src/ext/standard array.c
Log:
Allow mixed $initial (patch by Christian Seiler)
http://cvs.php.net/viewvc.cgi/php-src/ext/standard/array.c?r1=1.461&r2=1.462&diff_format=u
Index: php-src/ext/standard/array.c
diff -u php-src/ext/standard/array.c:1.461 php-src/ext/standard/array.c:1.462
--- php-src/ext/standard/array.c:1.461 Sun Aug 17 22:11:21 2008
+++ php-src/ext/standard/array.c Wed Aug 20 20:35:16 2008
@@ -21,7 +21,7 @@
+----------------------------------------------------------------------+
*/
-/* $Id: array.c,v 1.461 2008/08/17 22:11:21 felipe Exp $ */
+/* $Id: array.c,v 1.462 2008/08/20 20:35:16 lstrojny Exp $ */
#include "php.h"
#include "php_ini.h"
@@ -4296,7 +4296,7 @@
}
/* }}} */
-/* {{{ proto mixed array_reduce(array input, mixed callback [, int initial]) U
+/* {{{ proto mixed array_reduce(array input, mixed callback [, mixed initial])
U
Iteratively reduce the array to a single value via the callback. */
PHP_FUNCTION(array_reduce)
{
@@ -4307,18 +4307,19 @@
zval *retval;
zend_fcall_info fci;
zend_fcall_info_cache fci_cache = empty_fcall_info_cache;
- long initial;
+ zval *initial;
HashPosition pos;
HashTable *htbl;
- if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "af|l", &input,
&fci, &fci_cache, &initial) == FAILURE) {
+ if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "af|z", &input,
&fci, &fci_cache, &initial) == FAILURE) {
return;
}
if (ZEND_NUM_ARGS() > 2) {
ALLOC_ZVAL(result);
+ *result = *initial;
+ zval_copy_ctor(result);
INIT_PZVAL(result);
- ZVAL_LONG(result, initial);
} else {
MAKE_STD_ZVAL(result);
ZVAL_NULL(result);
http://cvs.php.net/viewvc.cgi/php-src/ext/standard/tests/array/array_reduce.phpt?view=markup&rev=1.1
Index: php-src/ext/standard/tests/array/array_reduce.phpt
+++ php-src/ext/standard/tests/array/array_reduce.phpt
--TEST--
Test array_reduce() function
--INI--
precision=14
--FILE--
<?php
/* Prototype: array array_reduce(array $array, mixed $callback, mixed $initial);
Description: Iteratively reduce the array to a single value via the callback
*/
$array = array('foo', 'foo', 'bar', 'qux', 'qux', 'quux');
echo "\n*** Testing array_reduce() to integer ***\n";
function reduce_int($w, $v) { return $w + strlen($v); }
$initial = 42;
var_dump(array_reduce($array, 'reduce_int', $initial), $initial);
echo "\n*** Testing array_reduce() to float ***\n";
function reduce_float($w, $v) { return $w + strlen($v) / 10; }
$initial = 4.2;
var_dump(array_reduce($array, 'reduce_float', $initial), $initial);
echo "\n*** Testing array_reduce() to string ***\n";
function reduce_string($w, $v) { return $w . $v; }
$initial = 'quux';
var_dump(array_reduce($array, 'reduce_string', $initial), $initial);
echo "\n*** Testing array_reduce() to array ***\n";
function reduce_array($w, $v) { $w[$v]++; return $w; }
$initial = array('foo' => 42, 'bar' => 17, 'qux' => -2, 'quux' => 0);
var_dump(array_reduce($array, 'reduce_array', $initial), $initial);
echo "\n*** Testing array_reduce() to null ***\n";
function reduce_null($w, $v) { return $w . $v; }
$initial = null;
var_dump(array_reduce($array, 'reduce_null', $initial), $initial);
echo "\nDone";
?>
--EXPECTF--
*** Testing array_reduce() to integer ***
int(61)
int(42)
*** Testing array_reduce() to float ***
float(6.1)
float(4.2)
*** Testing array_reduce() to string ***
unicode(23) "quuxfoofoobarquxquxquux"
unicode(4) "quux"
*** Testing array_reduce() to array ***
array(4) {
[u"foo"]=>
int(44)
[u"bar"]=>
int(18)
[u"qux"]=>
int(0)
[u"quux"]=>
int(1)
}
array(4) {
[u"foo"]=>
int(42)
[u"bar"]=>
int(17)
[u"qux"]=>
int(-2)
[u"quux"]=>
int(0)
}
*** Testing array_reduce() to null ***
unicode(19) "foofoobarquxquxquux"
NULL
Done
--
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php