eternal-timer 3.0.0 → 4.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +145 -35
- package/dist/cjs/EventEmitter.d.ts +12 -0
- package/dist/cjs/EventEmitter.d.ts.map +1 -0
- package/dist/cjs/EventEmitter.js +50 -0
- package/dist/cjs/EventEmitter.js.map +1 -0
- package/dist/cjs/TimersManager/JSONLTimersManager.d.ts.map +1 -1
- package/dist/cjs/TimersManager/JSONLTimersManager.js +3 -1
- package/dist/cjs/TimersManager/JSONLTimersManager.js.map +1 -1
- package/dist/cjs/TimersManager/TimersManager.d.ts +30 -29
- package/dist/cjs/TimersManager/TimersManager.d.ts.map +1 -1
- package/dist/cjs/TimersManager/TimersManager.js +52 -49
- package/dist/cjs/TimersManager/TimersManager.js.map +1 -1
- package/dist/cjs/types.d.ts +14 -0
- package/dist/cjs/types.d.ts.map +1 -1
- package/dist/esm/EventEmitter.d.ts +12 -0
- package/dist/esm/EventEmitter.d.ts.map +1 -0
- package/dist/esm/EventEmitter.js +46 -0
- package/dist/esm/EventEmitter.js.map +1 -0
- package/dist/esm/TimersManager/JSONLTimersManager.d.ts.map +1 -1
- package/dist/esm/TimersManager/JSONLTimersManager.js +3 -1
- package/dist/esm/TimersManager/JSONLTimersManager.js.map +1 -1
- package/dist/esm/TimersManager/TimersManager.d.ts +30 -29
- package/dist/esm/TimersManager/TimersManager.d.ts.map +1 -1
- package/dist/esm/TimersManager/TimersManager.js +52 -49
- package/dist/esm/TimersManager/TimersManager.js.map +1 -1
- package/dist/esm/types.d.ts +14 -0
- package/dist/esm/types.d.ts.map +1 -1
- package/package.json +2 -5
- package/dist/cjs/Log.d.ts +0 -8
- package/dist/cjs/Log.d.ts.map +0 -1
- package/dist/cjs/Log.js +0 -61
- package/dist/cjs/Log.js.map +0 -1
- package/dist/esm/Log.d.ts +0 -8
- package/dist/esm/Log.d.ts.map +0 -1
- package/dist/esm/Log.js +0 -24
- package/dist/esm/Log.js.map +0 -1
|
@@ -3,7 +3,7 @@ import fs from "fs";
|
|
|
3
3
|
import { v4 as uuidv4 } from "uuid";
|
|
4
4
|
import searchRoot from "../searchRoot.js";
|
|
5
5
|
import { TimersStore } from "../TimersStore/TimersStore.js";
|
|
6
|
-
import {
|
|
6
|
+
import { EventEmitter } from "../EventEmitter.js";
|
|
7
7
|
/**
|
|
8
8
|
* TimersManager
|
|
9
9
|
* @description
|
|
@@ -13,7 +13,7 @@ import { Log } from "../Log.js";
|
|
|
13
13
|
* - Timers are persisted in a file
|
|
14
14
|
* - Expired timers are detected by polling
|
|
15
15
|
*/
|
|
16
|
-
export class TimersManager {
|
|
16
|
+
export class TimersManager extends EventEmitter {
|
|
17
17
|
timerfiledir;
|
|
18
18
|
checkLock = false;
|
|
19
19
|
TimersStore = null;
|
|
@@ -26,15 +26,16 @@ export class TimersManager {
|
|
|
26
26
|
/**
|
|
27
27
|
* constructor
|
|
28
28
|
* @description Initializes the TimersManager instance. If the timer file does not exist, an empty file is created.
|
|
29
|
-
* @param {string} [
|
|
29
|
+
* @param {string} [timerfile] (string, optional) Configuration timer file path and it is treated as the timer file path.
|
|
30
30
|
* @throws If file access or creation fails
|
|
31
31
|
* @example
|
|
32
32
|
* const manager = new TimersManager(); // Uses default timer file path
|
|
33
33
|
* const manager = new TimersManager("/path/to/timers.txt"); // Uses specified timer file path
|
|
34
34
|
*/
|
|
35
|
-
constructor(
|
|
35
|
+
constructor(timerfile) {
|
|
36
|
+
super();
|
|
36
37
|
const rootDir = searchRoot();
|
|
37
|
-
this.timerfiledir = path.resolve(rootDir,
|
|
38
|
+
this.timerfiledir = path.resolve(rootDir, timerfile ?? this.getDefaultFilename());
|
|
38
39
|
if (!this.timerfiledir.startsWith(rootDir)) {
|
|
39
40
|
throw new Error(`Timer file path must be within the project directory`);
|
|
40
41
|
}
|
|
@@ -48,13 +49,17 @@ export class TimersManager {
|
|
|
48
49
|
/**
|
|
49
50
|
* createTimer
|
|
50
51
|
* @description Creates a new timer.
|
|
51
|
-
* @param {
|
|
52
|
+
* @param {CreateTimerOptions<T, Extra>} options Timer duration in milliseconds for PlainText or an object with length and extra for JSONL.
|
|
52
53
|
* @returns Promise that resolves to the timer ID (UUID)
|
|
53
|
-
* @throws If length is invalid(e.g. length < 0) or file operation fails
|
|
54
|
+
* @throws If length is invalid (e.g. length < 0) or file operation fails
|
|
54
55
|
* @example
|
|
55
|
-
*
|
|
56
|
-
* const
|
|
57
|
-
*
|
|
56
|
+
* // For PlainTextTimersManager
|
|
57
|
+
* const manager = new PlainTextTimersManager();
|
|
58
|
+
* const newTimerId = await manager.createTimer(5000); // Create a 5-second timer
|
|
59
|
+
*
|
|
60
|
+
* // For JSONLTimersManager
|
|
61
|
+
* const jsonlManager = new JSONLTimersManager<{ title: string }>();
|
|
62
|
+
* const jsonlTimerId = await jsonlManager.createTimer({ length: 10000, extra: { title: "My JSONL Timer" } }); // Create a 10-second timer with extra data
|
|
58
63
|
*/
|
|
59
64
|
async createTimer(options) {
|
|
60
65
|
return this.runExclusive(async () => {
|
|
@@ -78,6 +83,7 @@ export class TimersManager {
|
|
|
78
83
|
: {}),
|
|
79
84
|
};
|
|
80
85
|
await this.TimersStore.appendTimer(newTimerData);
|
|
86
|
+
await this.emit("started", newTimerData);
|
|
81
87
|
return id;
|
|
82
88
|
});
|
|
83
89
|
}
|
|
@@ -95,37 +101,35 @@ export class TimersManager {
|
|
|
95
101
|
this.TimersStore ??= await this.createTimersStore();
|
|
96
102
|
const timers = await this.TimersStore.loadTimers();
|
|
97
103
|
const index = timers.findIndex(t => t.id === id);
|
|
98
|
-
if (index === -1) {
|
|
104
|
+
if (index === -1 || timers[index] === undefined) {
|
|
99
105
|
throw new Error(`Timer with id ${id} not found`);
|
|
100
106
|
}
|
|
101
107
|
timers.splice(index, 1);
|
|
102
108
|
await this.TimersStore.saveTimers(timers);
|
|
109
|
+
await this.emit("stopped", timers[index]);
|
|
103
110
|
return;
|
|
104
111
|
});
|
|
105
112
|
}
|
|
106
113
|
/**
|
|
107
|
-
*
|
|
108
|
-
* @description Starts
|
|
109
|
-
*
|
|
110
|
-
* The
|
|
111
|
-
* @
|
|
112
|
-
* @param {number} [interval=200] (number, optional): Check interval in milliseconds (default: 200ms)
|
|
113
|
-
* @throws If file operation fails
|
|
114
|
-
* @returns {Promise<NodeJS.Timeout>} intervalId interval id of checkTimers
|
|
114
|
+
* checkStart
|
|
115
|
+
* @description Starts the timer checking loop. This method should be called once after creating an instance of TimersManager to detect expired timers.
|
|
116
|
+
* @param {number} [interval=200] Polling interval in milliseconds (default: 200ms)
|
|
117
|
+
* @returns The interval ID which can be used to stop the loop with clearInterval
|
|
118
|
+
* @throws If file operation fails during checking
|
|
115
119
|
* @example
|
|
116
|
-
* const
|
|
117
|
-
*
|
|
118
|
-
* });
|
|
120
|
+
* const manager = new TimersManager();
|
|
121
|
+
* manager.checkStart(1000); // Check for expired timers every 1 second
|
|
119
122
|
*/
|
|
120
|
-
async
|
|
123
|
+
async checkStart(interval = 200) {
|
|
121
124
|
this.TimersStore ??= await this.createTimersStore();
|
|
122
125
|
const loop = async () => {
|
|
123
|
-
if (this.checkLock)
|
|
126
|
+
if (this.checkLock)
|
|
124
127
|
return;
|
|
125
|
-
}
|
|
126
128
|
this.checkLock = true;
|
|
129
|
+
let expiredTimers = [];
|
|
127
130
|
try {
|
|
128
|
-
|
|
131
|
+
expiredTimers = await this.runExclusive(async () => {
|
|
132
|
+
await this.emit("interval", void 0);
|
|
129
133
|
const allTimers = await this.TimersStore.loadTimers();
|
|
130
134
|
const now = Date.now();
|
|
131
135
|
const expired = [];
|
|
@@ -143,35 +147,33 @@ export class TimersManager {
|
|
|
143
147
|
}
|
|
144
148
|
return expired;
|
|
145
149
|
});
|
|
146
|
-
for (const timerData of expiredTimers) {
|
|
147
|
-
try {
|
|
148
|
-
await callback(timerData);
|
|
149
|
-
}
|
|
150
|
-
catch (e) {
|
|
151
|
-
await Log.ensureLogger();
|
|
152
|
-
Log.loggerInstance?.error(`Error in callback of checkTimers: ${e}`);
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
150
|
}
|
|
156
151
|
catch (e) {
|
|
157
|
-
|
|
158
|
-
Log.loggerInstance?.error(`Error when checking timer: ${e}`);
|
|
159
|
-
}
|
|
160
|
-
finally {
|
|
152
|
+
this.emit("errored", e instanceof Error ? e : new Error(String(e))).catch(() => { });
|
|
161
153
|
this.checkLock = false;
|
|
154
|
+
return;
|
|
155
|
+
}
|
|
156
|
+
for (const timer of expiredTimers) {
|
|
157
|
+
try {
|
|
158
|
+
await this.emit("expired", timer);
|
|
159
|
+
}
|
|
160
|
+
catch (e) {
|
|
161
|
+
await this.emit("errored", e instanceof Error ? e : new Error(String(e)));
|
|
162
|
+
}
|
|
162
163
|
}
|
|
164
|
+
this.checkLock = false;
|
|
163
165
|
};
|
|
164
166
|
return setInterval(loop, interval);
|
|
165
167
|
}
|
|
166
168
|
/**
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
169
|
+
* showTimers
|
|
170
|
+
* @description Retrieves all active timers.
|
|
171
|
+
* @returns Array of `Timer` objects
|
|
172
|
+
* @throws If file operation fails
|
|
173
|
+
* @example
|
|
174
|
+
* const timers = await manager.showTimers();
|
|
175
|
+
* console.log(JSON.stringify(timers))
|
|
176
|
+
*/
|
|
175
177
|
async showTimers() {
|
|
176
178
|
return this.runExclusive(async () => {
|
|
177
179
|
this.TimersStore ??= await this.createTimersStore();
|
|
@@ -192,16 +194,17 @@ export class TimersManager {
|
|
|
192
194
|
this.TimersStore ??= await this.createTimersStore();
|
|
193
195
|
const timers = await this.TimersStore.loadTimers();
|
|
194
196
|
const index = timers.findIndex(t => t.id === id);
|
|
195
|
-
if (index === -1) {
|
|
197
|
+
if (index === -1 || timers[index] === undefined) {
|
|
196
198
|
throw new Error(`Timer with id ${id} not found`);
|
|
197
199
|
}
|
|
200
|
+
const old = { ...timers[index] };
|
|
198
201
|
const now = Date.now();
|
|
199
202
|
const timer = timers[index];
|
|
200
203
|
const remaining = Math.max(0, timer.stop - now);
|
|
201
204
|
const newRemaining = Math.max(0, remaining + delay);
|
|
202
205
|
timer.stop = now + newRemaining;
|
|
203
|
-
timers[index] = timer;
|
|
204
206
|
await this.TimersStore.saveTimers(timers);
|
|
207
|
+
await this.emit("updated", { old, new: timer });
|
|
205
208
|
return;
|
|
206
209
|
});
|
|
207
210
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TimersManager.js","sourceRoot":"","sources":["../../../src/TimersManager/TimersManager.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAC;AAEpC,OAAO,UAAU,MAAM,kBAAkB,CAAC;AAE1C,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"TimersManager.js","sourceRoot":"","sources":["../../../src/TimersManager/TimersManager.ts"],"names":[],"mappings":"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"}
|
package/dist/esm/types.d.ts
CHANGED
|
@@ -13,4 +13,18 @@ export type CreateTimerOptions<T extends StorageType, Extra extends object> = T
|
|
|
13
13
|
length: number;
|
|
14
14
|
extra: Extra;
|
|
15
15
|
} : T extends "PlainText" ? number : never;
|
|
16
|
+
export type TimerEvents<T extends StorageType, Extra extends object> = {
|
|
17
|
+
expired: Timer<T, Extra>;
|
|
18
|
+
errored: Error;
|
|
19
|
+
interval: void;
|
|
20
|
+
started: Timer<T, Extra>;
|
|
21
|
+
stopped: Timer<T, Extra>;
|
|
22
|
+
updated: {
|
|
23
|
+
old: Timer<T, Extra>;
|
|
24
|
+
new: Timer<T, Extra>;
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
export type ListenerMap<T extends StorageType, Extra extends object> = {
|
|
28
|
+
[K in keyof TimerEvents<T, Extra>]?: ((payload: TimerEvents<T, Extra>[K]) => void | Promise<void>)[];
|
|
29
|
+
};
|
|
16
30
|
//# sourceMappingURL=types.d.ts.map
|
package/dist/esm/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,WAAW,GAAG,OAAO,GAAG,WAAW,CAAC;AAEhD,MAAM,MAAM,KAAK,CAAC,CAAC,SAAS,WAAW,EAAE,KAAK,SAAS,MAAM,IACzD,CAAC,SAAS,OAAO,GACX;IACI,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,KAAK,CAAA;CACf,GACD;IACI,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CAChB,CAAC;AAEZ,MAAM,MAAM,kBAAkB,CAAC,CAAC,SAAS,WAAW,EAAE,KAAK,SAAS,MAAM,IAAI,CAAC,SAAS,OAAO,GACzF;IACI,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,KAAK,CAAA;CACf,GACD,CAAC,SAAS,WAAW,GACnB,MAAM,GACN,KAAK,CAAC"}
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,WAAW,GAAG,OAAO,GAAG,WAAW,CAAC;AAEhD,MAAM,MAAM,KAAK,CAAC,CAAC,SAAS,WAAW,EAAE,KAAK,SAAS,MAAM,IACzD,CAAC,SAAS,OAAO,GACX;IACI,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,KAAK,CAAA;CACf,GACD;IACI,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CAChB,CAAC;AAEZ,MAAM,MAAM,kBAAkB,CAAC,CAAC,SAAS,WAAW,EAAE,KAAK,SAAS,MAAM,IAAI,CAAC,SAAS,OAAO,GACzF;IACI,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,KAAK,CAAA;CACf,GACD,CAAC,SAAS,WAAW,GACnB,MAAM,GACN,KAAK,CAAC;AAEd,MAAM,MAAM,WAAW,CAAC,CAAC,SAAS,WAAW,EAAE,KAAK,SAAS,MAAM,IAAI;IACrE,OAAO,EAAE,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAA;IACxB,OAAO,EAAE,KAAK,CAAA;IACd,QAAQ,EAAE,IAAI,CAAA;IACd,OAAO,EAAE,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAA;IACxB,OAAO,EAAE,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAA;IACxB,OAAO,EAAE;QAAE,GAAG,EAAE,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;QAAC,GAAG,EAAE,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAA;KAAE,CAAA;CACxD,CAAA;AAED,MAAM,MAAM,WAAW,CAAC,CAAC,SAAS,WAAW,EAAE,KAAK,SAAS,MAAM,IAAI;KACpE,CAAC,IAAI,MAAM,WAAW,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CACpC,OAAO,EAAE,WAAW,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,KAC9B,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE;CAC7B,CAAA"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "eternal-timer",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "4.0.0",
|
|
4
4
|
"description": "timer for node.js package",
|
|
5
5
|
"scripts": {
|
|
6
6
|
"build": "tsc -p tsconfig.esm.json && tsc -p tsconfig.cjs.json && node scripts/move-package-json.js",
|
|
@@ -47,8 +47,5 @@
|
|
|
47
47
|
"files": [
|
|
48
48
|
"dist"
|
|
49
49
|
],
|
|
50
|
-
"main": "./dist/cjs/index.js"
|
|
51
|
-
"optionalDependencies": {
|
|
52
|
-
"@logtape/logtape": "^2.0.0"
|
|
53
|
-
}
|
|
50
|
+
"main": "./dist/cjs/index.js"
|
|
54
51
|
}
|
package/dist/cjs/Log.d.ts
DELETED
package/dist/cjs/Log.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Log.d.ts","sourceRoot":"","sources":["../../src/Log.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAE/C,qBAAa,GAAG;IACf,OAAO,CAAC,MAAM,CAAC,MAAM,CAAuB;IAC5C,OAAO,CAAC,MAAM,CAAC,WAAW,CAA8B;WAEpC,YAAY;IAiBhC,WAAkB,cAAc,IAAI,MAAM,GAAG,IAAI,CAEhD;CACD"}
|
package/dist/cjs/Log.js
DELETED
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
-
var ownKeys = function(o) {
|
|
20
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
-
var ar = [];
|
|
22
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
-
return ar;
|
|
24
|
-
};
|
|
25
|
-
return ownKeys(o);
|
|
26
|
-
};
|
|
27
|
-
return function (mod) {
|
|
28
|
-
if (mod && mod.__esModule) return mod;
|
|
29
|
-
var result = {};
|
|
30
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
-
__setModuleDefault(result, mod);
|
|
32
|
-
return result;
|
|
33
|
-
};
|
|
34
|
-
})();
|
|
35
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.Log = void 0;
|
|
37
|
-
class Log {
|
|
38
|
-
static logger = null;
|
|
39
|
-
static initPromise = null;
|
|
40
|
-
static async ensureLogger() {
|
|
41
|
-
if (Log.logger)
|
|
42
|
-
return;
|
|
43
|
-
if (!Log.initPromise) {
|
|
44
|
-
Log.initPromise = (async () => {
|
|
45
|
-
try {
|
|
46
|
-
const logtape = await Promise.resolve().then(() => __importStar(require("@logtape/logtape")));
|
|
47
|
-
Log.logger = logtape.getLogger(["eternal-timer"]);
|
|
48
|
-
}
|
|
49
|
-
catch {
|
|
50
|
-
console.info("Tip: Install the optional package '@logtape/logtape' to customize logging behavior.");
|
|
51
|
-
}
|
|
52
|
-
})();
|
|
53
|
-
}
|
|
54
|
-
await Log.initPromise;
|
|
55
|
-
}
|
|
56
|
-
static get loggerInstance() {
|
|
57
|
-
return Log.logger;
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
exports.Log = Log;
|
|
61
|
-
//# sourceMappingURL=Log.js.map
|
package/dist/cjs/Log.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Log.js","sourceRoot":"","sources":["../../src/Log.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,MAAa,GAAG;IACP,MAAM,CAAC,MAAM,GAAkB,IAAI,CAAC;IACpC,MAAM,CAAC,WAAW,GAAyB,IAAI,CAAC;IAEjD,MAAM,CAAC,KAAK,CAAC,YAAY;QAC/B,IAAI,GAAG,CAAC,MAAM;YAAE,OAAO;QACvB,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;YACtB,GAAG,CAAC,WAAW,GAAG,CAAC,KAAK,IAAI,EAAE;gBAC7B,IAAI,CAAC;oBACJ,MAAM,OAAO,GAAG,wDAAa,kBAAkB,GAAC,CAAC;oBACjD,GAAG,CAAC,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC;gBACnD,CAAC;gBAAC,MAAM,CAAC;oBACR,OAAO,CAAC,IAAI,CACX,qFAAqF,CACrF,CAAC;gBACH,CAAC;YACF,CAAC,CAAC,EAAE,CAAC;QACN,CAAC;QACD,MAAM,GAAG,CAAC,WAAW,CAAC;IACvB,CAAC;IAEM,MAAM,KAAK,cAAc;QAC/B,OAAO,GAAG,CAAC,MAAM,CAAC;IACnB,CAAC;;AAvBF,kBAwBC"}
|
package/dist/esm/Log.d.ts
DELETED
package/dist/esm/Log.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Log.d.ts","sourceRoot":"","sources":["../../src/Log.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAE/C,qBAAa,GAAG;IACf,OAAO,CAAC,MAAM,CAAC,MAAM,CAAuB;IAC5C,OAAO,CAAC,MAAM,CAAC,WAAW,CAA8B;WAEpC,YAAY;IAiBhC,WAAkB,cAAc,IAAI,MAAM,GAAG,IAAI,CAEhD;CACD"}
|
package/dist/esm/Log.js
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
export class Log {
|
|
2
|
-
static logger = null;
|
|
3
|
-
static initPromise = null;
|
|
4
|
-
static async ensureLogger() {
|
|
5
|
-
if (Log.logger)
|
|
6
|
-
return;
|
|
7
|
-
if (!Log.initPromise) {
|
|
8
|
-
Log.initPromise = (async () => {
|
|
9
|
-
try {
|
|
10
|
-
const logtape = await import("@logtape/logtape");
|
|
11
|
-
Log.logger = logtape.getLogger(["eternal-timer"]);
|
|
12
|
-
}
|
|
13
|
-
catch {
|
|
14
|
-
console.info("Tip: Install the optional package '@logtape/logtape' to customize logging behavior.");
|
|
15
|
-
}
|
|
16
|
-
})();
|
|
17
|
-
}
|
|
18
|
-
await Log.initPromise;
|
|
19
|
-
}
|
|
20
|
-
static get loggerInstance() {
|
|
21
|
-
return Log.logger;
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
//# sourceMappingURL=Log.js.map
|
package/dist/esm/Log.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Log.js","sourceRoot":"","sources":["../../src/Log.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,GAAG;IACP,MAAM,CAAC,MAAM,GAAkB,IAAI,CAAC;IACpC,MAAM,CAAC,WAAW,GAAyB,IAAI,CAAC;IAEjD,MAAM,CAAC,KAAK,CAAC,YAAY;QAC/B,IAAI,GAAG,CAAC,MAAM;YAAE,OAAO;QACvB,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;YACtB,GAAG,CAAC,WAAW,GAAG,CAAC,KAAK,IAAI,EAAE;gBAC7B,IAAI,CAAC;oBACJ,MAAM,OAAO,GAAG,MAAM,MAAM,CAAC,kBAAkB,CAAC,CAAC;oBACjD,GAAG,CAAC,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC;gBACnD,CAAC;gBAAC,MAAM,CAAC;oBACR,OAAO,CAAC,IAAI,CACX,qFAAqF,CACrF,CAAC;gBACH,CAAC;YACF,CAAC,CAAC,EAAE,CAAC;QACN,CAAC;QACD,MAAM,GAAG,CAAC,WAAW,CAAC;IACvB,CAAC;IAEM,MAAM,KAAK,cAAc;QAC/B,OAAO,GAAG,CAAC,MAAM,CAAC;IACnB,CAAC"}
|