0, 'dispatchLoopShutdown' => 0 ); protected $_closingBracket = null; /** * Creating time plugin * @return void */ public function __construct() { Zend_Controller_Front::getInstance()->registerPlugin($this); } /** * Gets identifier for this plugin * * @return string */ public function getIdentifier() { return $this->_identifier; } /** * Returns the base64 encoded icon * * @return string **/ public function getIconData() { return ''; } /** * Gets menu tab for the Debugbar * * @return string */ public function getTab() { return round($this->_timer['dispatchLoopShutdown'],2) .'/'.round($this->_timer['dispatchLoopShutdown']-$this->_timer['dispatchLoopStartup'],2). ' ms'; } /** * Gets content panel for the Debugbar * * @return string */ public function getPanel() { $html = '

Custom Timers

'; $html .= 'Dispatch: ' . round(($this->_timer['dispatchLoopShutdown']-$this->_timer['dispatchLoopStartup']),2) .' ms'.$this->getLinebreak(); if (isset($this->_timer['user']) && count($this->_timer['user'])) { foreach ($this->_timer['user'] as $name => $time) { $html .= ''.$name.': '. round($time,2).' ms'.$this->getLinebreak(); } } if (!Zend_Session::isStarted()){ Zend_Session::start(); } $request = Zend_Controller_Front::getInstance()->getRequest(); $this_module = $request->getModuleName(); $this_controller = $request->getControllerName(); $this_action = $request->getActionName(); $timerNamespace = new Zend_Session_Namespace('ZFDebug_Time',false); $timerNamespace->data[$this_module][$this_controller][$this_action][] = round($this->_timer['dispatchLoopShutdown'],2); $html .= '

Overall Timers

'; foreach ($timerNamespace->data as $module => $controller) { if ($module != $this_module) { continue; } $html .= $module . $this->getLinebreak(); $html .= '
'; foreach ($controller as $con => $action) { if ($con != $this_controller) { continue; } $html .= ' ' . $con . $this->getLinebreak(); $html .= '
'; foreach ($action as $key => $data) { if ($key != $this_action) { continue; } $html .= ' ' . $key . $this->getLinebreak(); $html .= '
'; $html .= ' Avg: ' . $this->_calcAvg($data) . ' ms / '.count($data).' requests'.$this->getLinebreak(); $html .= ' Min: ' . round(min($data), 2) . ' ms'.$this->getLinebreak(); $html .= ' Max: ' . round(max($data), 2) . ' ms'.$this->getLinebreak(); $html .= '
'; } $html .= '
'; } $html .= '
'; } $html .= $this->getLinebreak().'Reset timers by sending ZFDEBUG_RESET as a GET/POST parameter'; return $html; } /** * Sets a time mark identified with $name * * @param string $name */ public function mark($name) { if (isset($this->_timer['user'][$name])) $this->_timer['user'][$name] = (microtime(true)-$_SERVER['REQUEST_TIME'])*1000-$this->_timer['user'][$name]; else $this->_timer['user'][$name] = (microtime(true)-$_SERVER['REQUEST_TIME'])*1000; } #public function routeStartup(Zend_Controller_Request_Abstract $request) { # $this->timer['routeStartup'] = (microtime(true)-$_SERVER['REQUEST_TIME'])*1000; #} #public function routeShutdown(Zend_Controller_Request_Abstract $request) { # $this->timer['routeShutdown'] = (microtime(true)-$_SERVER['REQUEST_TIME'])*1000; #} /** * Defined by Zend_Controller_Plugin_Abstract * * @param Zend_Controller_Request_Abstract * @return void */ public function dispatchLoopStartup(Zend_Controller_Request_Abstract $request) { $reset = Zend_Controller_Front::getInstance()->getRequest()->getParam('ZFDEBUG_RESET'); if (isset($reset)) { if (!Zend_Session::isStarted()) { Zend_Session::start(); } $timerNamespace = new Zend_Session_Namespace('ZFDebug_Time',false); $timerNamespace->unsetAll(); } $this->_timer['dispatchLoopStartup'] = (microtime(true)-$_SERVER['REQUEST_TIME'])*1000; } /** * Defined by Zend_Controller_Plugin_Abstract * * @param Zend_Controller_Request_Abstract * @return void */ public function dispatchLoopShutdown() { $this->_timer['dispatchLoopShutdown'] = (microtime(true)-$_SERVER['REQUEST_TIME'])*1000; } /** * Calculate average time from $array * * @param array $array * @param int $precision * @return float */ protected function _calcAvg(array $array, $precision=2) { if (!is_array($array)) { return 'ERROR in method _calcAvg(): this is a not array'; } foreach ($array as $value) if (!is_numeric($value)) { return 'ERROR in method _calcAvg(): the array contains one or more non-numeric values'; } $cuantos=count($array); return round(array_sum($array)/$cuantos,$precision); } public function getLinebreak() { return 'getClosingBracket(); } public function getClosingBracket() { if (!$this->_closingBracket) { if ($this->_isXhtml()) { $this->_closingBracket = ' />'; } else { $this->_closingBracket = '>'; } } return $this->_closingBracket; } protected function _isXhtml() { $view = Zend_Controller_Action_HelperBroker::getStaticHelper('viewRenderer')->view; $doctype = $view->doctype(); return $doctype->isXhtml(); } }