@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.
Files changed (168) hide show
  1. package/cjs/api/call.js +5 -5
  2. package/cjs/api/call.js.map +1 -1
  3. package/cjs/api/config.js +30 -5
  4. package/cjs/api/config.js.map +1 -1
  5. package/cjs/api/index.js +5 -6
  6. package/cjs/api/index.js.map +1 -1
  7. package/cjs/api/interceptor.js +1 -1
  8. package/cjs/api/logging.js +3 -3
  9. package/cjs/api/logging.js.map +1 -1
  10. package/cjs/functions/assert.js +2 -4
  11. package/cjs/functions/assert.js.map +1 -1
  12. package/cjs/functions/disposer.js +10 -18
  13. package/cjs/functions/disposer.js.map +1 -1
  14. package/cjs/functions/throttle.js +8 -17
  15. package/cjs/functions/throttle.js.map +1 -1
  16. package/cjs/logger/batch.js +23 -3
  17. package/cjs/logger/batch.js.map +1 -1
  18. package/cjs/logger/buffered/base.js +52 -0
  19. package/cjs/logger/buffered/base.js.map +1 -0
  20. package/cjs/logger/buffered/buffered.logger.js +40 -0
  21. package/cjs/logger/buffered/buffered.logger.js.map +1 -0
  22. package/cjs/logger/buffered/buffered.memory.js +71 -0
  23. package/cjs/logger/buffered/buffered.memory.js.map +1 -0
  24. package/cjs/logger/buffered/file/buffered.file.js +43 -0
  25. package/cjs/logger/buffered/file/buffered.file.js.map +1 -0
  26. package/cjs/logger/buffered/file/index.js +5 -0
  27. package/cjs/logger/buffered/file/index.js.map +1 -0
  28. package/cjs/logger/buffered/index.js +7 -0
  29. package/cjs/logger/buffered/index.js.map +1 -0
  30. package/cjs/logger/console.js +1 -39
  31. package/cjs/logger/console.js.map +1 -1
  32. package/cjs/logger/empty.js +11 -0
  33. package/cjs/logger/empty.js.map +1 -0
  34. package/cjs/logger/index.js +5 -7
  35. package/cjs/logger/index.js.map +1 -1
  36. package/cjs/logger/loggable.js +39 -0
  37. package/cjs/logger/loggable.js.map +1 -0
  38. package/cjs/logger/manager.js +70 -20
  39. package/cjs/logger/manager.js.map +1 -1
  40. package/cjs/logger/named.js +15 -12
  41. package/cjs/logger/named.js.map +1 -1
  42. package/cjs/logger/provider.js +33 -0
  43. package/cjs/logger/provider.js.map +1 -0
  44. package/cjs/logger/proxy.js +3 -7
  45. package/cjs/logger/proxy.js.map +1 -1
  46. package/cjs/logger/types.js +9 -0
  47. package/cjs/logger/types.js.map +1 -0
  48. package/cjs/models/LogicModel.js +13 -11
  49. package/cjs/models/LogicModel.js.map +1 -1
  50. package/cjs/observing/event.js +5 -18
  51. package/cjs/observing/event.js.map +1 -1
  52. package/cjs/observing/progressTracker.js +8 -15
  53. package/cjs/observing/progressTracker.js.map +1 -1
  54. package/cjs/structures/promiseCache.js +14 -20
  55. package/cjs/structures/promiseCache.js.map +1 -1
  56. package/cjs/structures/queue/parallel.js +11 -13
  57. package/cjs/structures/queue/parallel.js.map +1 -1
  58. package/cjs/structures/subscribersMap.js +9 -7
  59. package/cjs/structures/subscribersMap.js.map +1 -1
  60. package/esm/api/call.js +5 -5
  61. package/esm/api/call.js.map +1 -1
  62. package/esm/api/config.js +28 -4
  63. package/esm/api/config.js.map +1 -1
  64. package/esm/api/index.js +4 -2
  65. package/esm/api/index.js.map +1 -1
  66. package/esm/api/interceptor.js +1 -1
  67. package/esm/api/logging.js +3 -3
  68. package/esm/api/logging.js.map +1 -1
  69. package/esm/functions/assert.js +2 -3
  70. package/esm/functions/assert.js.map +1 -1
  71. package/esm/functions/disposer.js +10 -17
  72. package/esm/functions/disposer.js.map +1 -1
  73. package/esm/functions/throttle.js +6 -15
  74. package/esm/functions/throttle.js.map +1 -1
  75. package/esm/logger/batch.js +23 -3
  76. package/esm/logger/batch.js.map +1 -1
  77. package/esm/logger/buffered/base.js +48 -0
  78. package/esm/logger/buffered/base.js.map +1 -0
  79. package/esm/logger/buffered/buffered.logger.js +36 -0
  80. package/esm/logger/buffered/buffered.logger.js.map +1 -0
  81. package/esm/logger/buffered/buffered.memory.js +67 -0
  82. package/esm/logger/buffered/buffered.memory.js.map +1 -0
  83. package/esm/logger/buffered/file/buffered.file.js +38 -0
  84. package/esm/logger/buffered/file/buffered.file.js.map +1 -0
  85. package/esm/logger/buffered/file/index.js +2 -0
  86. package/esm/logger/buffered/file/index.js.map +1 -0
  87. package/esm/logger/buffered/index.js +4 -0
  88. package/esm/logger/buffered/index.js.map +1 -0
  89. package/esm/logger/console.js +0 -37
  90. package/esm/logger/console.js.map +1 -1
  91. package/esm/logger/empty.js +7 -0
  92. package/esm/logger/empty.js.map +1 -0
  93. package/esm/logger/index.js +3 -7
  94. package/esm/logger/index.js.map +1 -1
  95. package/esm/logger/loggable.js +35 -0
  96. package/esm/logger/loggable.js.map +1 -0
  97. package/esm/logger/manager.js +70 -20
  98. package/esm/logger/manager.js.map +1 -1
  99. package/esm/logger/named.js +8 -4
  100. package/esm/logger/named.js.map +1 -1
  101. package/esm/logger/provider.js +29 -0
  102. package/esm/logger/provider.js.map +1 -0
  103. package/esm/logger/proxy.js +2 -6
  104. package/esm/logger/proxy.js.map +1 -1
  105. package/esm/logger/types.js +6 -0
  106. package/esm/logger/types.js.map +1 -0
  107. package/esm/models/LogicModel.js +13 -11
  108. package/esm/models/LogicModel.js.map +1 -1
  109. package/esm/observing/event.js +5 -18
  110. package/esm/observing/event.js.map +1 -1
  111. package/esm/observing/progressTracker.js +8 -14
  112. package/esm/observing/progressTracker.js.map +1 -1
  113. package/esm/structures/promiseCache.js +14 -20
  114. package/esm/structures/promiseCache.js.map +1 -1
  115. package/esm/structures/queue/parallel.js +11 -13
  116. package/esm/structures/queue/parallel.js.map +1 -1
  117. package/esm/structures/subscribersMap.js +9 -7
  118. package/esm/structures/subscribersMap.js.map +1 -1
  119. package/package.json +13 -1
  120. package/tsconfig.cjs.tsbuildinfo +1 -1
  121. package/tsconfig.esm.tsbuildinfo +1 -1
  122. package/tsconfig.types.tsbuildinfo +1 -1
  123. package/types/api/call.types.d.ts +2 -2
  124. package/types/api/config.d.ts +11 -4
  125. package/types/api/extensions/endpointHooks.d.ts +1 -1
  126. package/types/api/index.d.ts +4 -2
  127. package/types/api/interceptor.d.ts +1 -1
  128. package/types/api/logging.d.ts +8 -6
  129. package/types/functions/assert.d.ts +3 -3
  130. package/types/functions/disposer.d.ts +7 -6
  131. package/types/functions/throttle.d.ts +4 -5
  132. package/types/logger/batch.d.ts +3 -2
  133. package/types/logger/buffered/base.d.ts +23 -0
  134. package/types/logger/buffered/buffered.logger.d.ts +8 -0
  135. package/types/logger/buffered/buffered.memory.d.ts +19 -0
  136. package/types/logger/buffered/file/buffered.file.d.ts +9 -0
  137. package/types/logger/buffered/file/index.d.ts +1 -0
  138. package/types/logger/buffered/index.d.ts +3 -0
  139. package/types/logger/console.d.ts +1 -13
  140. package/types/logger/empty.d.ts +3 -0
  141. package/types/logger/index.d.ts +6 -10
  142. package/types/logger/loggable.d.ts +13 -0
  143. package/types/logger/manager.d.ts +31 -7
  144. package/types/logger/named.d.ts +4 -3
  145. package/types/logger/provider.d.ts +11 -0
  146. package/types/logger/proxy.d.ts +1 -2
  147. package/types/logger/types.d.ts +21 -0
  148. package/types/models/LogicModel.d.ts +4 -4
  149. package/types/observing/event.d.ts +3 -6
  150. package/types/observing/progressTracker.d.ts +3 -4
  151. package/types/structures/promiseCache.d.ts +3 -4
  152. package/types/structures/queue/parallel.d.ts +3 -3
  153. package/types/structures/subscribersMap.d.ts +3 -2
  154. package/cjs/logger/abstractions.js +0 -3
  155. package/cjs/logger/abstractions.js.map +0 -1
  156. package/cjs/logger/file.js +0 -65
  157. package/cjs/logger/file.js.map +0 -1
  158. package/cjs/logger/shared.js +0 -18
  159. package/cjs/logger/shared.js.map +0 -1
  160. package/esm/logger/abstractions.js +0 -2
  161. package/esm/logger/abstractions.js.map +0 -1
  162. package/esm/logger/file.js +0 -60
  163. package/esm/logger/file.js.map +0 -1
  164. package/esm/logger/shared.js +0 -15
  165. package/esm/logger/shared.js.map +0 -1
  166. package/types/logger/abstractions.d.ts +0 -10
  167. package/types/logger/file.d.ts +0 -15
  168. package/types/logger/shared.d.ts +0 -15
