123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321 |
- <?php
- /*
- Copyright (c) 2009-2014 F3::Factory/Bong Cosca, All rights reserved.
- This file is part of the Fat-Free Framework (http://fatfree.sf.net).
- THE SOFTWARE AND DOCUMENTATION ARE PROVIDED "AS IS" WITHOUT WARRANTY OF
- ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
- IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR
- PURPOSE.
- Please see the license.txt file for more information.
- */
- namespace DB;
- //! Simple cursor implementation
- abstract class Cursor extends \Magic {
- //@{ Error messages
- const
- E_Field='Undefined field %s';
- //@}
- protected
- //! Query results
- $query=array(),
- //! Current position
- $ptr=0,
- //! Event listeners
- $trigger=array();
- /**
- * Return database type
- * @return string
- **/
- abstract function dbtype();
- /**
- * Return fields of mapper object as an associative array
- * @return array
- * @param $obj object
- **/
- abstract function cast($obj=NULL);
- /**
- * Return records (array of mapper objects) that match criteria
- * @return array
- * @param $filter string|array
- * @param $options array
- * @param $ttl int
- **/
- abstract function find($filter=NULL,array $options=NULL,$ttl=0);
- /**
- * Count records that match criteria
- * @return int
- * @param $filter array
- * @param $ttl int
- **/
- abstract function count($filter=NULL,$ttl=0);
- /**
- * Insert new record
- * @return array
- **/
- abstract function insert();
- /**
- * Update current record
- * @return array
- **/
- abstract function update();
- /**
- * Hydrate mapper object using hive array variable
- * @return NULL
- * @param $key string
- * @param $func callback
- **/
- abstract function copyfrom($key,$func=NULL);
- /**
- * Populate hive array variable with mapper fields
- * @return NULL
- * @param $key string
- **/
- abstract function copyto($key);
- /**
- * Return TRUE if current cursor position is not mapped to any record
- * @return bool
- **/
- function dry() {
- return empty($this->query[$this->ptr]);
- }
- /**
- * Return first record (mapper object) that matches criteria
- * @return object|FALSE
- * @param $filter string|array
- * @param $options array
- * @param $ttl int
- **/
- function findone($filter=NULL,array $options=NULL,$ttl=0) {
- return ($data=$this->find($filter,$options,$ttl))?$data[0]:FALSE;
- }
- /**
- * Return array containing subset of records matching criteria,
- * total number of records in superset, specified limit, number of
- * subsets available, and actual subset position
- * @return array
- * @param $pos int
- * @param $size int
- * @param $filter string|array
- * @param $options array
- * @param $ttl int
- **/
- function paginate(
- $pos=0,$size=10,$filter=NULL,array $options=NULL,$ttl=0) {
- $total=$this->count($filter,$ttl);
- $count=ceil($total/$size);
- $pos=max(0,min($pos,$count-1));
- return array(
- 'subset'=>$this->find($filter,
- array_merge(
- $options?:array(),
- array('limit'=>$size,'offset'=>$pos*$size)
- ),
- $ttl
- ),
- 'total'=>$total,
- 'limit'=>$size,
- 'count'=>$count,
- 'pos'=>$pos<$count?$pos:0
- );
- }
- /**
- * Map to first record that matches criteria
- * @return array|FALSE
- * @param $filter string|array
- * @param $options array
- * @param $ttl int
- **/
- function load($filter=NULL,array $options=NULL,$ttl=0) {
- return ($this->query=$this->find($filter,$options,$ttl)) &&
- $this->skip(0)?$this->query[$this->ptr=0]:FALSE;
- }
- /**
- * Return the count of records loaded
- * @return int
- **/
- function loaded() {
- return count($this->query);
- }
- /**
- * Map to first record in cursor
- * @return mixed
- **/
- function first() {
- return $this->skip(-$this->ptr);
- }
- /**
- * Map to last record in cursor
- * @return mixed
- **/
- function last() {
- return $this->skip(($ofs=count($this->query)-$this->ptr)?$ofs-1:0);
- }
- /**
- * Map to nth record relative to current cursor position
- * @return mixed
- * @param $ofs int
- **/
- function skip($ofs=1) {
- $this->ptr+=$ofs;
- return $this->ptr>-1 && $this->ptr<count($this->query)?
- $this->query[$this->ptr]:FALSE;
- }
- /**
- * Map next record
- * @return mixed
- **/
- function next() {
- return $this->skip();
- }
- /**
- * Map previous record
- * @return mixed
- **/
- function prev() {
- return $this->skip(-1);
- }
- /**
- * Save mapped record
- * @return mixed
- **/
- function save() {
- return $this->query?$this->update():$this->insert();
- }
- /**
- * Delete current record
- * @return int|bool
- **/
- function erase() {
- $this->query=array_slice($this->query,0,$this->ptr,TRUE)+
- array_slice($this->query,$this->ptr,NULL,TRUE);
- $this->ptr=0;
- }
- /**
- * Define onload trigger
- * @return callback
- * @param $func callback
- **/
- function onload($func) {
- return $this->trigger['load']=$func;
- }
- /**
- * Define beforeinsert trigger
- * @return callback
- * @param $func callback
- **/
- function beforeinsert($func) {
- return $this->trigger['beforeinsert']=$func;
- }
- /**
- * Define afterinsert trigger
- * @return callback
- * @param $func callback
- **/
- function afterinsert($func) {
- return $this->trigger['afterinsert']=$func;
- }
- /**
- * Define oninsert trigger
- * @return callback
- * @param $func callback
- **/
- function oninsert($func) {
- return $this->afterinsert($func);
- }
- /**
- * Define beforeupdate trigger
- * @return callback
- * @param $func callback
- **/
- function beforeupdate($func) {
- return $this->trigger['beforeupdate']=$func;
- }
- /**
- * Define afterupdate trigger
- * @return callback
- * @param $func callback
- **/
- function afterupdate($func) {
- return $this->trigger['afterupdate']=$func;
- }
- /**
- * Define onupdate trigger
- * @return callback
- * @param $func callback
- **/
- function onupdate($func) {
- return $this->afterupdate($func);
- }
- /**
- * Define beforeerase trigger
- * @return callback
- * @param $func callback
- **/
- function beforeerase($func) {
- return $this->trigger['beforeerase']=$func;
- }
- /**
- * Define aftererase trigger
- * @return callback
- * @param $func callback
- **/
- function aftererase($func) {
- return $this->trigger['aftererase']=$func;
- }
- /**
- * Define onerase trigger
- * @return callback
- * @param $func callback
- **/
- function onerase($func) {
- return $this->aftererase($func);
- }
- /**
- * Reset cursor
- * @return NULL
- **/
- function reset() {
- $this->query=array();
- $this->ptr=0;
- }
- }
|