<?php 
/**  
 * @version V4.93 10 Oct 2006 (c) 2000-2012 John Lim (jlim#natsoft.com). 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; 
} 
?>
 
 |