1 | 'use strict';
|
2 |
|
3 | const timers = {};
|
4 |
|
5 | module.exports = {
|
6 | start,
|
7 | pause,
|
8 | stop,
|
9 | clear,
|
10 | msDiff
|
11 | };
|
12 |
|
13 |
|
14 |
|
15 |
|
16 |
|
17 | function start(id) {
|
18 | if (!timers[id]) {
|
19 | timers[id] = {
|
20 | start: 0,
|
21 | elapsed: 0
|
22 | };
|
23 | }
|
24 | timers[id].start = process.hrtime();
|
25 | }
|
26 |
|
27 |
|
28 |
|
29 |
|
30 |
|
31 |
|
32 | function pause(id) {
|
33 | if (!timers[id]) return start(id);
|
34 |
|
35 | timers[id].elapsed += msDiff(process.hrtime(), timers[id].start);
|
36 | }
|
37 |
|
38 |
|
39 |
|
40 |
|
41 |
|
42 |
|
43 |
|
44 | function stop(id, formatted) {
|
45 | const elapsed = timers[id].elapsed + msDiff(process.hrtime(), timers[id].start);
|
46 |
|
47 | clear(id);
|
48 | return formatted ? format(elapsed) : elapsed;
|
49 | }
|
50 |
|
51 |
|
52 |
|
53 |
|
54 |
|
55 | function clear(id) {
|
56 | delete timers[id];
|
57 | }
|
58 |
|
59 |
|
60 |
|
61 |
|
62 |
|
63 |
|
64 |
|
65 | function msDiff(t1, t2) {
|
66 | t1 = (t1[0] * 1e9 + t1[1]) / 1e6;
|
67 | t2 = (t2[0] * 1e9 + t2[1]) / 1e6;
|
68 | return Math.ceil((t1 - t2) * 100) / 100;
|
69 | }
|
70 |
|
71 |
|
72 |
|
73 |
|
74 |
|
75 |
|
76 | function format(t) {
|
77 | if (t < 1000) return `${Math.round(t)}ms`;
|
78 | return `${Math.floor(t / 1000 * 100) / 100}s`;
|
79 | }
|