@finos/legend-shared
Version:
Legend Studio shared utilities and helpers
61 lines (52 loc) • 1.6 kB
text/typescript
/**
* Copyright (c) 2020-present, Goldman Sachs
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { guaranteeNonNullable } from '../error/AssertionUtils.js';
export type TimingsRecord = {
[key: string]: number;
/**
* Number of interruptions ocurred during the record
*/
__numberOfInteruptions?: number;
total: number;
};
export class StopWatch {
private _startTime = Date.now();
private _time = this._startTime;
private _records = new Map<string, number>();
record(event?: string | undefined): void {
const currentTime = Date.now();
const duration = currentTime - this._time;
this._time = currentTime;
if (event) {
this._records.set(event, duration);
}
}
getRecord(event: string): number {
return guaranteeNonNullable(
this._records.get(event),
`Can't find record for event '${event}'`,
);
}
get startTime(): number {
return this._startTime;
}
get elapsed(): number {
return Date.now() - this._startTime;
}
get records(): Map<string, number> {
return new Map(this._records);
}
}