C:\xampp\php\pear\adodb\rsfilter.inc.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
<?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;
}
?>
x

Windows NT KPTV 6.2 build 9200 (Windows Server 2012 Datacenter Edition) i586