"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator.throw(value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments)).next());
});
};
const Debug = require("debug");
const debug = Debug('overland:core');
function timer(event) {
return function (target, key, descriptor) {
return {
value: function (...args) {
return __awaiter(this, void 0, void 0, function* () {
debug(`${event}ing`);
const boot = process.hrtime();
const res = yield descriptor.value.apply(this, args);
const [sec, ns] = process.hrtime(boot);
debug(`${event}ed (took ${(ns / 1000000).toFixed(3)} ms)`);
return res;
});
}
};
};
}
Object.defineProperty(exports, "__esModule", { value: true });
exports.default = timer;
|