mirror of
https://github.com/maximebf/php-debugbar.git
synced 2025-01-17 21:38:14 +01:00
2a95c20da4
ExceptionsCollector->addException() is deprecated since #281.
138 lines
5.2 KiB
Markdown
138 lines
5.2 KiB
Markdown
|
||
# Base collectors
|
||
|
||
Collectors provided in the `DebugBar\DataCollector` namespace.
|
||
|
||
## Messages
|
||
|
||
Provides a way to log messages (compatible with [PSR-3 logger](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-3-logger-interface.md)).
|
||
You can call the `useHtmlVarDumper()` function to use VarDumper's interactive HTML dumper for
|
||
interactively rendering complex variables. If you do that, you must properly render
|
||
[inline assets](rendering.html#assets) when rendering the debug bar in addition to the normal js/css
|
||
static assets.
|
||
|
||
$c = new DebugBar\DataCollector\MessagesCollector();
|
||
$c->useHtmlVarDumper(); // Enables prettier dumps of objects; requires inline assets
|
||
$debugbar->addCollector($c);
|
||
|
||
$debugbar['messages']->info('hello world');
|
||
$complicated_variable = array(1, 2, array(3, 4));
|
||
$debugbar['messages']->info($complicated_variable); // interactive HTML variable dumping
|
||
|
||
You can have multiple messages collector by naming them:
|
||
|
||
$debugbar->addCollector(new MessagesCollector('io_ops'));
|
||
$debugbar['io_ops']->info('opening files');
|
||
|
||
You can aggregate messages collector into other to have a unified view:
|
||
|
||
$debugbar['messages']->aggregate($debugbar['io_ops']);
|
||
|
||
If you don't want to create a standalone tab in the debug bar but still be able
|
||
to log messages from a different collector, you don't have to add the collector
|
||
to the debug bar:
|
||
|
||
$debugbar['messages']->aggregate(new MessagesCollector('io_ops'));
|
||
|
||
## TimeData
|
||
|
||
Provides a way to log total execution time as well as taking "measures" (ie. measure the execution time of a particular operation).
|
||
|
||
$debugbar->addCollector(new DebugBar\DataCollector\TimeDataCollector());
|
||
|
||
$debugbar['time']->startMeasure('longop', 'My long operation');
|
||
sleep(2);
|
||
$debugbar['time']->stopMeasure('longop');
|
||
|
||
$debugbar['time']->measure('My long operation', function() {
|
||
sleep(2);
|
||
});
|
||
|
||
Displays the measures on a timeline
|
||
|
||
## Exceptions
|
||
|
||
Display exceptions
|
||
|
||
$debugbar->addCollector(new DebugBar\DataCollector\ExceptionsCollector());
|
||
|
||
try {
|
||
throw new Exception('foobar');
|
||
} catch (Exception $e) {
|
||
$debugbar['exceptions']->addThrowable($e);
|
||
}
|
||
|
||
## PDO
|
||
|
||
Logs SQL queries. You need to wrap your `PDO` object into a `DebugBar\DataCollector\PDO\TraceablePDO` object.
|
||
|
||
$pdo = new DebugBar\DataCollector\PDO\TraceablePDO(new PDO('sqlite::memory:'));
|
||
$debugbar->addCollector(new DebugBar\DataCollector\PDO\PDOCollector($pdo));
|
||
|
||
You can even log queries from multiple `PDO` connections:
|
||
|
||
$pdoRead = new DebugBar\DataCollector\PDO\TraceablePDO(new PDO('sqlite::memory:'));
|
||
$pdoWrite = new DebugBar\DataCollector\PDO\TraceablePDO(new PDO('sqlite::memory:'));
|
||
|
||
$pdoCollector = new DebugBar\DataCollector\PDO\PDOCollector();
|
||
$pdoCollector->addConnection($pdoRead, 'read-db');
|
||
$pdoCollector->addConnection($pdoWrite, 'write-db');
|
||
|
||
$debugbar->addCollector($pdoCollector);
|
||
|
||
If you want to see your PDO requests in the TimeDataCollector, you must add the PDOConnector to the $debugbar _first_
|
||
|
||
$timeDataCollector = new DebugBar\DataCollector\TimeDataCollector();
|
||
$pdoCollector = new DebugBar\DataCollector\PDO\PDOCollector($pdo, $timeDataCollector);
|
||
|
||
$debugBar->addCollector($pdoCollector);
|
||
$debugBar->addCollector($timeDataCollector);
|
||
|
||
## RequestData
|
||
|
||
Collects the data of PHP's global variables. You can call the `useHtmlVarDumper()` function to use
|
||
VarDumper's interactive HTML dumper for rendering the variables. If you do that, you must properly
|
||
render [inline assets](rendering.html#assets) when rendering the debug bar in addition to the normal
|
||
js/css static assets.
|
||
|
||
$requestDataCollector = new DebugBar\DataCollector\RequestDataCollector();
|
||
$requestDataCollector->useHtmlVarDumper();
|
||
$debugbar->addCollector($requestDataCollector);
|
||
|
||
## Config
|
||
|
||
Used to display any key/value pairs array. You can call the `useHtmlVarDumper()` function to use
|
||
VarDumper's interactive HTML dumper for rendering the variables. If you do that, you must properly
|
||
render [inline assets](rendering.html#assets) when rendering the debug bar in addition to the normal
|
||
js/css static assets.
|
||
|
||
$data = array('foo' => 'bar');
|
||
$configCollector = new DebugBar\DataCollector\ConfigCollector($data);
|
||
$configCollector->useHtmlVarDumper();
|
||
$debugbar->addCollector($configCollector);
|
||
|
||
You can provide a different name for this collector in the second argument of the constructor.
|
||
|
||
## AggregatedCollector
|
||
|
||
Aggregates multiple collectors. Do not provide any widgets, you have to add your own controls.
|
||
|
||
$debugbar->addCollector(new DebugBar\DataCollector\AggregatedCollector('all_messages', 'messages', 'time'));
|
||
$debugbar['all_messages']->addCollector($debugbar['messages']);
|
||
$debugbar['all_messages']->addCollector(new MessagesCollector('mails'));
|
||
$debugbar['all_messages']['mails']->addMessage('sending mail');
|
||
|
||
$renderer = $debugbar->getJavascriptRenderer();
|
||
$renderer->addControl('all_messages', array(
|
||
'widget' => 'PhpDebugBar.Widgets.MessagesWidget',
|
||
'map' => 'all_messages',
|
||
'default' => '[]',
|
||
));
|
||
|
||
## Others
|
||
|
||
Misc collectors which you can just register:
|
||
|
||
- `MemoryCollector` (*memory*): Display memory usage
|
||
- `PhpInfoCollector` (*php*): PHP version number
|