Source for file jDbPDOResultSet.class.php
Documentation is available at jDbPDOResultSet.class.php
- <?php
- /**
- * @package    jelix
- * @subpackage db
- * @author     Laurent Jouanneau
- * @contributor Gwendal Jouannic, Thomas, Julien Issler
- * @copyright  2005-2010 Laurent Jouanneau
- * @copyright  2008 Gwendal Jouannic, 2009 Thomas
- * @copyright  2009 Julien Issler
- * @link      http://www.jelix.org
- * @licence  http://www.gnu.org/licenses/lgpl.html GNU Lesser General Public Licence, see LICENCE file
- */
-  
- /**
-  * a resultset based on PDOStatement
-  * @package  jelix
-  * @subpackage db
-  */
- class jDbPDOResultSet extends PDOStatement {
-  
-     protected $_fetchMode = 0;
-  
-     public function fetch ($fetch_style = null, $cursor_orientation = PDO::FETCH_ORI_NEXT, $cursor_offset = 0) {
-         // we take a shortcut: unused parameters are ignored by parent::fetch
-         // let the parent::setFetchMode override as needed, and PHP use its default
-         if ($fetch_style) {
-             $rec = parent::fetch($fetch_style, $cursor_orientation, $cursor_offset);
-         }
-         else {
-             $rec = parent::fetch();
-         }
-  
-         if ($rec && count($this->modifier)) {
-             foreach($this->modifier as $m)
-                 call_user_func_array($m, array($rec, $this));
-         }
-         return $rec;
-     }
-  
-     /**
-      * return all results from the statement.
-      * @param integer $fetch_style 
-      * @param integer $fetch_argument 
-      * @param array $ctor_arg 
-      * @return array list of object which contain all rows
-      */
-     public function fetchAll ($fetch_style = null, $fetch_argument=null, $ctor_arg=null) {
-         // if the user requested to override the style set with setFetchMode, use it
-         $final_style = ($fetch_style ?: $this->_fetchMode);
-  
-         // Check how many arguments, if available should be given
-         if (!$final_style) {
-             $records = parent::fetchAll(PDO::FETCH_OBJ);
-         }
-         else if ($ctor_arg) {
-             $records = parent::fetchAll($final_style, $fetch_argument, $ctor_arg);
-         }
-         else if ($fetch_argument) {
-             $records = parent::fetchAll($final_style, $fetch_argument);
-         }
-         else {
-             $records = parent::fetchAll($final_style);
-         }
-  
-         if (count($this->modifier)) {
-             foreach ($records as $rec)
-                 foreach($this->modifier as $m)
-                     call_user_func_array($m, array($rec, $this));
-         }
-         return $records;
-     }
-  
-     /**
-      * Set the fetch mode.
-      * @param int $mode  the mode, a PDO::FETCH_* constant
-      * @param mixed $arg1 a parameter for the given mode
-      * @param mixed $arg2 a parameter for the given mode
-      */
-     public function setFetchMode($mode, $arg1=null , $arg2=null){
-         $this->_fetchMode = $mode;
-         // depending the mode, original setFetchMode throw an error if wrong arguments
-         // are given, even if there are null
-         if ($arg1 === null)
-             return parent::setFetchMode($mode);
-         else if ($arg2 === null)
-             return parent::setFetchMode($mode, $arg1);
-         return parent::setFetchMode($mode, $arg1, $arg2);
-     }
-  
-     /**
-      * @param string $text a binary string to unescape
-      * @since 1.1.6
-      */
-     public function unescapeBin($text) {
-         return $text;
-     }
-  
-     /**
-      * a callback function which will modify on the fly record's value
-      * @var array of callback
-      * @since 1.1.6
-      */
-     protected $modifier = array();
-  
-     /**
-      * @param callback $function a callback function
-      *      the function should accept in parameter the record,
-      *      and the resulset object
-      * @since 1.1.6
-      */
-     public function addModifier($function) {
-         $this->modifier[] = $function;
-     }
- }
		Documentation generated on Wed, 04 Jan 2017 22:53:50 +0100 by phpDocumentor 1.4.3