<?php /** * @version V4.93 10 Oct 2006 (c) 2000-2007 John Lim (jlim#natsoft.com.my). All rights reserved. * Released under both BSD license and Lesser GPL library license. * Whenever there is any discrepancy between the two licenses, * the BSD license will take precedence. * * Set tabs to 4 for best viewing. * * Latest version is available at http://php.weblogs.com * * Requires PHP4.01pl2 or later because it uses include_once */ /* Filter all fields and all rows in a recordset and returns the processed recordset. We scroll to the beginning of the new recordset after processing. We pass a recordset and function name to RSFilter($rs,'rowfunc'); and the function will be called multiple times, once for each row in the recordset. The function will be passed an array containing one row repeatedly. Example: // ucwords() every element in the recordset function do_ucwords(&$arr,$rs) { foreach($arr as $k => $v) { $arr[$k] = ucwords($v); } } $rs = RSFilter($rs,'do_ucwords'); */ function &RSFilter($rs,$fn) { if ($rs->databaseType != 'array') { if (!$rs->connection) return false; $rs = &$rs->connection->_rs2rs($rs); } $rows = $rs->RecordCount(); for ($i=0; $i < $rows; $i++) { if (is_array ($fn)) { $obj = $fn[0]; $method = $fn[1]; $obj->$method ($rs->_array[$i],$rs); } else { $fn($rs->_array[$i],$rs); } } if (!$rs->EOF) { $rs->_currentRow = 0; $rs->fields = $rs->_array[0]; } return $rs; } ?>