@@ -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;IAmBD,SAAgB,OAAO,CAAC,MAAe,EAAE,GAAmB,EAAE,GAAiB,EAAE,IAAc;QAC3F,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,IAAI,IAAI,GAAG,CAAC,IAAI,CAAC;YAClC,CAAC,CAAC,CAAC,IAAI,IAAI,GAAG,CAAC,IAAI,CAAC,CAAC;QAEzB,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;AAGL,CAAC,EAxEgB,QAAQ,KAAR,QAAQ,QAwExB"}
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"}
@@ -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(logger);
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,EAAE,MAAM,mBAAmB,CAAC;AAC3C,OAAO,MAAM,MAAM,qBAAqB,CAAC;AAKzC,MAAM,UAAU,YAAY,CAAC,MAAe;IACxC,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,EAAE,CAAC;YACd,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,CAAC,MAAM,CAAC,CAAC"}
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 logger from '../logger/shared.js';
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(`[Disposer:${this._loggerName || '<unknown>'}] Disposing ${this._disposers.length} items including named ones:`, Array.from(this._map.entries()).map(e => e[0]));
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":"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"}
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 { createLogger } from '../logger/shared.js';
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._logger?.warn('[ThrottleAction] THROTTLE LOCKED, but another call is forced. Skipping since the behavior is undefined.');
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
- useLogger(logger) {
107
- this._action.useLogger(logger);
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":"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"}
1
+ {"version":3,"file":"throttle.js","sourceRoot":"","sources":["../../../src/functions/throttle.ts"],"names":[],"mappings":"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"}
@@ -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) => loggers.forEach(l => l.log(...args)),
4
- warn: (...args) => loggers.forEach(l => l.warn(...args)),
5
- error: (...args) => loggers.forEach(l => l.error(...args)),
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
@@ -1 +1 @@
1
- {"version":3,"file":"batch.js","sourceRoot":"","sources":["../../../src/logger/batch.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,YAAY,CAAC,GAAG,OAAkB;IAC9C,OAAO;QACH,GAAG,EAAE,CAAC,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;QAC7D,IAAI,EAAE,CAAC,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;QAC/D,KAAK,EAAE,CAAC,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;KACpE,CAAC;AACN,CAAC"}
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,2 @@
1
+ export * from './buffered.file.js';
2
+ //# sourceMappingURL=index.js.map
@@ -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,4 @@
1
+ export * from './base.js';
2
+ export * from './buffered.logger.js';
3
+ export * from './buffered.memory.js';
4
+ //# sourceMappingURL=index.js.map
@@ -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"}
@@ -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;AAED,MAAM,OAAO,qBAAqB;IACb,KAAK,CAAS;IACd,KAAK,GAAa,EAAE,CAAC;IAC9B,MAAM,GAAG,CAAC,CAAC;IAEX,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC;IAE3B,YAAY,IAAY;QACpB,IAAI,CAAC,KAAK,GAAG,IAAI,IAAI,EAAE,CAAC;IAC5B,CAAC;IAED,GAAG,CAAC,GAAG,IAAW;QACd,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,IAAI,CAAC,CAAC;IACvC,CAAC;IAED,IAAI,CAAC,GAAG,IAAW;QACf,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,EAAE,GAAG,IAAI,CAAC,CAAC;QAC1C,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;IACxB,CAAC;IAED,KAAK,CAAC,GAAG,IAAW;QAChB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,gBAAgB,EAAE,GAAG,IAAI,CAAC,CAAC;QAC3C,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;IACxB,CAAC;IAED,KAAK;QACD,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACxB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;YACrC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QAC1B,CAAC;IACL,CAAC;IAEO,WAAW,CAAC,CAAS;QACzB,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YAClB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;YAChB,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;gBACT,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,KAAK,CAAC;YAC9B,CAAC;iBAAM,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;gBAChB,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;YAC7B,CAAC;QACL,CAAC;IACL,CAAC;CACJ"}
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,7 @@
1
+ export const EMPTY_FUNCTION = () => { };
2
+ export const EMPTY_LOGGER = {
3
+ log: EMPTY_FUNCTION,
4
+ warn: EMPTY_FUNCTION,
5
+ error: EMPTY_FUNCTION,
6
+ };
7
+ //# sourceMappingURL=empty.js.map
@@ -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"}
@@ -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
@@ -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,EAAe,cAAc,EAAE,MAAM,cAAc,CAAC;AAG3D,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,CAAC;AACvC,OAAO,EAAE,cAAc,EAAE,CAAC;AAE1B;;;EAGE;AACF,OAAO,KAAK,YAAY,MAAM,aAAa,CAAC"}
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"}