2021-03-16 20:08:11 +00:00
|
|
|
// @ts-nocheck
|
|
|
|
|
2021-03-19 21:07:45 +00:00
|
|
|
const now =
|
|
|
|
typeof process !== 'undefined' && process.hrtime
|
|
|
|
? () => {
|
|
|
|
const t = process.hrtime();
|
|
|
|
return t[0] * 1e3 + t[1] / 1e6;
|
|
|
|
}
|
|
|
|
: () => self.performance.now();
|
2021-03-16 20:08:11 +00:00
|
|
|
|
|
|
|
interface Timing {
|
2021-03-19 21:07:45 +00:00
|
|
|
label: string;
|
|
|
|
start: number;
|
|
|
|
end: number;
|
|
|
|
children: Timing[];
|
2021-03-16 20:08:11 +00:00
|
|
|
}
|
|
|
|
|
2021-04-01 16:25:28 +00:00
|
|
|
/** Format benchmarks */
|
2021-03-16 20:08:11 +00:00
|
|
|
function collapse_timings(timings) {
|
2021-03-19 21:07:45 +00:00
|
|
|
const result = {};
|
|
|
|
timings.forEach((timing) => {
|
|
|
|
result[timing.label] = Object.assign(
|
|
|
|
{
|
|
|
|
total: timing.end - timing.start,
|
|
|
|
},
|
|
|
|
timing.children && collapse_timings(timing.children)
|
|
|
|
);
|
|
|
|
});
|
|
|
|
return result;
|
2021-03-16 20:08:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export default class Stats {
|
2021-03-19 21:07:45 +00:00
|
|
|
start_time: number;
|
|
|
|
current_timing: Timing;
|
|
|
|
current_children: Timing[];
|
|
|
|
timings: Timing[];
|
|
|
|
stack: Timing[];
|
2021-03-16 20:08:11 +00:00
|
|
|
|
2021-03-19 21:07:45 +00:00
|
|
|
constructor() {
|
|
|
|
this.start_time = now();
|
|
|
|
this.stack = [];
|
|
|
|
this.current_children = this.timings = [];
|
|
|
|
}
|
2021-03-16 20:08:11 +00:00
|
|
|
|
2021-03-19 21:07:45 +00:00
|
|
|
start(label) {
|
|
|
|
const timing = {
|
|
|
|
label,
|
|
|
|
start: now(),
|
|
|
|
end: null,
|
|
|
|
children: [],
|
|
|
|
};
|
2021-03-16 20:08:11 +00:00
|
|
|
|
2021-03-19 21:07:45 +00:00
|
|
|
this.current_children.push(timing);
|
|
|
|
this.stack.push(timing);
|
2021-03-16 20:08:11 +00:00
|
|
|
|
2021-03-19 21:07:45 +00:00
|
|
|
this.current_timing = timing;
|
|
|
|
this.current_children = timing.children;
|
|
|
|
}
|
2021-03-16 20:08:11 +00:00
|
|
|
|
2021-03-19 21:07:45 +00:00
|
|
|
stop(label) {
|
|
|
|
if (label !== this.current_timing.label) {
|
|
|
|
throw new Error(`Mismatched timing labels (expected ${this.current_timing.label}, got ${label})`);
|
|
|
|
}
|
2021-03-16 20:08:11 +00:00
|
|
|
|
2021-03-19 21:07:45 +00:00
|
|
|
this.current_timing.end = now();
|
|
|
|
this.stack.pop();
|
|
|
|
this.current_timing = this.stack[this.stack.length - 1];
|
|
|
|
this.current_children = this.current_timing ? this.current_timing.children : this.timings;
|
|
|
|
}
|
2021-03-16 20:08:11 +00:00
|
|
|
|
2021-03-19 21:07:45 +00:00
|
|
|
render() {
|
|
|
|
const timings = Object.assign(
|
|
|
|
{
|
|
|
|
total: now() - this.start_time,
|
|
|
|
},
|
|
|
|
collapse_timings(this.timings)
|
|
|
|
);
|
2021-03-16 20:08:11 +00:00
|
|
|
|
2021-03-19 21:07:45 +00:00
|
|
|
return {
|
|
|
|
timings,
|
|
|
|
};
|
|
|
|
}
|
2021-03-16 20:08:11 +00:00
|
|
|
}
|