zeed 0.7.101 → 0.7.105

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 (35) hide show
  1. package/dist/chunk-FLKB7XIS.js +509 -0
  2. package/dist/{chunk-YBNWDOXD.js.map → chunk-FLKB7XIS.js.map} +1 -1
  3. package/dist/chunk-JSBG4FAV.js +533 -0
  4. package/dist/{chunk-FRS5X2RR.js.map → chunk-JSBG4FAV.js.map} +1 -1
  5. package/dist/chunk-NZQXKE2T.js +247 -0
  6. package/dist/{chunk-2MNLLNRH.js.map → chunk-NZQXKE2T.js.map} +1 -1
  7. package/dist/chunk-XFNWEAIL.js +333 -0
  8. package/dist/{chunk-NBL7BZAW.js.map → chunk-XFNWEAIL.js.map} +1 -1
  9. package/dist/chunk-ZBR6MQ73.js +2512 -0
  10. package/dist/chunk-ZBR6MQ73.js.map +1 -0
  11. package/dist/index.all.cjs +4318 -9
  12. package/dist/index.all.cjs.map +1 -1
  13. package/dist/index.all.d.ts +3 -3
  14. package/dist/index.all.js +460 -1
  15. package/dist/index.browser.cjs +3787 -4
  16. package/dist/index.browser.cjs.map +1 -1
  17. package/dist/index.browser.d.ts +2 -2
  18. package/dist/index.browser.js +428 -1
  19. package/dist/index.log.cjs +634 -1
  20. package/dist/index.log.cjs.map +1 -1
  21. package/dist/index.log.js +14 -1
  22. package/dist/index.node.cjs +3762 -9
  23. package/dist/index.node.cjs.map +1 -1
  24. package/dist/index.node.d.ts +2 -2
  25. package/dist/index.node.js +438 -1
  26. package/dist/{log-colors-48e120a2.d.ts → log-colors-40ad830e.d.ts} +1 -1
  27. package/dist/{log-util-d3a084f6.d.ts → log-util-433570b2.d.ts} +1 -1
  28. package/dist/{uuid-bdf645cb.d.ts → uuid-83141d13.d.ts} +24 -4
  29. package/package.json +6 -6
  30. package/dist/chunk-2MNLLNRH.js +0 -2
  31. package/dist/chunk-FRS5X2RR.js +0 -7
  32. package/dist/chunk-NBL7BZAW.js +0 -2
  33. package/dist/chunk-PSHR634P.js +0 -5
  34. package/dist/chunk-PSHR634P.js.map +0 -1
  35. package/dist/chunk-YBNWDOXD.js +0 -2
