1
0
mirror of https://github.com/dg/dibi.git synced 2025-10-24 11:16:08 +02:00

- DibiProfiler: added some limits for Firebug

This commit is contained in:
David Grudl
2009-07-02 17:39:58 +00:00
parent 6ff605ef0a
commit a3f673e82b

View File

@@ -29,6 +29,12 @@
*/ */
class DibiProfiler extends DibiObject implements IDibiProfiler class DibiProfiler extends DibiObject implements IDibiProfiler
{ {
/** maximum number of rows */
const FIREBUG_MAX_ROWS = 30;
/** maximum SQL length */
const FIREBUG_MAX_LENGTH = 500;
/** @var string Name of the file where SQL errors should be logged */ /** @var string Name of the file where SQL errors should be logged */
private $file; private $file;
@@ -104,6 +110,7 @@ class DibiProfiler extends DibiObject implements IDibiProfiler
} }
list($connection, $event, $sql) = $this->tickets[$ticket]; list($connection, $event, $sql) = $this->tickets[$ticket];
$sql = trim($sql);
if (($event & $this->filter) === 0) return; if (($event & $this->filter) === 0) return;
@@ -115,12 +122,14 @@ class DibiProfiler extends DibiObject implements IDibiProfiler
} }
if ($this->useFirebug && !headers_sent()) { if ($this->useFirebug && !headers_sent()) {
self::$table[] = array( if (count(self::$table) < self::FIREBUG_MAX_ROWS) {
sprintf('%0.3f', dibi::$elapsedTime * 1000), self::$table[] = array(
trim($sql), sprintf('%0.3f', dibi::$elapsedTime * 1000),
$count, strlen($sql) > self::FIREBUG_MAX_LENGTH ? substr($sql, 0, self::FIREBUG_MAX_LENGTH) . '...' : $sql,
$connection->getConfig('driver') . '/' . $connection->getConfig('name') $count,
); $connection->getConfig('driver') . '/' . $connection->getConfig('name')
);
}
header('X-Wf-Protocol-dibi: http://meta.wildfirehq.org/Protocol/JsonStream/0.2'); header('X-Wf-Protocol-dibi: http://meta.wildfirehq.org/Protocol/JsonStream/0.2');
header('X-Wf-dibi-Plugin-1: http://meta.firephp.org/Wildfire/Plugin/FirePHP/Library-FirePHPCore/0.2.0'); header('X-Wf-dibi-Plugin-1: http://meta.firephp.org/Wildfire/Plugin/FirePHP/Library-FirePHPCore/0.2.0');