public
Description: Git mirror of the CMS Made Simple 2.0 rewrite
Homepage: http://cmsmadesimple.org
Clone URL: git://github.com/tedkulp/cmsmadesimple-2-0.git
cmsmadesimple-2-0 / lib / adodb5 / rsfilter.inc.php
100644 61 lines (54 sloc) 1.513 kb
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-2008 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;
}
?>