. */ Doctrine::autoload('Doctrine_Overloadable'); /** * Doctrine_Db_Profiler * * @author Konsta Vesterinen * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @package Doctrine * @category Object Relational Mapping * @link www.phpdoctrine.com * @since 1.0 * @version $Revision$ */ class Doctrine_Db_Profiler extends Doctrine_Access implements Doctrine_Overloadable, IteratorAggregate { /** * @param array $listeners an array containing all availible listeners */ private $listeners = array('query', 'prepare', 'commit', 'rollback', 'begintransaction', 'exec', 'execute', ); /** * @param array $events an array containing all listened events */ private $events = array(); /** * constructor */ public function __construct() { } /** * setFilterQueryType * * @param integer $filter * @return boolean */ public function setFilterQueryType() { } /** * method overloader * this method is used for invoking different listeners, for the full * list of availible listeners, see Doctrine_Db_EventListener * * @param string $m the name of the method * @param array $a method arguments * @see Doctrine_Db_EventListener * @return boolean */ public function __call($m, $a) { // first argument should be an instance of Doctrine_Db_Event if ( ! ($a[0] instanceof Doctrine_Db_Event)) { throw new Doctrine_Db_Profiler_Exception("Couldn't listen event. Event should be an instance of Doctrine_Db_Event."); } // event methods should start with 'on' if (substr($m, 0, 2) !== 'on') { throw new Doctrine_Db_Profiler_Exception("Couldn't invoke listener :" . $m); } if (substr($m, 2, 3) === 'Pre' && substr($m, 2, 7) !== 'Prepare') { if ( ! in_array(strtolower(substr($m, 5)), $this->listeners)) { throw new Doctrine_Db_Profiler_Exception("Couldn't invoke listener :" . $m); } // pre-event listener found $a[0]->start(); if( ! in_array($a[0], $this->events, true)) { $this->events[] = $a[0]; } } else { if ( ! in_array(strtolower(substr($m, 2)), $this->listeners)) { throw new Doctrine_Db_Profiler_Exception("Couldn't invoke listener :" . $m); } // after-event listener found $a[0]->end(); } /** * If filtering by query type is enabled, only keep the query if * it was one of the allowed types. */ if ( ! is_null($this->filterTypes)) { if ( ! ($a[0]->getQueryType() & $this->_filterTypes)) { return false; } } return true; } /** * get * * @param mixed $key * @return Doctrine_Event */ public function get($key) { if (isset($this->events[$key])) { return $this->events[$key]; } return null; } /** * getAll * returns all profiled events as an array * * @return array all events in an array */ public function getAll() { return $this->events; } /** * getIterator * returns an iterator that iterates through the logged events * * @return ArrayIterator */ public function getIterator() { return new ArrayIterator($this->events); } /** * pop the last event from the event stack * * @return Doctrine_Db_Event */ public function pop() { return array_pop($this->events); } /** * Get the Doctrine_Db_Event object for the last query that was run, regardless if it has * ended or not. If the event has not ended, it's end time will be Null. * * @return Doctrine_Db_Event */ public function lastEvent() { if (empty($this->events)) { return false; } end($this->events); return current($this->events); } }