Passed
Push — master ( 203560...e59319 )
by Caen
03:19 queued 12s
created

TracksExecutionTime::startClock()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 1
c 1
b 0
f 0
nc 1
nop 0
dl 0
loc 3
rs 10
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Hyde\Framework\Concerns;
6
7
use function microtime;
8
use function number_format;
9
10
trait TracksExecutionTime
11
{
12
    protected float $timeStart;
13
14
    protected function startClock(): void
15
    {
16
        $this->timeStart = microtime(true);
17
    }
18
19
    protected function stopClock(): float
20
    {
21
        return microtime(true) - $this->timeStart;
22
    }
23
24
    protected function getExecutionTimeInMs(): int|float
25
    {
26
        return $this->stopClock() * 1000;
27
    }
28
29
    protected function getExecutionTimeString(): string
30
    {
31
        return number_format($this->getExecutionTimeInMs(), 2).'ms';
32
    }
33
}
34