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
|
<?php /** * Class StopWatch. * * @package AmpProject\AmpWP */
namespace AmpProject\AmpWP\Instrumentation;
use AmpProject\AmpWP\Exception\InvalidStopwatchEvent;
/** * Record the timing of multiple events. * * @package AmpProject\AmpWP * @since 2.0 * @internal */ final class StopWatch {
/** * Collection of named events that the stopwatch is tracking. * * @var StopWatchEvent[] */ private $events = [];
/** * Start a named event. * * @param string $name Name of the event to start. */ public function start( $name ) { $this->events[ $name ] = new StopWatchEvent(); }
/** * Stop a named event. * * @param string $name Name of the event to stop. * @return StopWatchEvent Completed stopwatch event. * @throws InvalidStopwatchEvent If an unknown event name is provided. */ public function stop( $name ) { if ( ! array_key_exists( $name, $this->events ) ) { throw InvalidStopwatchEvent::from_name_to_stop( $name ); }
$event = $this->events[ $name ]; $event->stop();
return $event; } }
|