1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
<?php
/*
* This file is part of the ICanBoogie package.
*
* (c) Olivier Laviale <olivier.laviale@gmail.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace ICanBoogie;
/**
* Profiling information about events.
*/
final class EventProfiler
{
/**
* Unused event types.
*
* ```php
* list($time, $type) = $value;
* ````
*
* @var array
*/
static public $unused = [];
/**
* Event hooks calls.
*
* ```php
* list($time, $type, $hook, $started_at);
* ```
*
* @var array
*/
static public $calls = [];
/**
* Adds an unused event type.
*
* @param string $type
*/
static public function add_unused($type)
{
self::$unused[] = [ microtime(true), $type ];
}
/**
* Adds an event hook call.
*
* @param string $type
* @param callable $hook
* @param double $started_at
*/
static public function add_call($type, $hook, $started_at)
{
self::$calls[] = [ microtime(true), $type, $hook, $started_at ];
}
}