@zajno/common 2.7.0 → 2.7.2
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/cjs/api/call.js +5 -5
- package/cjs/api/call.js.map +1 -1
- package/cjs/api/config.js +30 -5
- package/cjs/api/config.js.map +1 -1
- package/cjs/api/index.js +5 -6
- package/cjs/api/index.js.map +1 -1
- package/cjs/api/interceptor.js +1 -1
- package/cjs/api/logging.js +3 -3
- package/cjs/api/logging.js.map +1 -1
- package/cjs/functions/assert.js +2 -4
- package/cjs/functions/assert.js.map +1 -1
- package/cjs/functions/disposer.js +10 -18
- package/cjs/functions/disposer.js.map +1 -1
- package/cjs/functions/throttle.js +8 -17
- package/cjs/functions/throttle.js.map +1 -1
- package/cjs/logger/batch.js +23 -3
- package/cjs/logger/batch.js.map +1 -1
- package/cjs/logger/buffered/base.js +52 -0
- package/cjs/logger/buffered/base.js.map +1 -0
- package/cjs/logger/buffered/buffered.logger.js +40 -0
- package/cjs/logger/buffered/buffered.logger.js.map +1 -0
- package/cjs/logger/buffered/buffered.memory.js +71 -0
- package/cjs/logger/buffered/buffered.memory.js.map +1 -0
- package/cjs/logger/buffered/file/buffered.file.js +43 -0
- package/cjs/logger/buffered/file/buffered.file.js.map +1 -0
- package/cjs/logger/buffered/file/index.js +5 -0
- package/cjs/logger/buffered/file/index.js.map +1 -0
- package/cjs/logger/buffered/index.js +7 -0
- package/cjs/logger/buffered/index.js.map +1 -0
- package/cjs/logger/console.js +1 -39
- package/cjs/logger/console.js.map +1 -1
- package/cjs/logger/empty.js +11 -0
- package/cjs/logger/empty.js.map +1 -0
- package/cjs/logger/index.js +5 -7
- package/cjs/logger/index.js.map +1 -1
- package/cjs/logger/loggable.js +39 -0
- package/cjs/logger/loggable.js.map +1 -0
- package/cjs/logger/manager.js +70 -20
- package/cjs/logger/manager.js.map +1 -1
- package/cjs/logger/named.js +15 -12
- package/cjs/logger/named.js.map +1 -1
- package/cjs/logger/provider.js +33 -0
- package/cjs/logger/provider.js.map +1 -0
- package/cjs/logger/proxy.js +3 -7
- package/cjs/logger/proxy.js.map +1 -1
- package/cjs/logger/types.js +9 -0
- package/cjs/logger/types.js.map +1 -0
- package/cjs/models/LogicModel.js +13 -11
- package/cjs/models/LogicModel.js.map +1 -1
- package/cjs/observing/event.js +5 -18
- package/cjs/observing/event.js.map +1 -1
- package/cjs/observing/progressTracker.js +8 -15
- package/cjs/observing/progressTracker.js.map +1 -1
- package/cjs/structures/promiseCache.js +14 -20
- package/cjs/structures/promiseCache.js.map +1 -1
- package/cjs/structures/queue/parallel.js +11 -13
- package/cjs/structures/queue/parallel.js.map +1 -1
- package/cjs/structures/subscribersMap.js +9 -7
- package/cjs/structures/subscribersMap.js.map +1 -1
- package/esm/api/call.js +5 -5
- package/esm/api/call.js.map +1 -1
- package/esm/api/config.js +28 -4
- package/esm/api/config.js.map +1 -1
- package/esm/api/index.js +4 -2
- package/esm/api/index.js.map +1 -1
- package/esm/api/interceptor.js +1 -1
- package/esm/api/logging.js +3 -3
- package/esm/api/logging.js.map +1 -1
- package/esm/functions/assert.js +2 -3
- package/esm/functions/assert.js.map +1 -1
- package/esm/functions/disposer.js +10 -17
- package/esm/functions/disposer.js.map +1 -1
- package/esm/functions/throttle.js +6 -15
- package/esm/functions/throttle.js.map +1 -1
- package/esm/logger/batch.js +23 -3
- package/esm/logger/batch.js.map +1 -1
- package/esm/logger/buffered/base.js +48 -0
- package/esm/logger/buffered/base.js.map +1 -0
- package/esm/logger/buffered/buffered.logger.js +36 -0
- package/esm/logger/buffered/buffered.logger.js.map +1 -0
- package/esm/logger/buffered/buffered.memory.js +67 -0
- package/esm/logger/buffered/buffered.memory.js.map +1 -0
- package/esm/logger/buffered/file/buffered.file.js +38 -0
- package/esm/logger/buffered/file/buffered.file.js.map +1 -0
- package/esm/logger/buffered/file/index.js +2 -0
- package/esm/logger/buffered/file/index.js.map +1 -0
- package/esm/logger/buffered/index.js +4 -0
- package/esm/logger/buffered/index.js.map +1 -0
- package/esm/logger/console.js +0 -37
- package/esm/logger/console.js.map +1 -1
- package/esm/logger/empty.js +7 -0
- package/esm/logger/empty.js.map +1 -0
- package/esm/logger/index.js +3 -7
- package/esm/logger/index.js.map +1 -1
- package/esm/logger/loggable.js +35 -0
- package/esm/logger/loggable.js.map +1 -0
- package/esm/logger/manager.js +70 -20
- package/esm/logger/manager.js.map +1 -1
- package/esm/logger/named.js +8 -4
- package/esm/logger/named.js.map +1 -1
- package/esm/logger/provider.js +29 -0
- package/esm/logger/provider.js.map +1 -0
- package/esm/logger/proxy.js +2 -6
- package/esm/logger/proxy.js.map +1 -1
- package/esm/logger/types.js +6 -0
- package/esm/logger/types.js.map +1 -0
- package/esm/models/LogicModel.js +13 -11
- package/esm/models/LogicModel.js.map +1 -1
- package/esm/observing/event.js +5 -18
- package/esm/observing/event.js.map +1 -1
- package/esm/observing/progressTracker.js +8 -14
- package/esm/observing/progressTracker.js.map +1 -1
- package/esm/structures/promiseCache.js +14 -20
- package/esm/structures/promiseCache.js.map +1 -1
- package/esm/structures/queue/parallel.js +11 -13
- package/esm/structures/queue/parallel.js.map +1 -1
- package/esm/structures/subscribersMap.js +9 -7
- package/esm/structures/subscribersMap.js.map +1 -1
- package/package.json +13 -1
- package/tsconfig.cjs.tsbuildinfo +1 -1
- package/tsconfig.esm.tsbuildinfo +1 -1
- package/tsconfig.types.tsbuildinfo +1 -1
- package/types/api/call.types.d.ts +2 -2
- package/types/api/config.d.ts +11 -4
- package/types/api/extensions/endpointHooks.d.ts +1 -1
- package/types/api/index.d.ts +4 -2
- package/types/api/interceptor.d.ts +1 -1
- package/types/api/logging.d.ts +8 -6
- package/types/functions/assert.d.ts +3 -3
- package/types/functions/disposer.d.ts +7 -6
- package/types/functions/throttle.d.ts +4 -5
- package/types/logger/batch.d.ts +3 -2
- package/types/logger/buffered/base.d.ts +23 -0
- package/types/logger/buffered/buffered.logger.d.ts +8 -0
- package/types/logger/buffered/buffered.memory.d.ts +19 -0
- package/types/logger/buffered/file/buffered.file.d.ts +9 -0
- package/types/logger/buffered/file/index.d.ts +1 -0
- package/types/logger/buffered/index.d.ts +3 -0
- package/types/logger/console.d.ts +1 -13
- package/types/logger/empty.d.ts +3 -0
- package/types/logger/index.d.ts +6 -10
- package/types/logger/loggable.d.ts +13 -0
- package/types/logger/manager.d.ts +31 -7
- package/types/logger/named.d.ts +4 -3
- package/types/logger/provider.d.ts +11 -0
- package/types/logger/proxy.d.ts +1 -2
- package/types/logger/types.d.ts +21 -0
- package/types/models/LogicModel.d.ts +4 -4
- package/types/observing/event.d.ts +3 -6
- package/types/observing/progressTracker.d.ts +3 -4
- package/types/structures/promiseCache.d.ts +3 -4
- package/types/structures/queue/parallel.d.ts +3 -3
- package/types/structures/subscribersMap.d.ts +3 -2
- package/cjs/logger/abstractions.js +0 -3
- package/cjs/logger/abstractions.js.map +0 -1
- package/cjs/logger/file.js +0 -65
- package/cjs/logger/file.js.map +0 -1
- package/cjs/logger/shared.js +0 -18
- package/cjs/logger/shared.js.map +0 -1
- package/esm/logger/abstractions.js +0 -2
- package/esm/logger/abstractions.js.map +0 -1
- package/esm/logger/file.js +0 -60
- package/esm/logger/file.js.map +0 -1
- package/esm/logger/shared.js +0 -15
- package/esm/logger/shared.js.map +0 -1
- package/types/logger/abstractions.d.ts +0 -10
- package/types/logger/file.d.ts +0 -15
- package/types/logger/shared.d.ts +0 -15
package/esm/api/logging.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logging.js","sourceRoot":"","sources":["../../../src/api/logging.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAW/C,MAAM,KAAW,QAAQ,CAwExB;AAxED,WAAiB,QAAQ;IAIrB;;;;MAIE;IACF,SAAgB,YAAY,CAAc,IAAwB,EAAE,GAAQ;QACxE,IAAI,IAAI,EAAE,CAAC;YACP,IAAI,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,MAAM,IAAI,IAAI,KAAK,GAAG,EAAE,CAAC;gBACnD,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;YAC7B,CAAC;YAED,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;gBAC3B,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;gBACtB,IAAI,GAAG,KAAK,IAAI,EAAE,CAAC;oBACf,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;gBAC7B,CAAC;gBAED,IAAI,OAAO,GAAG,KAAK,UAAU,EAAE,CAAC;oBAC5B,OAAO;wBACH,OAAO,EAAE,IAAI;wBACb,SAAS,EAAE,GAAG;qBACjB,CAAC;gBACN,CAAC;YACL,CAAC;QACL,CAAC;QAED,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;IAC9B,CAAC;IAtBe,qBAAY,eAsB3B,CAAA;
|
|
1
|
+
{"version":3,"file":"logging.js","sourceRoot":"","sources":["../../../src/api/logging.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAW/C,MAAM,KAAW,QAAQ,CAwExB;AAxED,WAAiB,QAAQ;IAIrB;;;;MAIE;IACF,SAAgB,YAAY,CAAc,IAAwB,EAAE,GAAQ;QACxE,IAAI,IAAI,EAAE,CAAC;YACP,IAAI,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,MAAM,IAAI,IAAI,KAAK,GAAG,EAAE,CAAC;gBACnD,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;YAC7B,CAAC;YAED,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;gBAC3B,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;gBACtB,IAAI,GAAG,KAAK,IAAI,EAAE,CAAC;oBACf,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;gBAC7B,CAAC;gBAED,IAAI,OAAO,GAAG,KAAK,UAAU,EAAE,CAAC;oBAC5B,OAAO;wBACH,OAAO,EAAE,IAAI;wBACb,SAAS,EAAE,GAAG;qBACjB,CAAC;gBACN,CAAC;YACL,CAAC;QACL,CAAC;QAED,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;IAC9B,CAAC;IAtBe,qBAAY,eAsB3B,CAAA;IAqBD,SAAgB,OAAO,CAAC,MAAe,EAAE,GAAyB,EAAE,GAAiB,EAAE,YAAsB;QACzG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,GAAG,KAAK,KAAK,IAAI,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,KAAK,eAAe,CAAC,GAAG,IAAI,GAAG,CAAC,IAAI,IAAI,IAAI,CAAC,EAAE,CAAC;YACxG,OAAO;QACX,CAAC;QAED,MAAM,IAAI,GAAG,QAAQ,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QACvD,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAChB,OAAO;QACX,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS;YAC7B,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,IAAI,GAAG,CAAC,IAAI,CAAC;YAC1C,CAAC,CAAC,CAAC,YAAY,IAAI,GAAG,CAAC,IAAI,CAAC,CAAC;QAEjC,MAAM,MAAM,GAAG,GAAG,KAAK,KAAK;YACxB,CAAC,CAAC,WAAW;YACb,CAAC,CAAC,WAAW,CAAC;QAElB,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC;IAClE,CAAC;IAnBe,gBAAO,UAmBtB,CAAA;AACL,CAAC,EAxEgB,QAAQ,KAAR,QAAQ,QAwExB"}
|
package/esm/functions/assert.js
CHANGED
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
import { Getter } from '../types/index.js';
|
|
2
|
-
import logger from '../logger/shared.js';
|
|
3
2
|
export function createAssert(logger) {
|
|
4
3
|
return function assert(condition, error, objectToLog) {
|
|
5
4
|
if (condition) {
|
|
6
5
|
return;
|
|
7
6
|
}
|
|
8
7
|
const e = Getter.toValue(error);
|
|
9
|
-
if (objectToLog) {
|
|
8
|
+
if (objectToLog && logger) {
|
|
10
9
|
logger.error('Assertion failed:', e, Getter.toValue(objectToLog));
|
|
11
10
|
}
|
|
12
11
|
if (typeof e === 'string') {
|
|
@@ -15,5 +14,5 @@ export function createAssert(logger) {
|
|
|
15
14
|
throw e;
|
|
16
15
|
};
|
|
17
16
|
}
|
|
18
|
-
export const assert = createAssert(
|
|
17
|
+
export const assert = createAssert();
|
|
19
18
|
//# sourceMappingURL=assert.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"assert.js","sourceRoot":"","sources":["../../../src/functions/assert.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"assert.js","sourceRoot":"","sources":["../../../src/functions/assert.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAiB,MAAM,mBAAmB,CAAC;AAK1D,MAAM,UAAU,YAAY,CAAC,MAA0B;IACnD,OAAO,SAAS,MAAM,CAAC,SAAkB,EAAE,KAA6B,EAAE,WAAyB;QAC/F,IAAI,SAAS,EAAE,CAAC;YACZ,OAAO;QACX,CAAC;QAED,MAAM,CAAC,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAChC,IAAI,WAAW,IAAI,MAAM,EAAE,CAAC;YACxB,MAAM,CAAC,KAAK,CAAC,mBAAmB,EAAE,CAAC,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC;QACtE,CAAC;QAED,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE,CAAC;YACxB,MAAM,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC;QACvB,CAAC;QAED,MAAM,CAAC,CAAC;IACZ,CAAC,CAAC;AACN,CAAC;AAED,MAAM,CAAC,MAAM,MAAM,GAAa,YAAY,EAAE,CAAC"}
|
|
@@ -1,15 +1,7 @@
|
|
|
1
|
-
import
|
|
2
|
-
export class Disposer {
|
|
1
|
+
import { Loggable } from '../logger/loggable.js';
|
|
2
|
+
export class Disposer extends Loggable {
|
|
3
3
|
_disposers = [];
|
|
4
4
|
_map = new Map();
|
|
5
|
-
_loggerName = null;
|
|
6
|
-
constructor(loggerName = null) {
|
|
7
|
-
this._loggerName = loggerName;
|
|
8
|
-
}
|
|
9
|
-
setLoggerName(loggerName) {
|
|
10
|
-
this._loggerName = loggerName;
|
|
11
|
-
return this;
|
|
12
|
-
}
|
|
13
5
|
add(d, id) {
|
|
14
6
|
if (!d) {
|
|
15
7
|
return;
|
|
@@ -39,8 +31,8 @@ export class Disposer {
|
|
|
39
31
|
d();
|
|
40
32
|
}
|
|
41
33
|
dispose(log = false) {
|
|
42
|
-
if (log) {
|
|
43
|
-
logger.log(`
|
|
34
|
+
if (log && this.logger) {
|
|
35
|
+
this.logger.log(`Disposing ${this._disposers.length} items including named ones:`, Array.from(this._map.entries()).map(e => e[0]));
|
|
44
36
|
}
|
|
45
37
|
const copy = this._disposers.slice().reverse();
|
|
46
38
|
this._disposers.length = 0;
|
|
@@ -52,16 +44,17 @@ export class Disposer {
|
|
|
52
44
|
export function combineDisposers(...items) {
|
|
53
45
|
return () => items.forEach(i => i());
|
|
54
46
|
}
|
|
55
|
-
export class Disposable {
|
|
56
|
-
disposer;
|
|
47
|
+
export class Disposable extends Loggable {
|
|
48
|
+
disposer = new Disposer();
|
|
57
49
|
_isDisposed = false;
|
|
58
|
-
constructor(loggerName = null) {
|
|
59
|
-
this.disposer = new Disposer(loggerName);
|
|
60
|
-
}
|
|
61
50
|
dispose = () => {
|
|
62
51
|
this._isDisposed = true;
|
|
63
52
|
this.disposer.dispose();
|
|
64
53
|
};
|
|
54
|
+
setLogger(logger) {
|
|
55
|
+
this.disposer.setLogger(logger);
|
|
56
|
+
return super.setLogger(logger);
|
|
57
|
+
}
|
|
65
58
|
}
|
|
66
59
|
export function isDisposable(v) {
|
|
67
60
|
return !!v && typeof v === 'object' && 'dispose' in v && typeof v.dispose === 'function';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"disposer.js","sourceRoot":"","sources":["../../../src/functions/disposer.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"disposer.js","sourceRoot":"","sources":["../../../src/functions/disposer.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,14 +1,13 @@
|
|
|
1
1
|
import { createManualPromise } from '../async/manualPromise.js';
|
|
2
|
-
import {
|
|
2
|
+
import { Loggable } from '../logger/index.js';
|
|
3
3
|
import { random } from '../math/index.js';
|
|
4
4
|
import { catchPromise } from './safe.js';
|
|
5
5
|
/** Runs a callback after a timeout, ignoring all consecutive calls until the first is processed. */
|
|
6
|
-
export class ThrottleAction {
|
|
6
|
+
export class ThrottleAction extends Loggable {
|
|
7
7
|
timeout;
|
|
8
8
|
_timeoutRef = null;
|
|
9
9
|
_postponedCb = null;
|
|
10
10
|
_locked = false;
|
|
11
|
-
_logger = null;
|
|
12
11
|
/**
|
|
13
12
|
* In case previous action has started processing but not finished yet, and the following one is going to start,
|
|
14
13
|
* this flag allows to run the second in parallel.
|
|
@@ -16,21 +15,13 @@ export class ThrottleAction {
|
|
|
16
15
|
_allowParallelRuns = false;
|
|
17
16
|
_currentRun = null;
|
|
18
17
|
constructor(timeout = 1000) {
|
|
18
|
+
super();
|
|
19
19
|
this.timeout = timeout;
|
|
20
20
|
}
|
|
21
21
|
useParallelRuns() {
|
|
22
22
|
this._allowParallelRuns = true;
|
|
23
23
|
return this;
|
|
24
24
|
}
|
|
25
|
-
useLogger(logger) {
|
|
26
|
-
if (typeof logger === 'string') {
|
|
27
|
-
this._logger = createLogger(logger);
|
|
28
|
-
}
|
|
29
|
-
else {
|
|
30
|
-
this._logger = logger;
|
|
31
|
-
}
|
|
32
|
-
return this;
|
|
33
|
-
}
|
|
34
25
|
clear() {
|
|
35
26
|
if (this._timeoutRef) {
|
|
36
27
|
clearTimeout(this._timeoutRef);
|
|
@@ -64,7 +55,7 @@ export class ThrottleAction {
|
|
|
64
55
|
// This is probably OK since the running call should cover the current one.
|
|
65
56
|
// TODO Maybe just don't start timeout if the lock is set?
|
|
66
57
|
// The reason for not doing that 👆 is there's still a valid case when previous is still working but it's legit to start a new one (e.g. some state has changed already)
|
|
67
|
-
this.
|
|
58
|
+
this.logger?.warn('[ThrottleAction] THROTTLE LOCKED, but another call is forced. Skipping since the behavior is undefined.');
|
|
68
59
|
}
|
|
69
60
|
else if (cb) {
|
|
70
61
|
let result = undefined;
|
|
@@ -103,8 +94,8 @@ export class ThrottleProcessor {
|
|
|
103
94
|
this._action = new ThrottleAction(timeout)
|
|
104
95
|
.useParallelRuns();
|
|
105
96
|
}
|
|
106
|
-
|
|
107
|
-
this._action.
|
|
97
|
+
setLogger(logger) {
|
|
98
|
+
this._action.setLogger(logger);
|
|
108
99
|
return this;
|
|
109
100
|
}
|
|
110
101
|
async push(data) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"throttle.js","sourceRoot":"","sources":["../../../src/functions/throttle.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiB,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAC/E,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"throttle.js","sourceRoot":"","sources":["../../../src/functions/throttle.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiB,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAC/E,OAAO,EAAE,QAAQ,EAAgB,MAAM,oBAAoB,CAAC;AAC5D,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAE1C,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAIzC,qGAAqG;AACrG,MAAM,OAAO,cAAwB,SAAQ,QAAQ;IAc9B;IAZX,WAAW,GAAyC,IAAI,CAAC;IACzD,YAAY,GAAuB,IAAI,CAAC;IACxC,OAAO,GAAmB,KAAK,CAAC;IAExC;;;QAGI;IACI,kBAAkB,GAAG,KAAK,CAAC;IAE3B,WAAW,GAAwC,IAAI,CAAC;IAEhE,YAAmB,UAAU,IAAI;QAC7B,KAAK,EAAE,CAAC;QADO,YAAO,GAAP,OAAO,CAAO;IAEjC,CAAC;IAEM,eAAe;QAClB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QAC/B,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,KAAK;QACD,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACnC,CAAC;QACD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC7B,CAAC;IAED,MAAM,CAAC,EAAwB,EAAE,cAAc,GAAG,KAAK;QACnD,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,oBAAoB;YACzC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;gBACpB,IAAI,CAAC,WAAW,GAAG,mBAAmB,EAAiB,CAAC;YAC5D,CAAC;YAED,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;YAExC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;YACvB,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;YAEjF,OAAO,MAAM,CAAC;QAClB,CAAC;QAED,IAAI,cAAc,EAAE,CAAC;YACjB,IAAI,CAAC,KAAK,EAAE,CAAC;YACb,OAAO,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;QAClC,CAAC;QAED,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC;IAC7B,CAAC;IAED,QAAQ,GAAG,KAAK,IAAI,EAAE;QAClB,MAAM,EAAE,GAAG,IAAI,CAAC,YAAY,CAAC;QAC7B,MAAM,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC;QAC3B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QAExB,IAAI,CAAC,KAAK,EAAE,CAAC;QAEb,IAAI,CAAC,IAAI,CAAC,kBAAkB,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YAC3C,4HAA4H;YAC5H,2EAA2E;YAC3E,0DAA0D;YAC1D,wKAAwK;YACxK,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,yGAAyG,CAAC,CAAC;QACjI,CAAC;aAAM,IAAI,EAAE,EAAE,CAAC;YACZ,IAAI,MAAM,GAAkB,SAAS,CAAC;YACtC,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;YACpC,IAAI,CAAC;gBACD,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;gBACtB,MAAM,GAAG,MAAM,EAAE,EAAE,CAAC;gBACpB,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;gBACnB,OAAO,MAAM,CAAC;YAClB,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACX,CAAC,EAAE,MAAM,CAAC,GAAY,CAAC,CAAC;gBACxB,OAAO,SAAS,CAAC;YACrB,CAAC;oBAAS,CAAC;gBACP,IAAI,IAAI,CAAC,OAAO,KAAK,MAAM,EAAE,CAAC;oBAC1B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;gBACzB,CAAC;YACL,CAAC;QACL,CAAC;IACL,CAAC,CAAC;IAEF,UAAU;QACN,OAAO,IAAI,CAAC,WAAW,EAAE,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACnE,CAAC;CACJ;AAID,MAAM,OAAO,iBAAiB;IAOG;IALZ,MAAM,GAAe,EAAE,CAAC;IACxB,OAAO,CAAsC;IAEtD,QAAQ,GAAkC,IAAI,CAAC;IAEvD,YAA6B,OAA+C,EAAE,OAAO,GAAG,IAAI;QAA/D,YAAO,GAAP,OAAO,CAAwC;QACxE,IAAI,CAAC,OAAO,EAAE,CAAC;YACX,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;QAC9C,CAAC;QAED,IAAI,CAAC,OAAO,GAAG,IAAI,cAAc,CAAC,OAAO,CAAC;aACrC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAEM,SAAS,CAAC,MAAuB;QACpC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAC/B,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,IAAc;QACrB,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAEzC,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;QAE3D,OAAO;YACH,MAAM,EAAE,GAAG;YACX,KAAK;SACR,CAAC;IACN,CAAC;IAEO,QAAQ,GAAG,KAAK,IAAI,EAAE;QAC1B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;YACtB,OAAO;QACX,CAAC;QAED,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;QACjC,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;QAEvB,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC,CAAC;IAEF,KAAK;QACD,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,EAAE,OAAO,CAAC,SAAoB,CAAC,CAAC;QAC7C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IACzB,CAAC;CACJ"}
|
package/esm/logger/batch.js
CHANGED
|
@@ -1,8 +1,28 @@
|
|
|
1
|
+
import { EMPTY_LOGGER } from './empty.js';
|
|
1
2
|
export function batchLoggers(...loggers) {
|
|
3
|
+
const filtered = loggers.filter(l => !!l);
|
|
4
|
+
if (filtered.length === 0) {
|
|
5
|
+
return EMPTY_LOGGER;
|
|
6
|
+
}
|
|
7
|
+
if (filtered.length === 1) {
|
|
8
|
+
return filtered[0];
|
|
9
|
+
}
|
|
2
10
|
return {
|
|
3
|
-
log: (...args) =>
|
|
4
|
-
|
|
5
|
-
|
|
11
|
+
log: (...args) => {
|
|
12
|
+
for (let i = 0, len = filtered.length; i < len; ++i) {
|
|
13
|
+
filtered[i].log(...args);
|
|
14
|
+
}
|
|
15
|
+
},
|
|
16
|
+
warn: (...args) => {
|
|
17
|
+
for (let i = 0, len = filtered.length; i < len; ++i) {
|
|
18
|
+
filtered[i].warn(...args);
|
|
19
|
+
}
|
|
20
|
+
},
|
|
21
|
+
error: (...args) => {
|
|
22
|
+
for (let i = 0, len = filtered.length; i < len; ++i) {
|
|
23
|
+
filtered[i].error(...args);
|
|
24
|
+
}
|
|
25
|
+
},
|
|
6
26
|
};
|
|
7
27
|
}
|
|
8
28
|
//# sourceMappingURL=batch.js.map
|
package/esm/logger/batch.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"batch.js","sourceRoot":"","sources":["../../../src/logger/batch.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,YAAY,CAAC,GAAG,
|
|
1
|
+
{"version":3,"file":"batch.js","sourceRoot":"","sources":["../../../src/logger/batch.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAE1C,MAAM,UAAU,YAAY,CAAC,GAAG,OAA4B;IACxD,MAAM,QAAQ,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1C,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACxB,OAAO,YAAY,CAAC;IACxB,CAAC;IAED,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACxB,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC;IAED,OAAO;QACH,GAAG,EAAE,CAAC,GAAG,IAAW,EAAE,EAAE;YACpB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,GAAG,GAAG,EAAE,EAAE,CAAC,EAAE,CAAC;gBAClD,QAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;YAC7B,CAAC;QACL,CAAC;QACD,IAAI,EAAE,CAAC,GAAG,IAAW,EAAE,EAAE;YACrB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,GAAG,GAAG,EAAE,EAAE,CAAC,EAAE,CAAC;gBAClD,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;YAC9B,CAAC;QACL,CAAC;QACD,KAAK,EAAE,CAAC,GAAG,IAAW,EAAE,EAAE;YACtB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,GAAG,GAAG,EAAE,EAAE,CAAC,EAAE,CAAC;gBAClD,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;YAC/B,CAAC;QACL,CAAC;KACJ,CAAC;AACN,CAAC"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { LogLevels } from '../types.js';
|
|
2
|
+
export class BaseBufferedLogger {
|
|
3
|
+
name;
|
|
4
|
+
_buffer = [];
|
|
5
|
+
_maxBufferSize = 100;
|
|
6
|
+
constructor(name) {
|
|
7
|
+
this.name = name;
|
|
8
|
+
}
|
|
9
|
+
get entries() { return this._buffer.length; }
|
|
10
|
+
get maxBufferSize() { return this._maxBufferSize; }
|
|
11
|
+
getBuffer() { return this._buffer.slice(); }
|
|
12
|
+
withMaxBufferSize(size) {
|
|
13
|
+
this._maxBufferSize = size;
|
|
14
|
+
return this;
|
|
15
|
+
}
|
|
16
|
+
log(...args) {
|
|
17
|
+
this._buffer.push([LogLevels.log, args, Date.now()]);
|
|
18
|
+
this.tryAutoFlush();
|
|
19
|
+
}
|
|
20
|
+
warn(...args) {
|
|
21
|
+
this._buffer.push([LogLevels.warn, args, Date.now()]);
|
|
22
|
+
this.tryAutoFlush();
|
|
23
|
+
}
|
|
24
|
+
error(...args) {
|
|
25
|
+
this._buffer.push([LogLevels.error, args, Date.now()]);
|
|
26
|
+
this.tryAutoFlush();
|
|
27
|
+
}
|
|
28
|
+
flush() {
|
|
29
|
+
if (this._buffer.length > 0) {
|
|
30
|
+
const copy = this._buffer.slice();
|
|
31
|
+
this._buffer.length = 0;
|
|
32
|
+
this.doFlush(copy);
|
|
33
|
+
this.onFlushed();
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
dispose() {
|
|
37
|
+
this.flush();
|
|
38
|
+
}
|
|
39
|
+
onFlushed() {
|
|
40
|
+
// Optional: Override to handle post-flush actions
|
|
41
|
+
}
|
|
42
|
+
tryAutoFlush() {
|
|
43
|
+
if (this._buffer.length >= this._maxBufferSize) {
|
|
44
|
+
this.flush();
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=base.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../src/logger/buffered/base.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAqC,MAAM,aAAa,CAAC;AAK3E,MAAM,OAAgB,kBAAkB;IAIR;IAHX,OAAO,GAAe,EAAE,CAAC;IAClC,cAAc,GAAG,GAAG,CAAC;IAE7B,YAA4B,IAAY;QAAZ,SAAI,GAAJ,IAAI,CAAQ;IAAI,CAAC;IAE7C,IAAW,OAAO,KAAK,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC;IACpD,IAAW,aAAa,KAAK,OAAO,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;IAEnD,SAAS,KAAK,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;IAEnD,iBAAiB,CAAC,IAAY;QAC1B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,GAAG,CAAC,GAAG,IAAW;QACd,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QACrD,IAAI,CAAC,YAAY,EAAE,CAAC;IACxB,CAAC;IAED,IAAI,CAAC,GAAG,IAAW;QACf,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QACtD,IAAI,CAAC,YAAY,EAAE,CAAC;IACxB,CAAC;IAED,KAAK,CAAC,GAAG,IAAW;QAChB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QACvD,IAAI,CAAC,YAAY,EAAE,CAAC;IACxB,CAAC;IAED,KAAK;QACD,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC1B,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YAClC,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC;YACxB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACnB,IAAI,CAAC,SAAS,EAAE,CAAC;QACrB,CAAC;IACL,CAAC;IAED,OAAO;QACH,IAAI,CAAC,KAAK,EAAE,CAAC;IACjB,CAAC;IAIS,SAAS;QACf,kDAAkD;IACtD,CAAC;IAES,YAAY;QAClB,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YAC7C,IAAI,CAAC,KAAK,EAAE,CAAC;QACjB,CAAC;IACL,CAAC;CAEJ"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { clamp } from '../../math/calc.js';
|
|
2
|
+
import { LogLevels } from '../types.js';
|
|
3
|
+
import { BaseBufferedLogger } from './base.js';
|
|
4
|
+
const Prefixes = {
|
|
5
|
+
[1]: '\n\t--->',
|
|
6
|
+
[2]: '\n\t---> [WARN]',
|
|
7
|
+
[3]: '\n\t---> [ERROR]',
|
|
8
|
+
};
|
|
9
|
+
export class BufferedLogger extends BaseBufferedLogger {
|
|
10
|
+
_target;
|
|
11
|
+
_binded;
|
|
12
|
+
constructor(name, target) {
|
|
13
|
+
super(name);
|
|
14
|
+
this._target = target;
|
|
15
|
+
this._binded = {
|
|
16
|
+
[LogLevels.log]: this._target.log.bind(this._target),
|
|
17
|
+
[LogLevels.warn]: this._target.warn.bind(this._target),
|
|
18
|
+
[LogLevels.error]: this._target.error.bind(this._target),
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
doFlush(buffer) {
|
|
22
|
+
const result = [
|
|
23
|
+
this.name,
|
|
24
|
+
];
|
|
25
|
+
let maxLevel = LogLevels.log;
|
|
26
|
+
for (const [level, args] of buffer) {
|
|
27
|
+
if (level > maxLevel) {
|
|
28
|
+
maxLevel = level;
|
|
29
|
+
}
|
|
30
|
+
result.push(Prefixes[level], ...args);
|
|
31
|
+
}
|
|
32
|
+
maxLevel = clamp(maxLevel, LogLevels.log, LogLevels.error);
|
|
33
|
+
this._binded[maxLevel](...result);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=buffered.logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buffered.logger.js","sourceRoot":"","sources":["../../../../src/logger/buffered/buffered.logger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAC3C,OAAO,EAAE,SAAS,EAAqD,MAAM,aAAa,CAAC;AAC3F,OAAO,EAAE,kBAAkB,EAAY,MAAM,WAAW,CAAC;AAEzD,MAAM,QAAQ,GAAmC;IAC7C,CAAC,CAAC,CAAC,EAAE,UAAU;IACf,CAAC,CAAC,CAAC,EAAE,iBAAiB;IACtB,CAAC,CAAC,CAAC,EAAE,kBAAkB;CAC1B,CAAC;AAEF,MAAM,OAAO,cAAe,SAAQ,kBAAkB;IAEjC,OAAO,CAAU;IAC1B,OAAO,CAAiC;IAEhD,YAAY,IAAY,EAAE,MAAe;QACrC,KAAK,CAAC,IAAI,CAAC,CAAC;QACZ,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;QACtB,IAAI,CAAC,OAAO,GAAG;YACX,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC;YACpD,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC;YACtD,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC;SAC3D,CAAC;IACN,CAAC;IAES,OAAO,CAAC,MAAkB;QAChC,MAAM,MAAM,GAAU;YAClB,IAAI,CAAC,IAAI;SACZ,CAAC;QACF,IAAI,QAAQ,GAAW,SAAS,CAAC,GAAG,CAAC;QAErC,KAAK,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,MAAM,EAAE,CAAC;YACjC,IAAI,KAAK,GAAG,QAAQ,EAAE,CAAC;gBACnB,QAAQ,GAAG,KAAK,CAAC;YACrB,CAAC;YAED,MAAM,CAAC,IAAI,CACP,QAAQ,CAAC,KAAK,CAAC,EACf,GAAG,IAAI,CACV,CAAC;QACN,CAAC;QAED,QAAQ,GAAG,KAAK,CAAC,QAAQ,EAAE,SAAS,CAAC,GAAG,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC;QAE3D,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC;IACtC,CAAC;CACJ"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { BaseBufferedLogger } from './base.js';
|
|
2
|
+
const Prefixes = {
|
|
3
|
+
[1]: '[LOG]',
|
|
4
|
+
[2]: '[WARN]',
|
|
5
|
+
[3]: '[ERROR]',
|
|
6
|
+
};
|
|
7
|
+
export class BufferedMemoryLogger extends BaseBufferedLogger {
|
|
8
|
+
_memory = [];
|
|
9
|
+
_timestamps = false;
|
|
10
|
+
_argFormatter = formatArg;
|
|
11
|
+
_argsJoiner = (args) => args.filter(Boolean).join(' ');
|
|
12
|
+
constructor(name) {
|
|
13
|
+
super(name);
|
|
14
|
+
}
|
|
15
|
+
setArgsJoiner(joiner) {
|
|
16
|
+
this._argsJoiner = joiner;
|
|
17
|
+
return this;
|
|
18
|
+
}
|
|
19
|
+
setArgFormatter(formatter) {
|
|
20
|
+
this._argFormatter = formatter;
|
|
21
|
+
return this;
|
|
22
|
+
}
|
|
23
|
+
withTimestamps() {
|
|
24
|
+
this._timestamps = true;
|
|
25
|
+
return this;
|
|
26
|
+
}
|
|
27
|
+
getMemory(clear = false) {
|
|
28
|
+
if (clear) {
|
|
29
|
+
const copy = this._memory;
|
|
30
|
+
this._memory = [];
|
|
31
|
+
return copy;
|
|
32
|
+
}
|
|
33
|
+
return this._memory.slice();
|
|
34
|
+
}
|
|
35
|
+
clearMemory() {
|
|
36
|
+
this._memory.length = 0;
|
|
37
|
+
}
|
|
38
|
+
getPrefix(level) {
|
|
39
|
+
return Prefixes[level];
|
|
40
|
+
}
|
|
41
|
+
getTimestamp(timestamp) {
|
|
42
|
+
return new Date(timestamp).toISOString();
|
|
43
|
+
}
|
|
44
|
+
formatLine(line) {
|
|
45
|
+
return this._argsJoiner(line.map(this._argFormatter));
|
|
46
|
+
}
|
|
47
|
+
doFlush(buffer) {
|
|
48
|
+
for (const [level, args, timestamp] of buffer) {
|
|
49
|
+
this._memory.push(this.combineLine(level, args, timestamp));
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
combineLine(level, args, timestamp) {
|
|
53
|
+
const line = [];
|
|
54
|
+
if (this._timestamps) {
|
|
55
|
+
line.push(this.getTimestamp(timestamp));
|
|
56
|
+
}
|
|
57
|
+
line.push(this.getPrefix(level), ...args);
|
|
58
|
+
return this.formatLine(line);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
function formatArg(arg) {
|
|
62
|
+
if (typeof arg === 'object') {
|
|
63
|
+
return JSON.stringify(arg);
|
|
64
|
+
}
|
|
65
|
+
return String(arg);
|
|
66
|
+
}
|
|
67
|
+
//# sourceMappingURL=buffered.memory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buffered.memory.js","sourceRoot":"","sources":["../../../../src/logger/buffered/buffered.memory.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAY,MAAM,WAAW,CAAC;AAEzD,MAAM,QAAQ,GAAmC;IAC7C,CAAC,CAAC,CAAC,EAAE,OAAO;IACZ,CAAC,CAAC,CAAC,EAAE,QAAQ;IACb,CAAC,CAAC,CAAC,EAAE,SAAS;CACjB,CAAC;AAEF,MAAM,OAAO,oBAAqB,SAAQ,kBAAkB;IAE9C,OAAO,GAAa,EAAE,CAAC;IACzB,WAAW,GAAY,KAAK,CAAC;IAE7B,aAAa,GAAG,SAAS,CAAC;IAC1B,WAAW,GAAG,CAAC,IAAc,EAAU,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAEjF,YAAY,IAAY;QACpB,KAAK,CAAC,IAAI,CAAC,CAAC;IAChB,CAAC;IAED,aAAa,CAAC,MAAkC;QAC5C,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;QAC1B,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,eAAe,CAAC,SAAmC;QAC/C,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;QAC/B,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,cAAc;QACV,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,OAAO,IAAI,CAAC;IAChB,CAAC;IAEM,SAAS,CAAC,KAAK,GAAG,KAAK;QAC1B,IAAI,KAAK,EAAE,CAAC;YACR,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC;YAC1B,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;YAClB,OAAO,IAAI,CAAC;QAChB,CAAC;QAED,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;IAChC,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC;IAC5B,CAAC;IAES,SAAS,CAAC,KAAqB;QACrC,OAAO,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAES,YAAY,CAAC,SAAiB;QACpC,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;IAC7C,CAAC;IAES,UAAU,CAAC,IAAW;QAC5B,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;IAC1D,CAAC;IAES,OAAO,CAAC,MAAkB;QAChC,KAAK,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,SAAS,CAAC,IAAI,MAAM,EAAE,CAAC;YAC5C,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,IAAI,EAAE,SAAS,CAAC,CAAC,CAAC;QAChE,CAAC;IACL,CAAC;IAES,WAAW,CAAC,KAAqB,EAAE,IAAW,EAAE,SAAiB;QACvE,MAAM,IAAI,GAAU,EAAE,CAAC;QAEvB,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC;QAC5C,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC;QAE1C,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;CACJ;AAED,SAAS,SAAS,CAAC,GAAQ;IACvB,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE,CAAC;QAC1B,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IAC/B,CAAC;IACD,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC;AACvB,CAAC"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/* eslint-disable no-console */
|
|
2
|
+
import * as Path from 'node:path';
|
|
3
|
+
import * as FS from 'node:fs';
|
|
4
|
+
import * as Util from 'node:util';
|
|
5
|
+
import { BufferedMemoryLogger } from '../buffered.memory.js';
|
|
6
|
+
export class FileLoggerNode extends BufferedMemoryLogger {
|
|
7
|
+
_logFilePath = null;
|
|
8
|
+
setLogFilePath(path) {
|
|
9
|
+
this._logFilePath = path;
|
|
10
|
+
return this;
|
|
11
|
+
}
|
|
12
|
+
setLogName(name) {
|
|
13
|
+
const n = name ? `-${name}` : '';
|
|
14
|
+
this._logFilePath = Path.resolve(process.cwd(), `run${n}.${new Date().toISOString()}.log`);
|
|
15
|
+
return this;
|
|
16
|
+
}
|
|
17
|
+
formatLine(line) {
|
|
18
|
+
return Util.format.apply(null, line);
|
|
19
|
+
}
|
|
20
|
+
onFlushed() {
|
|
21
|
+
super.onFlushed();
|
|
22
|
+
// should transfer the internal buffer to the memory, formatted
|
|
23
|
+
// copy and clear the memory
|
|
24
|
+
const memory = this.getMemory(true);
|
|
25
|
+
try {
|
|
26
|
+
if (this._logFilePath) {
|
|
27
|
+
this.appendToFileSync(this._logFilePath, memory.join(''));
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
catch (err) {
|
|
31
|
+
console.warn('Failed to flush file, error', err);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
appendToFileSync(path, data) {
|
|
35
|
+
FS.appendFileSync(path, data);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=buffered.file.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buffered.file.js","sourceRoot":"","sources":["../../../../../src/logger/buffered/file/buffered.file.ts"],"names":[],"mappings":"AACA,+BAA+B;AAC/B,OAAO,KAAK,IAAI,MAAM,WAAW,CAAC;AAClC,OAAO,KAAK,EAAE,MAAM,SAAS,CAAC;AAC9B,OAAO,KAAK,IAAI,MAAM,WAAW,CAAC;AAElC,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAE7D,MAAM,OAAO,cAAe,SAAQ,oBAAoB;IAC5C,YAAY,GAAkB,IAAI,CAAC;IAE3C,cAAc,CAAC,IAAY;QACvB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,UAAU,CAAC,IAAY;QACnB,MAAM,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACjC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,MAAM,CAAC,IAAI,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC;QAC3F,OAAO,IAAI,CAAC;IAChB,CAAC;IAES,UAAU,CAAC,IAAW;QAC5B,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACzC,CAAC;IAES,SAAS;QACf,KAAK,CAAC,SAAS,EAAE,CAAC;QAElB,+DAA+D;QAC/D,4BAA4B;QAC5B,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEpC,IAAI,CAAC;YACD,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;gBACpB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,YAAY,EAAE,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;YAC9D,CAAC;QACL,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACX,OAAO,CAAC,IAAI,CAAC,6BAA6B,EAAE,GAAG,CAAC,CAAC;QACrD,CAAC;IACL,CAAC;IAES,gBAAgB,CAAC,IAAY,EAAE,IAAY;QACjD,EAAE,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAClC,CAAC;CACJ"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/logger/buffered/file/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/logger/buffered/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,cAAc,sBAAsB,CAAC;AACrC,cAAc,sBAAsB,CAAC"}
|
package/esm/logger/console.js
CHANGED
|
@@ -3,41 +3,4 @@ export const CONSOLE = console;
|
|
|
3
3
|
export class ConsoleLogger extends NamedLogger {
|
|
4
4
|
get implementation() { return CONSOLE; }
|
|
5
5
|
}
|
|
6
|
-
export class BufferedConsoleLogger {
|
|
7
|
-
_name;
|
|
8
|
-
_logs = [];
|
|
9
|
-
_level = 1;
|
|
10
|
-
_log = CONSOLE.log;
|
|
11
|
-
constructor(name) {
|
|
12
|
-
this._name = name || '';
|
|
13
|
-
}
|
|
14
|
-
log(...args) {
|
|
15
|
-
this._logs.push('\t--->', ...args);
|
|
16
|
-
}
|
|
17
|
-
warn(...args) {
|
|
18
|
-
this._logs.push('\t---> [WARN]', ...args);
|
|
19
|
-
this._raiseLevel(2);
|
|
20
|
-
}
|
|
21
|
-
error(...args) {
|
|
22
|
-
this._logs.push('\t---> [ERROR]', ...args);
|
|
23
|
-
this._raiseLevel(3);
|
|
24
|
-
}
|
|
25
|
-
flush() {
|
|
26
|
-
if (this._logs.length > 0) {
|
|
27
|
-
this._log(this._name, ...this._logs);
|
|
28
|
-
this._logs.length = 0;
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
_raiseLevel(l) {
|
|
32
|
-
if (l > this._level) {
|
|
33
|
-
this._level = l;
|
|
34
|
-
if (l >= 3) {
|
|
35
|
-
this._log = CONSOLE.error;
|
|
36
|
-
}
|
|
37
|
-
else if (l >= 2) {
|
|
38
|
-
this._log = CONSOLE.warn;
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
6
|
//# sourceMappingURL=console.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"console.js","sourceRoot":"","sources":["../../../src/logger/console.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAEzC,MAAM,CAAC,MAAM,OAAO,GAAY,OAAO,CAAC;AAExC,MAAM,OAAO,aAAc,SAAQ,WAAW;IAC1C,IAAc,cAAc,KAAK,OAAO,OAAO,CAAC,CAAC,CAAC;CACrD
|
|
1
|
+
{"version":3,"file":"console.js","sourceRoot":"","sources":["../../../src/logger/console.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAEzC,MAAM,CAAC,MAAM,OAAO,GAAY,OAAO,CAAC;AAExC,MAAM,OAAO,aAAc,SAAQ,WAAW;IAC1C,IAAc,cAAc,KAAK,OAAO,OAAO,CAAC,CAAC,CAAC;CACrD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"empty.js","sourceRoot":"","sources":["../../../src/logger/empty.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,cAAc,GAAmB,GAAG,EAAE,GAAe,CAAC,CAAC;AAEpE,MAAM,CAAC,MAAM,YAAY,GAAY;IACjC,GAAG,EAAE,cAAc;IACnB,IAAI,EAAE,cAAc;IACpB,KAAK,EAAE,cAAc;CACxB,CAAC"}
|
package/esm/logger/index.js
CHANGED
|
@@ -1,12 +1,8 @@
|
|
|
1
1
|
import { ConsoleLogger } from './console.js';
|
|
2
2
|
import { batchLoggers } from './batch.js';
|
|
3
3
|
import { LoggersManager } from './manager.js';
|
|
4
|
+
import { Loggable } from './loggable.js';
|
|
5
|
+
import { LoggerProvider } from './provider.js';
|
|
4
6
|
export { NamedLogger } from './named.js';
|
|
5
|
-
export { ConsoleLogger, batchLoggers };
|
|
6
|
-
export { LoggersManager };
|
|
7
|
-
/** Shared logger instance used internally in this library.
|
|
8
|
-
*
|
|
9
|
-
* For internal default loggers to be enabled and working, don't forget to set the mode to this instance.
|
|
10
|
-
*/
|
|
11
|
-
export * as SharedLogger from './shared.js';
|
|
7
|
+
export { ConsoleLogger, batchLoggers, LoggersManager, Loggable, LoggerProvider, };
|
|
12
8
|
//# sourceMappingURL=index.js.map
|
package/esm/logger/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/logger/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/logger/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAG/C,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EACH,aAAa,EACb,YAAY,EACZ,cAAc,EACd,QAAQ,EACR,cAAc,GACjB,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { Getter } from '../types/getter.js';
|
|
2
|
+
/** Helper base class for storing and using a logger instance. */
|
|
3
|
+
export class Loggable {
|
|
4
|
+
_logger = null;
|
|
5
|
+
constructor(logger) {
|
|
6
|
+
if (logger) {
|
|
7
|
+
this.setLogger(logger);
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
get logger() { return this._logger; }
|
|
11
|
+
setLogger(logger) {
|
|
12
|
+
if (!logger) {
|
|
13
|
+
this._logger = null;
|
|
14
|
+
}
|
|
15
|
+
else {
|
|
16
|
+
this._logger = Getter.toValue(logger) ?? null;
|
|
17
|
+
}
|
|
18
|
+
return this;
|
|
19
|
+
}
|
|
20
|
+
setLoggerFactory(factory, ...args) {
|
|
21
|
+
if (!factory) {
|
|
22
|
+
return this.setLogger(null);
|
|
23
|
+
}
|
|
24
|
+
const res = this._createLogger(factory, ...args);
|
|
25
|
+
return this.setLogger(res);
|
|
26
|
+
}
|
|
27
|
+
getLoggerName(name) {
|
|
28
|
+
return name ? `[${name}]` : '';
|
|
29
|
+
}
|
|
30
|
+
_createLogger(factory, ...args) {
|
|
31
|
+
const [originalName, ...rest] = args;
|
|
32
|
+
return factory(this.getLoggerName(originalName), ...rest);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=loggable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loggable.js","sourceRoot":"","sources":["../../../src/logger/loggable.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAI5C,iEAAiE;AACjE,MAAM,OAAO,QAAQ;IAET,OAAO,GAAmB,IAAI,CAAC;IAEvC,YAAY,MAAgB;QACxB,IAAI,MAAM,EAAE,CAAC;YACT,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAC3B,CAAC;IACL,CAAC;IAED,IAAc,MAAM,KAAK,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;IAExC,SAAS,CAAC,MAAkC;QAC/C,IAAI,CAAC,MAAM,EAAE,CAAC;YACV,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACxB,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC;QAClD,CAAC;QAED,OAAO,IAAI,CAAC;IAChB,CAAC;IAEM,gBAAgB,CAAC,OAA8B,EAAE,GAAG,IAAgC;QACvF,IAAI,CAAC,OAAO,EAAE,CAAC;YACX,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAChC,CAAC;QAED,MAAM,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;QACjD,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IAC/B,CAAC;IAES,aAAa,CAAC,IAAwB;QAC5C,OAAO,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;IACnC,CAAC;IAES,aAAa,CAAC,OAAuB,EAAE,GAAG,IAAgC;QAChF,MAAM,CAAC,YAAY,EAAE,GAAG,IAAI,CAAC,GAAG,IAAI,CAAC;QACrC,OAAO,OAAO,CACV,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,EAChC,GAAG,IAAI,CACV,CAAC;IACN,CAAC;CACJ"}
|