9use Psr\Log\LoggerAwareInterface;
10use Psr\Log\LoggerInterface;
11use Psr\Log\NullLogger;
33class Timing implements LoggerAwareInterface {
36 private $entries = [];
43 $this->
setLogger( $params[
'logger'] ??
new NullLogger() );
60 public function mark( $markName ) {
61 $this->entries[$markName] = [
63 'entryType' =>
'mark',
64 'startTime' => microtime(
true ),
67 return $this->entries[$markName];
75 if ( $markName !==
null ) {
76 unset( $this->entries[$markName] );
80 'name' =>
'requestStart',
81 'entryType' =>
'mark',
82 'startTime' => $_SERVER[
'REQUEST_TIME_FLOAT'],
109 public function measure( $measureName, $startMark =
'requestStart', $endMark =
null ) {
110 $start = $this->getEntryByName( $startMark );
111 if ( $start ===
null ) {
112 $this->logger->error( __METHOD__ .
": The mark '$startMark' does not exist" );
115 $startTime = $start[
'startTime'];
118 $end = $this->getEntryByName( $endMark );
119 if ( $end ===
null ) {
120 $this->logger->error( __METHOD__ .
": The mark '$endMark' does not exist" );
123 $endTime = $end[
'startTime'];
125 $endTime = microtime(
true );
128 $this->entries[$measureName] = [
129 'name' => $measureName,
130 'entryType' =>
'measure',
131 'startTime' => $startTime,
132 'duration' => $endTime - $startTime,
135 return $this->entries[$measureName];
141 private function sortEntries() {
142 uasort( $this->entries,
static function ( $a, $b ) {
143 return $a[
'startTime'] <=> $b[
'startTime'];
151 $this->sortEntries();
152 return $this->entries;
161 $this->sortEntries();
163 foreach ( $this->entries as $entry ) {
164 if ( $entry[
'entryType'] === $entryType ) {
176 return $this->entries[$name] ??
null;
181class_alias( Timing::class,
'Timing' );