@@ -0,0 +1,509 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defProps = Object.defineProperties;
3
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
+ var __spreadValues = (a, b) => {
9
+ for (var prop in b || (b = {}))
10
+ if (__hasOwnProp.call(b, prop))
11
+ __defNormalProp(a, prop, b[prop]);
12
+ if (__getOwnPropSymbols)
13
+ for (var prop of __getOwnPropSymbols(b)) {
14
+ if (__propIsEnum.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ }
17
+ return a;
18
+ };
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
21
+
22
+ // src/common/data/is.ts
23
+ function isObject(obj) {
24
+ return obj != null && typeof obj === "object";
25
+ }
26
+ __name(isObject, "isObject");
27
+ function isPrimitive(obj) {
28
+ return Object(obj) !== obj;
29
+ }
30
+ __name(isPrimitive, "isPrimitive");
31
+ function isArray(obj) {
32
+ return Array.isArray(obj);
33
+ }
34
+ __name(isArray, "isArray");
35
+ function isRecord(obj) {
36
+ return isObject(obj) && !isArray(obj);
37
+ }
38
+ __name(isRecord, "isRecord");
39
+ function isString(obj) {
40
+ return typeof obj === "string";
41
+ }
42
+ __name(isString, "isString");
43
+ function isNumber(obj) {
44
+ return typeof obj === "number";
45
+ }
46
+ __name(isNumber, "isNumber");
47
+ function isInteger(obj) {
48
+ return typeof obj === "number" && Number.isInteger(obj);
49
+ }
50
+ __name(isInteger, "isInteger");
51
+ function isSafeInteger(obj) {
52
+ return typeof obj === "number" && Number.isSafeInteger(obj);
53
+ }
54
+ __name(isSafeInteger, "isSafeInteger");
55
+ function isBoolean(obj) {
56
+ return typeof obj === "boolean";
57
+ }
58
+ __name(isBoolean, "isBoolean");
59
+ function isNullOrUndefined(obj) {
60
+ return obj == null;
61
+ }
62
+ __name(isNullOrUndefined, "isNullOrUndefined");
63
+
64
+ // src/common/data/deep.ts
65
+ function deepEqual(a, b, hash = /* @__PURE__ */ new WeakSet()) {
66
+ if (a === b) {
67
+ return true;
68
+ }
69
+ if (hash.has(b)) {
70
+ return true;
71
+ }
72
+ if (!isPrimitive(b)) {
73
+ hash.add(b);
74
+ }
75
+ if (!(a instanceof Object) || !(b instanceof Object)) {
76
+ return false;
77
+ }
78
+ if (a.constructor !== b.constructor) {
79
+ return false;
80
+ }
81
+ if (a.length !== b.length) {
82
+ return false;
83
+ }
84
+ for (let p in a) {
85
+ if (!a.hasOwnProperty(p)) {
86
+ continue;
87
+ }
88
+ if (!b.hasOwnProperty(p)) {
89
+ return false;
90
+ }
91
+ let aa = a[p];
92
+ let bb = b[p];
93
+ if (!deepEqual(aa, bb, hash)) {
94
+ return false;
95
+ }
96
+ }
97
+ for (let p in b) {
98
+ if (b.hasOwnProperty(p) && !a.hasOwnProperty(p)) {
99
+ return false;
100
+ }
101
+ }
102
+ return true;
103
+ }
104
+ __name(deepEqual, "deepEqual");
105
+ function deepMerge(target, ...sources) {
106
+ for (let source of sources) {
107
+ if (!isObject(target)) {
108
+ target = {};
109
+ }
110
+ if (source == null)
111
+ continue;
112
+ Object.keys(source).forEach((key) => {
113
+ const targetValue = target[key];
114
+ const sourceValue = source[key];
115
+ if (Array.isArray(targetValue) && Array.isArray(sourceValue)) {
116
+ target[key] = targetValue.concat(sourceValue);
117
+ } else if (isObject(targetValue) && isObject(sourceValue)) {
118
+ target[key] = deepMerge(Object.assign({}, targetValue), sourceValue);
119
+ } else {
120
+ target[key] = sourceValue;
121
+ }
122
+ });
123
+ }
124
+ return target;
125
+ }
126
+ __name(deepMerge, "deepMerge");
127
+
128
+ // src/common/log-console.ts
129
+ function LoggerConsoleHandler(opt = {}) {
130
+ const {
131
+ level = void 0,
132
+ filter = void 0,
133
+ colors = true,
134
+ levelHelper = false,
135
+ nameBrackets = true,
136
+ padding = 16
137
+ } = opt;
138
+ const matchesNamespace = useNamespaceFilter(filter);
139
+ const matchesLevel = useLevelFilter(level);
140
+ return (msg) => {
141
+ if (!matchesLevel(msg.level))
142
+ return;
143
+ if (!matchesNamespace(msg.name))
144
+ return;
145
+ let name = msg.name ? `[${msg.name}]` : "";
146
+ switch (msg.level) {
147
+ case 1 /* info */:
148
+ console.info(`I|* ${name}`, ...msg.messages);
149
+ break;
150
+ case 2 /* warn */:
151
+ console.warn(`W|** ${name}`, ...msg.messages);
152
+ break;
153
+ case 3 /* error */:
154
+ console.error(`E|*** ${name}`, ...msg.messages);
155
+ break;
156
+ default:
157
+ console.debug(`D| ${name}`, ...msg.messages);
158
+ break;
159
+ }
160
+ };
161
+ }
162
+ __name(LoggerConsoleHandler, "LoggerConsoleHandler");
163
+
164
+ // src/common/log-base.ts
165
+ var LogLevel = /* @__PURE__ */ ((LogLevel2) => {
166
+ LogLevel2[LogLevel2["all"] = -1] = "all";
167
+ LogLevel2[LogLevel2["debug"] = 0] = "debug";
168
+ LogLevel2[LogLevel2["info"] = 1] = "info";
169
+ LogLevel2[LogLevel2["warn"] = 2] = "warn";
170
+ LogLevel2[LogLevel2["error"] = 3] = "error";
171
+ LogLevel2[LogLevel2["fatal"] = 4] = "fatal";
172
+ LogLevel2[LogLevel2["off"] = Infinity] = "off";
173
+ return LogLevel2;
174
+ })(LogLevel || {});
175
+ var LogLevelAlias = {
176
+ "*": -1 /* all */,
177
+ a: -1 /* all */,
178
+ all: -1 /* all */,
179
+ d: 0 /* debug */,
180
+ dbg: 0 /* debug */,
181
+ debug: 0 /* debug */,
182
+ i: 1 /* info */,
183
+ inf: 1 /* info */,
184
+ info: 1 /* info */,
185
+ w: 2 /* warn */,
186
+ warn: 2 /* warn */,
187
+ warning: 2 /* warn */,
188
+ e: 3 /* error */,
189
+ err: 3 /* error */,
190
+ error: 3 /* error */,
191
+ fatal: 4 /* fatal */,
192
+ off: Infinity /* off */,
193
+ "-": Infinity /* off */
194
+ };
195
+ function LoggerContext(prefix = "") {
196
+ let logHandlers = [LoggerConsoleHandler()];
197
+ let logAssertLevel = 2 /* warn */;
198
+ let logCheckNamespace = /* @__PURE__ */ __name((name) => true, "logCheckNamespace");
199
+ let logLock = false;
200
+ let logFactory = LoggerBaseFactory;
201
+ function LoggerBaseFactory(name = "") {
202
+ log.extend = function(prefix2) {
203
+ return logFactory(name ? `${name}:${prefix2}` : prefix2);
204
+ };
205
+ const emit = /* @__PURE__ */ __name((msg) => {
206
+ if (log.active === true) {
207
+ if (msg.level >= Logger2.level && msg.level >= log.level) {
208
+ if (logCheckNamespace(name)) {
209
+ for (let handler of logHandlers) {
210
+ if (handler)
211
+ handler(msg);
212
+ }
213
+ }
214
+ }
215
+ }
216
+ }, "emit");
217
+ function log(...messages) {
218
+ emit({
219
+ name,
220
+ messages,
221
+ level: 0 /* debug */
222
+ });
223
+ }
224
+ __name(log, "log");
225
+ log.active = true;
226
+ log.level = -1 /* all */;
227
+ log.debug = function(...messages) {
228
+ emit({
229
+ name,
230
+ messages,
231
+ level: 0 /* debug */
232
+ });
233
+ };
234
+ log.info = function(...messages) {
235
+ emit({
236
+ name,
237
+ messages,
238
+ level: 1 /* info */
239
+ });
240
+ };
241
+ log.warn = function(...messages) {
242
+ emit({
243
+ name,
244
+ messages,
245
+ level: 2 /* warn */
246
+ });
247
+ };
248
+ log.error = function(...messages) {
249
+ emit({
250
+ name,
251
+ messages,
252
+ level: 3 /* error */
253
+ });
254
+ };
255
+ log.assert = function(cond, ...messages) {
256
+ if (!cond) {
257
+ if (typeof console !== void 0) {
258
+ if (console.assert) {
259
+ console.assert(cond, ...messages);
260
+ } else {
261
+ console.error(`Assert did fail with: ${cond}`, ...messages);
262
+ }
263
+ }
264
+ emit({
265
+ name,
266
+ messages: messages || [`Assert did fail with: ${cond}`],
267
+ level: logAssertLevel
268
+ });
269
+ }
270
+ };
271
+ log.assertEqual = function(value, expected, ...args) {
272
+ let equal = deepEqual(value, expected);
273
+ if (!equal) {
274
+ log.assert(equal, `Assert did fail. Expected ${expected} got ${value}`, expected, value, ...args);
275
+ }
276
+ };
277
+ log.assertNotEqual = function(value, expected, ...args) {
278
+ let equal = deepEqual(value, expected);
279
+ if (equal) {
280
+ log.assert(equal, `Assert did fail. Expected ${expected} not to be equal with ${value}`, expected, value, ...args);
281
+ }
282
+ };
283
+ return log;
284
+ }
285
+ __name(LoggerBaseFactory, "LoggerBaseFactory");
286
+ function Logger2(name = "") {
287
+ return logFactory(name);
288
+ }
289
+ __name(Logger2, "Logger");
290
+ Logger2.registerHandler = function(handler) {
291
+ logHandlers.push(handler);
292
+ };
293
+ Logger2.setFilter = function(namespaces) {
294
+ logCheckNamespace = useNamespaceFilter(namespaces);
295
+ };
296
+ Logger2.setLock = (lock = true) => logLock = lock;
297
+ Logger2.setHandlers = function(handlers = []) {
298
+ if (logFactory !== LoggerBaseFactory) {
299
+ logFactory = LoggerBaseFactory;
300
+ }
301
+ if (logLock)
302
+ return;
303
+ logHandlers = [...handlers].filter((h) => typeof h === "function");
304
+ };
305
+ Logger2.level = -1 /* all */;
306
+ Logger2.setLogLevel = function(level = -1 /* all */) {
307
+ if (logLock)
308
+ return;
309
+ Logger2.level = level;
310
+ };
311
+ Logger2.setFactory = function(factory) {
312
+ if (logLock)
313
+ return;
314
+ logFactory = factory;
315
+ };
316
+ return Logger2;
317
+ }
318
+ __name(LoggerContext, "LoggerContext");
319
+
320
+ // src/common/log-filter.ts
321
+ function getNamespaceFilterString(defaultNamespaceFilter2) {
322
+ if (defaultNamespaceFilter2 === true || defaultNamespaceFilter2 === "true" || defaultNamespaceFilter2 === "1" || typeof defaultNamespaceFilter2 === "number" && defaultNamespaceFilter2 !== 0) {
323
+ defaultNamespaceFilter2 = "*";
324
+ } else if (defaultNamespaceFilter2 === false || defaultNamespaceFilter2 === "false" || defaultNamespaceFilter2 === 0 || defaultNamespaceFilter2 === "0" || defaultNamespaceFilter2 == null || defaultNamespaceFilter2 === "null" || defaultNamespaceFilter2 === "undefined") {
325
+ defaultNamespaceFilter2 = "";
326
+ } else {
327
+ defaultNamespaceFilter2 = String(defaultNamespaceFilter2);
328
+ }
329
+ return defaultNamespaceFilter2;
330
+ }
331
+ __name(getNamespaceFilterString, "getNamespaceFilterString");
332
+ var _a, _b;
333
+ var defaultNamespaceFilter = getNamespaceFilterString(typeof process !== "undefined" ? (_a = process.env.ZEED) != null ? _a : process.env.DEBUG : typeof localStorage !== "undefined" ? (_b = localStorage.zeed) != null ? _b : localStorage.debug : "*");
334
+ function useNamespaceFilter(filter = defaultNamespaceFilter) {
335
+ let fn;
336
+ let reject = [];
337
+ let accept = [];
338
+ if (!filter) {
339
+ fn = /* @__PURE__ */ __name(function(name) {
340
+ return false;
341
+ }, "fn");
342
+ } else if (filter === "*") {
343
+ fn = /* @__PURE__ */ __name(function(name) {
344
+ return true;
345
+ }, "fn");
346
+ } else {
347
+ let i;
348
+ const split = filter.split(/[\s,]+/);
349
+ const len = split.length;
350
+ for (i = 0; i < len; i++) {
351
+ if (!split[i]) {
352
+ continue;
353
+ }
354
+ let template = split[i].replace(/\*/g, ".*?");
355
+ if (template[0] === "-") {
356
+ reject.push(new RegExp("^" + template.substr(1) + "$"));
357
+ } else {
358
+ accept.push(new RegExp("^" + template + "$"));
359
+ }
360
+ }
361
+ fn = /* @__PURE__ */ __name(function(name) {
362
+ if (reject.length === 0 && accept.length === 0) {
363
+ return true;
364
+ }
365
+ let i2, len2;
366
+ for (i2 = 0, len2 = reject.length; i2 < len2; i2++) {
367
+ if (reject[i2].test(name)) {
368
+ return false;
369
+ }
370
+ }
371
+ for (i2 = 0, len2 = accept.length; i2 < len2; i2++) {
372
+ if (accept[i2].test(name)) {
373
+ return true;
374
+ }
375
+ }
376
+ return false;
377
+ }, "fn");
378
+ }
379
+ fn.accept = accept;
380
+ fn.reject = reject;
381
+ fn.filter = filter;
382
+ return fn;
383
+ }
384
+ __name(useNamespaceFilter, "useNamespaceFilter");
385
+ var _a2, _b2, _c, _d;
386
+ var defaultLevelFilter = typeof process !== "undefined" ? (_b2 = (_a2 = process.env.ZEED_LEVEL) != null ? _a2 : process.env.LEVEL) != null ? _b2 : process.env.DEBUG_LEVEL : typeof localStorage !== "undefined" ? (_d = (_c = localStorage.zeed_level) != null ? _c : localStorage.level) != null ? _d : localStorage.debug_level : void 0;
387
+ function useLevelFilter(filter = defaultLevelFilter) {
388
+ let filterLevel = -1 /* all */;
389
+ if (typeof filter === "string") {
390
+ const l = LogLevelAlias[filter.toLocaleLowerCase().trim()];
391
+ if (l != null)
392
+ filterLevel = l;
393
+ } else if (typeof filter === "number") {
394
+ filterLevel = filter;
395
+ }
396
+ return (level) => level >= filterLevel;
397
+ }
398
+ __name(useLevelFilter, "useLevelFilter");
399
+
400
+ // src/common/global.ts
401
+ function _global() {
402
+ if (typeof self !== "undefined")
403
+ return self;
404
+ if (typeof window !== "undefined")
405
+ return window;
406
+ if (typeof global !== "undefined")
407
+ return global;
408
+ if (typeof globalThis !== "undefined")
409
+ return globalThis;
410
+ throw new Error("unable to locate global object");
411
+ }
412
+ __name(_global, "_global");
413
+ function getGlobalContext() {
414
+ let gcontext = _global();
415
+ if (gcontext._zeedGlobal == null) {
416
+ gcontext._zeedGlobal = {};
417
+ }
418
+ return gcontext._zeedGlobal;
419
+ }
420
+ __name(getGlobalContext, "getGlobalContext");
421
+
422
+ // src/common/log.ts
423
+ var globalLogger;
424
+ function getLoggerContext() {
425
+ let logger = LoggerContext();
426
+ logger.setHandlers([LoggerConsoleHandler()]);
427
+ return logger;
428
+ }
429
+ __name(getLoggerContext, "getLoggerContext");
430
+ try {
431
+ let _global2 = getGlobalContext();
432
+ if (_global2 != null) {
433
+ if ((_global2 == null ? void 0 : _global2.logger) == null) {
434
+ globalLogger = getLoggerContext();
435
+ _global2.logger = globalLogger;
436
+ } else {
437
+ globalLogger = _global2.logger;
438
+ }
439
+ } else {
440
+ globalLogger = getLoggerContext();
441
+ }
442
+ } catch (e) {
443
+ globalLogger = getLoggerContext();
444
+ }
445
+ var Logger = globalLogger;
446
+
447
+ // src/common/time.ts
448
+ var getTimestamp = /* @__PURE__ */ __name(() => Date.now(), "getTimestamp");
449
+ function formatMilliseconds(ms) {
450
+ return ms > 999 ? (ms / 1e3).toFixed(1) + "s" : ms.toFixed(2) + "ms";
451
+ }
452
+ __name(formatMilliseconds, "formatMilliseconds");
453
+ function parseDate(...dateCandidates) {
454
+ for (let dateCandidate of dateCandidates) {
455
+ if (dateCandidate instanceof Date) {
456
+ return dateCandidate;
457
+ }
458
+ if (typeof dateCandidate === "string") {
459
+ let date = null;
460
+ if (dateCandidate.includes(":")) {
461
+ try {
462
+ date = new Date(dateCandidate);
463
+ } catch (err) {
464
+ }
465
+ }
466
+ if (!(date instanceof Date)) {
467
+ let m = /(\d\d\d\d)-(\d\d)-(\d\d)/.exec(dateCandidate);
468
+ if (m) {
469
+ date = new Date(+m[1], +m[2] - 1, +m[3], 12, 0);
470
+ }
471
+ }
472
+ if (date instanceof Date) {
473
+ return date;
474
+ }
475
+ }
476
+ }
477
+ }
478
+ __name(parseDate, "parseDate");
479
+
480
+ export {
481
+ __spreadValues,
482
+ __spreadProps,
483
+ __name,
484
+ isObject,
485
+ isPrimitive,
486
+ isArray,
487
+ isRecord,
488
+ isString,
489
+ isNumber,
490
+ isInteger,
491
+ isSafeInteger,
492
+ isBoolean,
493
+ isNullOrUndefined,
494
+ deepEqual,
495
+ deepMerge,
496
+ getNamespaceFilterString,
497
+ useNamespaceFilter,
498
+ useLevelFilter,
499
+ LogLevel,
500
+ LogLevelAlias,
501
+ LoggerContext,
502
+ LoggerConsoleHandler,
503
+ getGlobalContext,
504
+ Logger,
505
+ getTimestamp,
506
+ formatMilliseconds,
507
+ parseDate
508
+ };
509
+ //# sourceMappingURL=chunk-FLKB7XIS.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/common/data/is.ts","../src/common/data/deep.ts","../src/common/log-console.ts","../src/common/log-base.ts","../src/common/log-filter.ts","../src/common/global.ts","../src/common/log.ts","../src/common/time.ts"],"sourcesContent":["// https://github.com/sindresorhus/is/ MIT\n// https://github.com/sindresorhus/ts-extras\n// https://github.com/sindresorhus/type-fest\n// https://github.com/antfu/utils\n\nexport type Primitive =\n | null\n | undefined\n | string\n | number\n | boolean\n | symbol\n | bigint\n\nexport function isObject(obj: unknown): obj is object {\n return obj != null && typeof obj === \"object\"\n}\n\nexport function isPrimitive(obj: unknown): obj is Primitive {\n return Object(obj) !== obj\n}\n\nexport function isArray(obj: unknown): obj is Array<any> {\n return Array.isArray(obj)\n}\n\nexport function isRecord(obj: unknown): obj is Record<string, any> {\n return isObject(obj) && !isArray(obj)\n}\n\nexport function isString(obj: unknown): obj is string {\n return typeof obj === \"string\"\n}\n\nexport function isNumber(obj: unknown): obj is number {\n return typeof obj === \"number\"\n}\n\nexport function isInteger(obj: unknown): obj is number {\n return typeof obj === \"number\" && Number.isInteger(obj)\n}\n\nexport function isSafeInteger(obj: unknown): obj is number {\n return typeof obj === \"number\" && Number.isSafeInteger(obj)\n}\n\nexport function isBoolean(obj: unknown): obj is boolean {\n return typeof obj === \"boolean\"\n}\n\nexport function isNullOrUndefined(obj: unknown): obj is null | undefined {\n return obj == null\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { isObject, isPrimitive } from \"./is\"\n\n// // https://stackoverflow.com/a/40294058/140927\n// // Handles cyclic references\n// export function deepClonePrimitives(obj, hash = new WeakMap()) {\n//\n// // primitives\n// if (Object(obj) !== obj) {\n// // log('Primitive', obj)\n// return obj\n// }\n//\n// // cyclic reference\n// if (hash.has(obj)) {\n// return hash.get(obj)\n// }\n//\n// let result\n//\n// // primitives as objects like new String(), new Number()\n// if (\n// obj instanceof String ||\n// obj instanceof Number ||\n// obj instanceof BigInt ||\n// obj instanceof Boolean ||\n// obj instanceof Symbol\n// ) {\n// result = new obj.constructor(obj.valueOf())\n// // hash.set(obj, result)\n// return result\n// }\n//\n// // log('Obj', obj)\n//\n// if (obj instanceof Set) {\n// result = new Set(obj)\n// } else if (obj instanceof Map) {\n// result = new Map(Array.from(obj, ([key, val]) => [key, deepClonePrimitives(val, hash)]))\n// } else if (obj instanceof Date) {\n// result = new Date(obj)\n// } else if (obj instanceof RegExp) {\n// result = new RegExp(obj.source, obj.flags)\n// } else if (Array.isArray(obj)) {\n// result = Array.from(obj, val => deepClonePrimitives(val, hash))\n// } else if (obj.constructor) {\n// result = new obj.constructor()\n// log('bj object', result)\n// } else if (obj instanceof Function || typeof obj === 'function') {\n// log('Keep object', obj, Object.getPrototypeOf(obj))\n// result = obj\n// } else {\n// result = Object.create(null)\n// }\n//\n// hash.set(obj, result)\n//\n// return Object.assign(result, ...Object.keys(obj).map(key => ({\n// [key]: deepClonePrimitives(obj[key], hash),\n// })))\n// }\n\nexport function deepEqual(a: any, b: any, hash = new WeakSet()) {\n // if both x and y are null or undefined and exactly the same\n if (a === b) {\n return true\n }\n\n // Cyclic\n if (hash.has(b)) {\n // console.log('cyclic')\n return true\n }\n\n if (!isPrimitive(b)) {\n hash.add(b)\n }\n\n // if they are not strictly equal, they both need to be Objects\n if (!(a instanceof Object) || !(b instanceof Object)) {\n return false\n }\n\n // they must have the exact same prototype chain, the closest we can do is\n // test there constructor.\n if (a.constructor !== b.constructor) {\n return false\n }\n\n // Shortcut to avoid to many loops\n if (a.length !== b.length) {\n return false\n }\n\n for (let p in a) {\n // other properties were tested using x.constructor === y.constructor\n if (!a.hasOwnProperty(p)) {\n continue\n }\n\n // allows to compare x[ p ] and y[ p ] when set to undefined\n if (!b.hasOwnProperty(p)) {\n return false\n }\n\n let aa = a[p]\n let bb = b[p]\n\n // if they have the same strict value or identity then they are equal\n // if (aa === bb) {\n // console.log('eq', typeof bb)\n // if (bb != null) hash.set(bb, true)\n // continue\n // }\n //\n // // Numbers, Strings, Functions, Booleans must be strictly equal\n // if (typeof (aa) !== 'object') {\n // return false\n // }\n\n // Objects and Arrays must be tested recursively\n if (!deepEqual(aa, bb, hash)) {\n return false\n }\n }\n\n // allows x[ p ] to be set to undefined\n for (let p in b) {\n if (b.hasOwnProperty(p) && !a.hasOwnProperty(p)) {\n return false\n }\n }\n\n return true\n}\n\nexport function deepMerge(target: any, ...sources: any[]) {\n for (let source of sources) {\n if (!isObject(target)) {\n target = {}\n }\n\n if (source == null) continue\n\n Object.keys(source).forEach((key) => {\n const targetValue = target[key]\n const sourceValue = source[key]\n\n if (Array.isArray(targetValue) && Array.isArray(sourceValue)) {\n target[key] = targetValue.concat(sourceValue)\n } else if (isObject(targetValue) && isObject(sourceValue)) {\n target[key] = deepMerge(Object.assign({}, targetValue), sourceValue)\n } else {\n target[key] = sourceValue\n }\n })\n }\n\n return target\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { LogHandler, LogHandlerOptions, LogLevel, LogMessage } from \"./log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"./log-filter\"\n\n/**\n * Very basic logger. Please take a look at the browser and node\n * optimized loggers. This one is just the absolute fallback option.\n *\n * @param level Log level\n * @returns Logger\n */\nexport function LoggerConsoleHandler(opt: LogHandlerOptions = {}): LogHandler {\n const {\n level = undefined,\n filter = undefined,\n colors = true,\n levelHelper = false,\n nameBrackets = true,\n padding = 16,\n } = opt\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level)) return\n if (!matchesNamespace(msg.name)) return\n let name = msg.name ? `[${msg.name}]` : \"\"\n switch (msg.level) {\n case LogLevel.info:\n console.info(`I|* ${name}`, ...msg.messages)\n break\n case LogLevel.warn:\n console.warn(`W|** ${name}`, ...msg.messages)\n break\n case LogLevel.error:\n console.error(`E|*** ${name}`, ...msg.messages)\n break\n default:\n console.debug(`D| ${name}`, ...msg.messages)\n break\n }\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { deepEqual } from \"./data/deep\"\nimport { LoggerConsoleHandler } from \"./log-console\"\nimport { useNamespaceFilter } from \"./log-filter\"\n\nexport enum LogLevel {\n all = -1,\n debug = 0,\n info,\n warn,\n error,\n fatal,\n off = Infinity,\n}\n\nexport const LogLevelAlias: Record<string, LogLevel> = {\n \"*\": LogLevel.all,\n a: LogLevel.all,\n all: LogLevel.all,\n d: LogLevel.debug,\n dbg: LogLevel.debug,\n debug: LogLevel.debug,\n i: LogLevel.info,\n inf: LogLevel.info,\n info: LogLevel.info,\n w: LogLevel.warn,\n warn: LogLevel.warn,\n warning: LogLevel.warn,\n e: LogLevel.error,\n err: LogLevel.error,\n error: LogLevel.error,\n fatal: LogLevel.fatal,\n off: LogLevel.off,\n \"-\": LogLevel.off,\n}\n\nexport interface LogMessage {\n level: LogLevel\n name: string\n messages: any[]\n line?: number\n file?: string\n timestamp?: number\n}\n\nexport type LogHandler = (msg: LogMessage) => void\n\nexport interface LoggerInterface {\n (...messages: any[]): void\n\n /** @deprecated use .level = LogLevel.off or LogLevel.all */\n active: boolean\n\n level: LogLevel\n\n debug(...messages: any[]): void\n\n info(...messages: any[]): void\n\n warn(...messages: any[]): void\n\n error(...messages: any[]): void\n\n assert(cond: any, ...messages: any[]): void\n\n /** @deprecated use .assert */\n assertEqual(value: any, expected: any, ...args: any[]): void\n\n /** @deprecated use .assert */\n assertNotEqual(value: any, expected: any, ...args: any[]): void\n\n extend(prefix: string): LoggerInterface\n\n factory?: LoggerContextInterface\n}\n\nexport interface LoggerContextInterface {\n (name?: string): LoggerInterface\n registerHandler(handler: LogHandler): void\n setFilter(namespaces: string): void\n setHandlers(handlers?: (LogHandler | undefined | null)[]): void\n setLock(lock: boolean): void\n setLogLevel(level?: LogLevel): void\n setFactory(factory: (name?: string) => LoggerInterface): void\n}\n\nexport interface LogHandlerOptions {\n level?: LogLevel\n filter?: string\n colors?: boolean\n levelHelper?: boolean\n nameBrackets?: boolean\n padding?: number\n fill?: number\n stack?: boolean | number\n}\n\nexport function LoggerContext(prefix: string = \"\"): LoggerContextInterface {\n let logHandlers: LogHandler[] = [LoggerConsoleHandler()]\n let logAssertLevel: LogLevel = LogLevel.warn\n let logCheckNamespace = (name: string) => true\n let logLock = false\n let logFactory = LoggerBaseFactory\n\n function LoggerBaseFactory(name: string = \"\"): LoggerInterface {\n log.extend = function (prefix: string): LoggerInterface {\n return logFactory(name ? `${name}:${prefix}` : prefix)\n }\n\n const emit = (msg: LogMessage) => {\n if (log.active === true) {\n if (msg.level >= Logger.level && msg.level >= log.level) {\n if (logCheckNamespace(name)) {\n for (let handler of logHandlers) {\n if (handler) handler(msg)\n }\n }\n }\n }\n }\n\n function log(...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.debug,\n })\n }\n\n log.active = true\n log.level = LogLevel.all\n\n log.debug = function (...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.debug,\n })\n }\n\n log.info = function (...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.info,\n })\n }\n\n log.warn = function (...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.warn,\n })\n }\n\n log.error = function (...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.error,\n })\n }\n\n // fatal(...args: any[]) {\n // console.error(...args)\n // },\n\n log.assert = function (cond: any, ...messages: any[]) {\n if (!cond) {\n if (typeof console !== undefined) {\n if (console.assert) {\n // https://developer.mozilla.org/de/docs/Web/API/Console/assert\n console.assert(cond, ...messages)\n } else {\n console.error(`Assert did fail with: ${cond}`, ...messages)\n }\n }\n emit({\n name,\n messages: messages || [`Assert did fail with: ${cond}`],\n level: logAssertLevel,\n })\n // try {\n // if (typeof expect !== undefined) {\n // expect(cond).toBeTruthy()\n // }\n // } catch (err) {\n // methods.warn(...args)\n // }\n }\n }\n\n log.assertEqual = function (value: any, expected: any, ...args: any[]) {\n let equal = deepEqual(value, expected)\n if (!equal) {\n log.assert(\n equal,\n `Assert did fail. Expected ${expected} got ${value}`,\n expected,\n value,\n ...args\n )\n // } else {\n // methods.debug(`Passed equal`)\n }\n }\n\n log.assertNotEqual = function (value: any, expected: any, ...args: any[]) {\n let equal = deepEqual(value, expected)\n if (equal) {\n log.assert(\n equal,\n `Assert did fail. Expected ${expected} not to be equal with ${value}`,\n expected,\n value,\n ...args\n )\n // } else {\n // methods.debug(`Passed not equal check`)\n }\n }\n\n return log\n }\n\n function Logger(name: string = \"\"): LoggerInterface {\n return logFactory(name)\n }\n\n Logger.registerHandler = function (handler: LogHandler) {\n logHandlers.push(handler)\n }\n\n Logger.setFilter = function (namespaces: string) {\n logCheckNamespace = useNamespaceFilter(namespaces)\n }\n\n Logger.setLock = (lock: boolean = true) => (logLock = lock)\n\n Logger.setHandlers = function (handlers: LogHandler[] = []) {\n if (logFactory !== LoggerBaseFactory) {\n logFactory = LoggerBaseFactory\n }\n if (logLock) return\n logHandlers = [...handlers].filter((h) => typeof h === \"function\")\n }\n\n Logger.level = LogLevel.all\n\n /** @deprecated */\n Logger.setLogLevel = function (level: LogLevel = LogLevel.all) {\n if (logLock) return\n Logger.level = level\n }\n\n Logger.setFactory = function (\n factory: (name?: string) => LoggerInterface\n ): void {\n if (logLock) return\n logFactory = factory\n }\n\n return Logger\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { LogLevel, LogLevelAlias } from \"./log-base\"\n\ninterface NamespaceFilter {\n (name: string): boolean\n accept: RegExp[]\n reject: RegExp[]\n filter: string\n}\n\nexport function getNamespaceFilterString(defaultNamespaceFilter: any): string {\n if (\n defaultNamespaceFilter === true ||\n defaultNamespaceFilter === \"true\" ||\n defaultNamespaceFilter === \"1\" ||\n (typeof defaultNamespaceFilter === \"number\" && defaultNamespaceFilter !== 0)\n ) {\n defaultNamespaceFilter = \"*\"\n } else if (\n defaultNamespaceFilter === false ||\n defaultNamespaceFilter === \"false\" ||\n defaultNamespaceFilter === 0 ||\n defaultNamespaceFilter === \"0\" ||\n defaultNamespaceFilter == null ||\n defaultNamespaceFilter === \"null\" ||\n defaultNamespaceFilter === \"undefined\"\n ) {\n defaultNamespaceFilter = \"\"\n } else {\n defaultNamespaceFilter = String(defaultNamespaceFilter)\n }\n return defaultNamespaceFilter\n}\n\nconst defaultNamespaceFilter: string = getNamespaceFilterString(\n typeof process !== \"undefined\"\n ? process.env.ZEED ?? process.env.DEBUG\n : typeof localStorage !== \"undefined\"\n ? localStorage.zeed ?? localStorage.debug\n : \"*\"\n)\n\n/**\n * Filter as described here https://github.com/visionmedia/debug#wildcards\n *\n * @param filter Namespace filter\n * @returns Function to check if filter applies\n */\nexport function useNamespaceFilter(\n filter: string = defaultNamespaceFilter\n): NamespaceFilter {\n let fn: any // (name: string) => boolean\n let reject = [] as RegExp[]\n let accept = [] as RegExp[]\n\n if (!filter) {\n fn = function (name: string) {\n return false\n }\n } else if (filter === \"*\") {\n fn = function (name: string) {\n return true\n }\n } else {\n let i\n const split = filter.split(/[\\s,]+/)\n const len = split.length\n for (i = 0; i < len; i++) {\n if (!split[i]) {\n // ignore empty strings\n continue\n }\n let template = split[i].replace(/\\*/g, \".*?\")\n if (template[0] === \"-\") {\n reject.push(new RegExp(\"^\" + template.substr(1) + \"$\"))\n } else {\n accept.push(new RegExp(\"^\" + template + \"$\"))\n }\n }\n\n fn = function (name: string) {\n if (reject.length === 0 && accept.length === 0) {\n return true\n }\n let i, len\n for (i = 0, len = reject.length; i < len; i++) {\n if (reject[i].test(name)) {\n return false\n }\n }\n for (i = 0, len = accept.length; i < len; i++) {\n if (accept[i].test(name)) {\n return true\n }\n }\n return false\n }\n }\n fn.accept = accept\n fn.reject = reject\n fn.filter = filter\n return fn as NamespaceFilter\n}\n\nconst defaultLevelFilter: any =\n typeof process !== \"undefined\"\n ? process.env.ZEED_LEVEL ?? process.env.LEVEL ?? process.env.DEBUG_LEVEL\n : typeof localStorage !== \"undefined\"\n ? localStorage.zeed_level ?? localStorage.level ?? localStorage.debug_level\n : undefined\n\nexport function useLevelFilter(\n filter: string | number = defaultLevelFilter\n): (level: LogLevel) => boolean {\n let filterLevel: LogLevel = LogLevel.all\n if (typeof filter === \"string\") {\n const l = LogLevelAlias[filter.toLocaleLowerCase().trim()]\n if (l != null) filterLevel = l\n } else if (typeof filter === \"number\") {\n filterLevel = filter as number\n }\n return (level) => level >= filterLevel\n}\n","// Global context across build systems etc.\n\ndeclare global {\n interface ZeedGlobalContext {}\n}\n\ninterface ZeedGlobalIntegration {\n _zeedGlobal?: ZeedGlobalContext\n}\n\nfunction _global(): ZeedGlobalIntegration {\n if (typeof self !== \"undefined\") return self as ZeedGlobalIntegration\n if (typeof window !== \"undefined\") return window as ZeedGlobalIntegration\n if (typeof global !== \"undefined\") return global as ZeedGlobalIntegration\n if (typeof globalThis !== \"undefined\")\n return globalThis as ZeedGlobalIntegration\n throw new Error(\"unable to locate global object\")\n}\n\nexport function getGlobalContext(): ZeedGlobalContext {\n let gcontext = _global()\n if (gcontext._zeedGlobal == null) {\n gcontext._zeedGlobal = {}\n }\n return gcontext._zeedGlobal\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { LoggerConsoleHandler } from \"./log-console\"\nimport { getGlobalContext } from \"./global\"\nimport { LoggerContext, LoggerContextInterface } from \"./log-base\"\n\n// Global logger to guarantee all submodules use the same logger instance\n\nlet globalLogger: LoggerContextInterface\n\ndeclare global {\n interface ZeedGlobalContext {\n logger?: any // Should be LoggerContextInterface, but avoid compiler issues this way\n }\n}\n\nfunction getLoggerContext() {\n let logger = LoggerContext()\n logger.setHandlers([LoggerConsoleHandler()])\n return logger\n}\n\ntry {\n let _global = getGlobalContext()\n if (_global != null) {\n if (_global?.logger == null) {\n globalLogger = getLoggerContext()\n _global.logger = globalLogger\n } else {\n globalLogger = _global.logger\n }\n } else {\n globalLogger = getLoggerContext()\n }\n} catch (e) {\n globalLogger = getLoggerContext()\n}\n\n// /** @deprecated Use `Logger` instead, it is global as well */\n// export const GlobalLogger = globalLogger\n\nexport const Logger = globalLogger\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\n/**\n * @returns Timestamp in miliseconds\n */\nexport const getTimestamp = (): number => Date.now()\n// @ts-ignore\n// typeof performance !== \"undefined\" ? performance.now() : new Date().getTime()\n\nexport function formatMilliseconds(ms: number): string {\n return ms > 999 ? (ms / 1000).toFixed(1) + \"s\" : ms.toFixed(2) + \"ms\"\n}\n\nexport function parseDate(\n ...dateCandidates: (string | Date)[]\n): Date | undefined {\n for (let dateCandidate of dateCandidates) {\n if (dateCandidate instanceof Date) {\n return dateCandidate\n }\n if (typeof dateCandidate === \"string\") {\n let date = null\n if (dateCandidate.includes(\":\")) {\n try {\n date = new Date(dateCandidate)\n } catch (err) {}\n }\n if (!(date instanceof Date)) {\n let m = /(\\d\\d\\d\\d)-(\\d\\d)-(\\d\\d)/.exec(dateCandidate)\n if (m) {\n date = new Date(+m[1], +m[2] - 1, +m[3], 12, 0)\n }\n }\n if (date instanceof Date) {\n return date\n }\n }\n }\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../src/common/data/is.ts","../src/common/data/deep.ts","../src/common/log-console.ts","../src/common/log-base.ts","../src/common/log-filter.ts","../src/common/global.ts","../src/common/log.ts","../src/common/time.ts"],"sourcesContent":["// https://github.com/sindresorhus/is/ MIT\n// https://github.com/sindresorhus/ts-extras\n// https://github.com/sindresorhus/type-fest\n// https://github.com/antfu/utils\n\nexport type Primitive =\n | null\n | undefined\n | string\n | number\n | boolean\n | symbol\n | bigint\n\nexport function isObject(obj: unknown): obj is object {\n return obj != null && typeof obj === \"object\"\n}\n\nexport function isPrimitive(obj: unknown): obj is Primitive {\n return Object(obj) !== obj\n}\n\nexport function isArray(obj: unknown): obj is Array<any> {\n return Array.isArray(obj)\n}\n\nexport function isRecord(obj: unknown): obj is Record<string, any> {\n return isObject(obj) && !isArray(obj)\n}\n\nexport function isString(obj: unknown): obj is string {\n return typeof obj === \"string\"\n}\n\nexport function isNumber(obj: unknown): obj is number {\n return typeof obj === \"number\"\n}\n\nexport function isInteger(obj: unknown): obj is number {\n return typeof obj === \"number\" && Number.isInteger(obj)\n}\n\nexport function isSafeInteger(obj: unknown): obj is number {\n return typeof obj === \"number\" && Number.isSafeInteger(obj)\n}\n\nexport function isBoolean(obj: unknown): obj is boolean {\n return typeof obj === \"boolean\"\n}\n\nexport function isNullOrUndefined(obj: unknown): obj is null | undefined {\n return obj == null\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { isObject, isPrimitive } from \"./is\"\n\n// // https://stackoverflow.com/a/40294058/140927\n// // Handles cyclic references\n// export function deepClonePrimitives(obj, hash = new WeakMap()) {\n//\n// // primitives\n// if (Object(obj) !== obj) {\n// // log('Primitive', obj)\n// return obj\n// }\n//\n// // cyclic reference\n// if (hash.has(obj)) {\n// return hash.get(obj)\n// }\n//\n// let result\n//\n// // primitives as objects like new String(), new Number()\n// if (\n// obj instanceof String ||\n// obj instanceof Number ||\n// obj instanceof BigInt ||\n// obj instanceof Boolean ||\n// obj instanceof Symbol\n// ) {\n// result = new obj.constructor(obj.valueOf())\n// // hash.set(obj, result)\n// return result\n// }\n//\n// // log('Obj', obj)\n//\n// if (obj instanceof Set) {\n// result = new Set(obj)\n// } else if (obj instanceof Map) {\n// result = new Map(Array.from(obj, ([key, val]) => [key, deepClonePrimitives(val, hash)]))\n// } else if (obj instanceof Date) {\n// result = new Date(obj)\n// } else if (obj instanceof RegExp) {\n// result = new RegExp(obj.source, obj.flags)\n// } else if (Array.isArray(obj)) {\n// result = Array.from(obj, val => deepClonePrimitives(val, hash))\n// } else if (obj.constructor) {\n// result = new obj.constructor()\n// log('bj object', result)\n// } else if (obj instanceof Function || typeof obj === 'function') {\n// log('Keep object', obj, Object.getPrototypeOf(obj))\n// result = obj\n// } else {\n// result = Object.create(null)\n// }\n//\n// hash.set(obj, result)\n//\n// return Object.assign(result, ...Object.keys(obj).map(key => ({\n// [key]: deepClonePrimitives(obj[key], hash),\n// })))\n// }\n\nexport function deepEqual(a: any, b: any, hash = new WeakSet()) {\n // if both x and y are null or undefined and exactly the same\n if (a === b) {\n return true\n }\n\n // Cyclic\n if (hash.has(b)) {\n // console.log('cyclic')\n return true\n }\n\n if (!isPrimitive(b)) {\n hash.add(b)\n }\n\n // if they are not strictly equal, they both need to be Objects\n if (!(a instanceof Object) || !(b instanceof Object)) {\n return false\n }\n\n // they must have the exact same prototype chain, the closest we can do is\n // test there constructor.\n if (a.constructor !== b.constructor) {\n return false\n }\n\n // Shortcut to avoid to many loops\n if (a.length !== b.length) {\n return false\n }\n\n for (let p in a) {\n // other properties were tested using x.constructor === y.constructor\n if (!a.hasOwnProperty(p)) {\n continue\n }\n\n // allows to compare x[ p ] and y[ p ] when set to undefined\n if (!b.hasOwnProperty(p)) {\n return false\n }\n\n let aa = a[p]\n let bb = b[p]\n\n // if they have the same strict value or identity then they are equal\n // if (aa === bb) {\n // console.log('eq', typeof bb)\n // if (bb != null) hash.set(bb, true)\n // continue\n // }\n //\n // // Numbers, Strings, Functions, Booleans must be strictly equal\n // if (typeof (aa) !== 'object') {\n // return false\n // }\n\n // Objects and Arrays must be tested recursively\n if (!deepEqual(aa, bb, hash)) {\n return false\n }\n }\n\n // allows x[ p ] to be set to undefined\n for (let p in b) {\n if (b.hasOwnProperty(p) && !a.hasOwnProperty(p)) {\n return false\n }\n }\n\n return true\n}\n\nexport function deepMerge(target: any, ...sources: any[]) {\n for (let source of sources) {\n if (!isObject(target)) {\n target = {}\n }\n\n if (source == null) continue\n\n Object.keys(source).forEach((key) => {\n const targetValue = target[key]\n const sourceValue = source[key]\n\n if (Array.isArray(targetValue) && Array.isArray(sourceValue)) {\n target[key] = targetValue.concat(sourceValue)\n } else if (isObject(targetValue) && isObject(sourceValue)) {\n target[key] = deepMerge(Object.assign({}, targetValue), sourceValue)\n } else {\n target[key] = sourceValue\n }\n })\n }\n\n return target\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { LogHandler, LogHandlerOptions, LogLevel, LogMessage } from \"./log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"./log-filter\"\n\n/**\n * Very basic logger. Please take a look at the browser and node\n * optimized loggers. This one is just the absolute fallback option.\n *\n * @param level Log level\n * @returns Logger\n */\nexport function LoggerConsoleHandler(opt: LogHandlerOptions = {}): LogHandler {\n const {\n level = undefined,\n filter = undefined,\n colors = true,\n levelHelper = false,\n nameBrackets = true,\n padding = 16,\n } = opt\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level)) return\n if (!matchesNamespace(msg.name)) return\n let name = msg.name ? `[${msg.name}]` : \"\"\n switch (msg.level) {\n case LogLevel.info:\n console.info(`I|* ${name}`, ...msg.messages)\n break\n case LogLevel.warn:\n console.warn(`W|** ${name}`, ...msg.messages)\n break\n case LogLevel.error:\n console.error(`E|*** ${name}`, ...msg.messages)\n break\n default:\n console.debug(`D| ${name}`, ...msg.messages)\n break\n }\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { deepEqual } from \"./data/deep\"\nimport { LoggerConsoleHandler } from \"./log-console\"\nimport { useNamespaceFilter } from \"./log-filter\"\n\nexport enum LogLevel {\n all = -1,\n debug = 0,\n info,\n warn,\n error,\n fatal,\n off = Infinity,\n}\n\nexport const LogLevelAlias: Record<string, LogLevel> = {\n \"*\": LogLevel.all,\n a: LogLevel.all,\n all: LogLevel.all,\n d: LogLevel.debug,\n dbg: LogLevel.debug,\n debug: LogLevel.debug,\n i: LogLevel.info,\n inf: LogLevel.info,\n info: LogLevel.info,\n w: LogLevel.warn,\n warn: LogLevel.warn,\n warning: LogLevel.warn,\n e: LogLevel.error,\n err: LogLevel.error,\n error: LogLevel.error,\n fatal: LogLevel.fatal,\n off: LogLevel.off,\n \"-\": LogLevel.off,\n}\n\nexport interface LogMessage {\n level: LogLevel\n name: string\n messages: any[]\n line?: number\n file?: string\n timestamp?: number\n}\n\nexport type LogHandler = (msg: LogMessage) => void\n\nexport interface LoggerInterface {\n (...messages: any[]): void\n\n /** @deprecated use .level = LogLevel.off or LogLevel.all */\n active: boolean\n\n level: LogLevel\n\n debug(...messages: any[]): void\n\n info(...messages: any[]): void\n\n warn(...messages: any[]): void\n\n error(...messages: any[]): void\n\n assert(cond: any, ...messages: any[]): void\n\n /** @deprecated use .assert */\n assertEqual(value: any, expected: any, ...args: any[]): void\n\n /** @deprecated use .assert */\n assertNotEqual(value: any, expected: any, ...args: any[]): void\n\n extend(prefix: string): LoggerInterface\n\n factory?: LoggerContextInterface\n}\n\nexport interface LoggerContextInterface {\n (name?: string): LoggerInterface\n registerHandler(handler: LogHandler): void\n setFilter(namespaces: string): void\n setHandlers(handlers?: (LogHandler | undefined | null)[]): void\n setLock(lock: boolean): void\n setLogLevel(level?: LogLevel): void\n setFactory(factory: (name?: string) => LoggerInterface): void\n}\n\nexport interface LogHandlerOptions {\n level?: LogLevel\n filter?: string\n colors?: boolean\n levelHelper?: boolean\n nameBrackets?: boolean\n padding?: number\n fill?: number\n stack?: boolean | number\n}\n\nexport function LoggerContext(prefix: string = \"\"): LoggerContextInterface {\n let logHandlers: LogHandler[] = [LoggerConsoleHandler()]\n let logAssertLevel: LogLevel = LogLevel.warn\n let logCheckNamespace = (name: string) => true\n let logLock = false\n let logFactory = LoggerBaseFactory\n\n function LoggerBaseFactory(name: string = \"\"): LoggerInterface {\n log.extend = function (prefix: string): LoggerInterface {\n return logFactory(name ? `${name}:${prefix}` : prefix)\n }\n\n const emit = (msg: LogMessage) => {\n if (log.active === true) {\n if (msg.level >= Logger.level && msg.level >= log.level) {\n if (logCheckNamespace(name)) {\n for (let handler of logHandlers) {\n if (handler) handler(msg)\n }\n }\n }\n }\n }\n\n function log(...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.debug,\n })\n }\n\n log.active = true\n log.level = LogLevel.all\n\n log.debug = function (...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.debug,\n })\n }\n\n log.info = function (...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.info,\n })\n }\n\n log.warn = function (...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.warn,\n })\n }\n\n log.error = function (...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.error,\n })\n }\n\n // fatal(...args: any[]) {\n // console.error(...args)\n // },\n\n log.assert = function (cond: any, ...messages: any[]) {\n if (!cond) {\n if (typeof console !== undefined) {\n if (console.assert) {\n // https://developer.mozilla.org/de/docs/Web/API/Console/assert\n console.assert(cond, ...messages)\n } else {\n console.error(`Assert did fail with: ${cond}`, ...messages)\n }\n }\n emit({\n name,\n messages: messages || [`Assert did fail with: ${cond}`],\n level: logAssertLevel,\n })\n // try {\n // if (typeof expect !== undefined) {\n // expect(cond).toBeTruthy()\n // }\n // } catch (err) {\n // methods.warn(...args)\n // }\n }\n }\n\n log.assertEqual = function (value: any, expected: any, ...args: any[]) {\n let equal = deepEqual(value, expected)\n if (!equal) {\n log.assert(\n equal,\n `Assert did fail. Expected ${expected} got ${value}`,\n expected,\n value,\n ...args\n )\n // } else {\n // methods.debug(`Passed equal`)\n }\n }\n\n log.assertNotEqual = function (value: any, expected: any, ...args: any[]) {\n let equal = deepEqual(value, expected)\n if (equal) {\n log.assert(\n equal,\n `Assert did fail. Expected ${expected} not to be equal with ${value}`,\n expected,\n value,\n ...args\n )\n // } else {\n // methods.debug(`Passed not equal check`)\n }\n }\n\n return log\n }\n\n function Logger(name: string = \"\"): LoggerInterface {\n return logFactory(name)\n }\n\n Logger.registerHandler = function (handler: LogHandler) {\n logHandlers.push(handler)\n }\n\n Logger.setFilter = function (namespaces: string) {\n logCheckNamespace = useNamespaceFilter(namespaces)\n }\n\n Logger.setLock = (lock: boolean = true) => (logLock = lock)\n\n Logger.setHandlers = function (handlers: LogHandler[] = []) {\n if (logFactory !== LoggerBaseFactory) {\n logFactory = LoggerBaseFactory\n }\n if (logLock) return\n logHandlers = [...handlers].filter((h) => typeof h === \"function\")\n }\n\n Logger.level = LogLevel.all\n\n /** @deprecated */\n Logger.setLogLevel = function (level: LogLevel = LogLevel.all) {\n if (logLock) return\n Logger.level = level\n }\n\n Logger.setFactory = function (\n factory: (name?: string) => LoggerInterface\n ): void {\n if (logLock) return\n logFactory = factory\n }\n\n return Logger\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { LogLevel, LogLevelAlias } from \"./log-base\"\n\ninterface NamespaceFilter {\n (name: string): boolean\n accept: RegExp[]\n reject: RegExp[]\n filter: string\n}\n\nexport function getNamespaceFilterString(defaultNamespaceFilter: any): string {\n if (\n defaultNamespaceFilter === true ||\n defaultNamespaceFilter === \"true\" ||\n defaultNamespaceFilter === \"1\" ||\n (typeof defaultNamespaceFilter === \"number\" && defaultNamespaceFilter !== 0)\n ) {\n defaultNamespaceFilter = \"*\"\n } else if (\n defaultNamespaceFilter === false ||\n defaultNamespaceFilter === \"false\" ||\n defaultNamespaceFilter === 0 ||\n defaultNamespaceFilter === \"0\" ||\n defaultNamespaceFilter == null ||\n defaultNamespaceFilter === \"null\" ||\n defaultNamespaceFilter === \"undefined\"\n ) {\n defaultNamespaceFilter = \"\"\n } else {\n defaultNamespaceFilter = String(defaultNamespaceFilter)\n }\n return defaultNamespaceFilter\n}\n\nconst defaultNamespaceFilter: string = getNamespaceFilterString(\n typeof process !== \"undefined\"\n ? process.env.ZEED ?? process.env.DEBUG\n : typeof localStorage !== \"undefined\"\n ? localStorage.zeed ?? localStorage.debug\n : \"*\"\n)\n\n/**\n * Filter as described here https://github.com/visionmedia/debug#wildcards\n *\n * @param filter Namespace filter\n * @returns Function to check if filter applies\n */\nexport function useNamespaceFilter(\n filter: string = defaultNamespaceFilter\n): NamespaceFilter {\n let fn: any // (name: string) => boolean\n let reject = [] as RegExp[]\n let accept = [] as RegExp[]\n\n if (!filter) {\n fn = function (name: string) {\n return false\n }\n } else if (filter === \"*\") {\n fn = function (name: string) {\n return true\n }\n } else {\n let i\n const split = filter.split(/[\\s,]+/)\n const len = split.length\n for (i = 0; i < len; i++) {\n if (!split[i]) {\n // ignore empty strings\n continue\n }\n let template = split[i].replace(/\\*/g, \".*?\")\n if (template[0] === \"-\") {\n reject.push(new RegExp(\"^\" + template.substr(1) + \"$\"))\n } else {\n accept.push(new RegExp(\"^\" + template + \"$\"))\n }\n }\n\n fn = function (name: string) {\n if (reject.length === 0 && accept.length === 0) {\n return true\n }\n let i, len\n for (i = 0, len = reject.length; i < len; i++) {\n if (reject[i].test(name)) {\n return false\n }\n }\n for (i = 0, len = accept.length; i < len; i++) {\n if (accept[i].test(name)) {\n return true\n }\n }\n return false\n }\n }\n fn.accept = accept\n fn.reject = reject\n fn.filter = filter\n return fn as NamespaceFilter\n}\n\nconst defaultLevelFilter: any =\n typeof process !== \"undefined\"\n ? process.env.ZEED_LEVEL ?? process.env.LEVEL ?? process.env.DEBUG_LEVEL\n : typeof localStorage !== \"undefined\"\n ? localStorage.zeed_level ?? localStorage.level ?? localStorage.debug_level\n : undefined\n\nexport function useLevelFilter(\n filter: string | number = defaultLevelFilter\n): (level: LogLevel) => boolean {\n let filterLevel: LogLevel = LogLevel.all\n if (typeof filter === \"string\") {\n const l = LogLevelAlias[filter.toLocaleLowerCase().trim()]\n if (l != null) filterLevel = l\n } else if (typeof filter === \"number\") {\n filterLevel = filter as number\n }\n return (level) => level >= filterLevel\n}\n","// Global context across build systems etc.\n\ndeclare global {\n interface ZeedGlobalContext {}\n}\n\ninterface ZeedGlobalIntegration {\n _zeedGlobal?: ZeedGlobalContext\n}\n\nfunction _global(): ZeedGlobalIntegration {\n if (typeof self !== \"undefined\") return self as ZeedGlobalIntegration\n if (typeof window !== \"undefined\") return window as ZeedGlobalIntegration\n if (typeof global !== \"undefined\") return global as ZeedGlobalIntegration\n if (typeof globalThis !== \"undefined\")\n return globalThis as ZeedGlobalIntegration\n throw new Error(\"unable to locate global object\")\n}\n\nexport function getGlobalContext(): ZeedGlobalContext {\n let gcontext = _global()\n if (gcontext._zeedGlobal == null) {\n gcontext._zeedGlobal = {}\n }\n return gcontext._zeedGlobal\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { LoggerConsoleHandler } from \"./log-console\"\nimport { getGlobalContext } from \"./global\"\nimport { LoggerContext, LoggerContextInterface } from \"./log-base\"\n\n// Global logger to guarantee all submodules use the same logger instance\n\nlet globalLogger: LoggerContextInterface\n\ndeclare global {\n interface ZeedGlobalContext {\n logger?: any // Should be LoggerContextInterface, but avoid compiler issues this way\n }\n}\n\nfunction getLoggerContext() {\n let logger = LoggerContext()\n logger.setHandlers([LoggerConsoleHandler()])\n return logger\n}\n\ntry {\n let _global = getGlobalContext()\n if (_global != null) {\n if (_global?.logger == null) {\n globalLogger = getLoggerContext()\n _global.logger = globalLogger\n } else {\n globalLogger = _global.logger\n }\n } else {\n globalLogger = getLoggerContext()\n }\n} catch (e) {\n globalLogger = getLoggerContext()\n}\n\n// /** @deprecated Use `Logger` instead, it is global as well */\n// export const GlobalLogger = globalLogger\n\nexport const Logger = globalLogger\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\n/**\n * @returns Timestamp in miliseconds\n */\nexport const getTimestamp = (): number => Date.now()\n// @ts-ignore\n// typeof performance !== \"undefined\" ? performance.now() : new Date().getTime()\n\nexport function formatMilliseconds(ms: number): string {\n return ms > 999 ? (ms / 1000).toFixed(1) + \"s\" : ms.toFixed(2) + \"ms\"\n}\n\nexport function parseDate(\n ...dateCandidates: (string | Date)[]\n): Date | undefined {\n for (let dateCandidate of dateCandidates) {\n if (dateCandidate instanceof Date) {\n return dateCandidate\n }\n if (typeof dateCandidate === \"string\") {\n let date = null\n if (dateCandidate.includes(\":\")) {\n try {\n date = new Date(dateCandidate)\n } catch (err) {}\n }\n if (!(date instanceof Date)) {\n let m = /(\\d\\d\\d\\d)-(\\d\\d)-(\\d\\d)/.exec(dateCandidate)\n if (m) {\n date = new Date(+m[1], +m[2] - 1, +m[3], 12, 0)\n }\n }\n if (date instanceof Date) {\n return date\n }\n }\n }\n}\n"],"mappings":"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","names":[]}