UNPKG

@finos/legend-shared

Version:
61 lines (52 loc) 1.6 kB
/** * 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); } }