zeed 0.8.1 → 0.8.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.
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.log.ts","../src/common/data/is.ts","../src/common/data/deep.ts","../src/common/log-filter.ts","../src/common/log-base.ts","../src/common/log-console.ts","../src/common/global.ts","../src/common/log.ts","../src/common/time.ts","../src/browser/log-colors.ts","../src/browser/log-browser.ts"],"sourcesContent":["// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nexport * from \"./common/log\"\nexport * from \"./browser/log-browser\"\n","// 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\nexport function isUint8Array(obj: unknown): obj is Uint8Array {\n return isObject(obj) && obj.constructor.name === \"Uint8Array\"\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { isObject, isPrimitive } from \"./is\"\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\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","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { LogLevel, LogLevelAlias, LogLevelAliasType } 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 parseLogLevel(filter: LogLevelAliasType): LogLevel {\n if (filter === false) return LogLevel.off\n if (typeof filter === \"number\") return filter as number\n if (typeof filter === \"string\") {\n const l = LogLevelAlias[filter.toLocaleLowerCase().trim()]\n if (l != null) return l\n }\n return LogLevel.all\n}\n\nexport function useLevelFilter(\n filter: string | number | boolean | LogLevelAliasType = defaultLevelFilter\n): (level: LogLevel) => boolean {\n const filterLevel = parseLogLevel(filter)\n return (level) => level >= filterLevel\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 { parseLogLevel, 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 type LogLevelAliasKey = keyof typeof LogLevelAlias\nexport type LogLevelAliasType = LogLevel | boolean | LogLevelAliasKey\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 label: string\n}\n\nexport interface LoggerContextInterface {\n (name?: string, level?: LogLevelAliasType): 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(\n name: string = \"\",\n level?: LogLevelAliasType\n ): LoggerInterface {\n function log(...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.debug,\n })\n }\n\n log.label = name\n log.active = true\n log.level = parseLogLevel(level ?? LogLevel.all)\n\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 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 // https://www.typescriptlang.org/docs/handbook/release-notes/typescript-3-7.html#assertion-functions\n log.assert = function (cond: any, ...messages: any[]): asserts cond {\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(\n name: string = \"\",\n level?: LogLevelAliasType\n ): LoggerInterface {\n return logFactory(name, level)\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 { 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","// 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","// Taken from https://github.com/visionmedia/debug/blob/master/src/browser.js#L27\n\nconst colors = [\n \"#0000CC\",\n \"#0000FF\",\n \"#0033CC\",\n \"#0033FF\",\n \"#0066CC\",\n \"#0066FF\",\n \"#0099CC\",\n \"#0099FF\",\n \"#00CC00\",\n \"#00CC33\",\n \"#00CC66\",\n \"#00CC99\",\n \"#00CCCC\",\n \"#00CCFF\",\n \"#3300CC\",\n \"#3300FF\",\n \"#3333CC\",\n \"#3333FF\",\n \"#3366CC\",\n \"#3366FF\",\n \"#3399CC\",\n \"#3399FF\",\n \"#33CC00\",\n \"#33CC33\",\n \"#33CC66\",\n \"#33CC99\",\n \"#33CCCC\",\n \"#33CCFF\",\n \"#6600CC\",\n \"#6600FF\",\n \"#6633CC\",\n \"#6633FF\",\n \"#66CC00\",\n \"#66CC33\",\n \"#9900CC\",\n \"#9900FF\",\n \"#9933CC\",\n \"#9933FF\",\n \"#99CC00\",\n \"#99CC33\",\n \"#CC0000\",\n \"#CC0033\",\n \"#CC0066\",\n \"#CC0099\",\n \"#CC00CC\",\n \"#CC00FF\",\n \"#CC3300\",\n \"#CC3333\",\n \"#CC3366\",\n \"#CC3399\",\n \"#CC33CC\",\n \"#CC33FF\",\n \"#CC6600\",\n \"#CC6633\",\n \"#CC9900\",\n \"#CC9933\",\n \"#CCCC00\",\n \"#CCCC33\",\n \"#FF0000\",\n \"#FF0033\",\n \"#FF0066\",\n \"#FF0099\",\n \"#FF00CC\",\n \"#FF00FF\",\n \"#FF3300\",\n \"#FF3333\",\n \"#FF3366\",\n \"#FF3399\",\n \"#FF33CC\",\n \"#FF33FF\",\n \"#FF6600\",\n \"#FF6633\",\n \"#FF9900\",\n \"#FF9933\",\n \"#FFCC00\",\n \"#FFCC33\",\n]\n\nexport function supportsColors(): boolean {\n // NB: In an Electron preload script, document will be defined but not fully\n // initialized. Since we know we're in Chrome, we'll just detect this case\n // explicitly\n if (\n typeof window !== \"undefined\" &&\n window.process &&\n // @ts-ignore\n (window.process.type === \"renderer\" || window.process.__nwjs)\n ) {\n return true\n }\n\n // Internet Explorer and Edge do not support colors.\n if (\n typeof navigator !== \"undefined\" &&\n navigator.userAgent &&\n navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)\n ) {\n return false\n }\n\n // Is webkit? http://stackoverflow.com/a/16459606/376773\n // document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n return (\n (typeof document !== \"undefined\" &&\n document.documentElement &&\n document.documentElement.style &&\n // @ts-ignore\n document.documentElement.style.WebkitAppearance) ||\n // Is firebug? http://stackoverflow.com/a/398120/376773\n (typeof window !== \"undefined\" &&\n window.console &&\n // @ts-ignore\n (window.console.firebug ||\n // @ts-ignore\n (window.console.exception && window.console.table))) ||\n // Is firefox >= v31?\n // https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n (typeof navigator !== \"undefined\" &&\n navigator.userAgent &&\n navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/) &&\n parseInt(RegExp.$1, 10) >= 31) ||\n // Double check webkit in userAgent just in case we are in a worker\n (typeof navigator !== \"undefined\" &&\n navigator.userAgent &&\n navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/))\n )\n}\n\nexport function selectColor(namespace: string) {\n let hash = 0\n for (let i = 0; i < namespace.length; i++) {\n hash = (hash << 5) - hash + namespace.charCodeAt(i)\n hash |= 0 // Convert to 32bit integer\n }\n return colors[Math.abs(hash) % colors.length]\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { deepEqual } from \"../common/data/deep\"\nimport {\n LoggerInterface,\n LogHandler,\n LogHandlerOptions,\n LogLevel,\n LogMessage,\n} from \"../common/log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"../common/log-filter\"\nimport { formatMilliseconds, getTimestamp } from \"../common/time\"\nimport { selectColor, supportsColors } from \"./log-colors\"\n\nconst styleFont = `font-family: \"JetBrains Mono\", Menlo; font-size: 11px;`\nconst styleDefault = `${styleFont}`\nconst styleBold = `font-weight: 600; ${styleFont}`\nconst useColors = supportsColors()\n\nlet namespaces: Record<string, any> = {}\n\nlet time = getTimestamp()\n\nexport function LoggerBrowserHandler(opt: LogHandlerOptions = {}): LogHandler {\n const {\n filter = undefined,\n level = 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\n const timeNow = getTimestamp()\n let name = msg.name || \"\"\n let ninfo = namespaces[name || \"\"]\n if (ninfo == null) {\n ninfo = {\n color: selectColor(name),\n // time: timeNow\n }\n namespaces[name] = ninfo\n }\n const diff = formatMilliseconds(timeNow - time)\n let args: string[]\n\n if (padding > 0) {\n name = name.padEnd(16, \" \")\n }\n\n if (colors && useColors) {\n args = [`%c${name}%c \\t%s %c+${diff}`]\n args.push(`color:${ninfo.color}; ${styleBold}`)\n args.push(styleDefault)\n args.push(msg.messages?.[0] ?? \"\")\n args.push(`color:${ninfo.color};`)\n args.push(...msg.messages.slice(1))\n } else {\n args = [name, ...msg.messages, `+${diff}`]\n }\n\n // function consoleArgs(args: any[] = []): any[] {\n // return [\n // args\n // .filter((a) => typeof a === \"string\")\n // .map((a) => String(a))\n // .join(\" \"),\n // ...styles,\n // ...args.filter((a) => typeof a !== \"string\"),\n // ]\n // }\n\n switch (msg.level) {\n case LogLevel.info:\n if (opt.levelHelper) args[0] = `I|* ` + args[0]\n console.info(...args)\n break\n case LogLevel.warn:\n if (opt.levelHelper) args[0] = `W|** ` + args[0]\n console.warn(...args)\n break\n case LogLevel.error:\n if (opt.levelHelper) args[0] = `E|*** ` + args[0]\n console.error(...args)\n break\n default:\n if (opt.levelHelper) args[0] = `D| ` + args[0]\n console.debug(...args)\n break\n }\n }\n}\n\nexport function LoggerBrowserSetupDebugFactory(opt: LogHandlerOptions = {}) {\n const filter = opt.filter ?? localStorage.zeed ?? localStorage.debug\n\n /// The trick is, that console called directly provides a reference to the source code.\n /// For the regular implementation this information is lost. But this approach has other\n /// drawbacks, therefore only use it in the Browser when actively debugging.\n return function LoggerBrowserDebugFactory(\n name: string = \"\"\n ): LoggerInterface {\n let log: LoggerInterface\n\n const matches = useNamespaceFilter(filter)\n\n if (matches(name)) {\n let fixedArgs = []\n if (useColors) {\n const color = selectColor(name)\n fixedArgs.push(`%c${name.padEnd(16, \" \")}%c \\t%s`)\n fixedArgs.push(`color:${color}; ${styleBold}`)\n fixedArgs.push(styleDefault)\n } else {\n fixedArgs.push(`[${name}] \\t%s`)\n }\n\n // @ts-ignore\n // console.previous = {\n // debug: console.debug,\n // info: console.info,\n // warn: console.warn,\n // error: console.error,\n // assert: console.assert,\n // }\n\n log = console.debug.bind(console, ...fixedArgs) as LoggerInterface\n log.debug = console.debug.bind(console, ...fixedArgs)\n log.info = console.info.bind(console, ...fixedArgs)\n log.warn = console.warn.bind(console, ...fixedArgs)\n log.error = console.error.bind(console, ...fixedArgs)\n\n log.assert = console.assert.bind(console)\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 }\n }\n\n log.assertNotEqual = function (\n value: any,\n expected: any,\n ...args: any[]\n ) {\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 }\n }\n } else {\n const noop = () => {}\n log = noop as LoggerInterface\n log.debug = noop\n log.info = noop\n log.warn = noop\n log.error = noop\n\n log.assert = noop\n log.assertEqual = noop\n log.assertNotEqual = noop\n }\n\n log.extend = (subName: string) => {\n return LoggerBrowserDebugFactory(name ? `${name}:${subName}` : subName)\n }\n\n log.label = name\n\n return log\n }\n}\n\n/** @deprecated This output is default for initial use of Logger in browser environments. */\nexport function activateConsoleDebug(opt: LogHandlerOptions = {}) {\n console.info(\"activateConsoleDebug is activated by default in browsers\")\n // Logger.setHandlers([LoggerBrowserHandler(opt)]) // Fallback for previously registered Loggers\n // Logger.setFactory(LoggerBrowserSetupDebugFactory(opt))\n}\n\n// let klass = console\n// let debug = console.debug.bind(window.console, klass.toString() + \": \")\n\n// debug(\"test\")\n// console.debug(\"test2\")\n\n// let dd\n// if (Function.prototype.bind) {\n// dd = Function.prototype.bind.call(console.log, console)\n// } else {\n// dd = function () {\n// Function.prototype.apply.call(console.log, console, arguments)\n// }\n// }\n\n// dd(\"dd\")\n\n// let c = 1\n// Object.defineProperty(window, \"log2\", {\n// get: () => {\n// return console.log.bind(\n// window.console,\n// \"%c[log]%c %s\" + c++,\n// \"color:red\",\n// \"\"\n// )\n// },\n// })\n\n// // usage:\n// log2(\"Back to the future\")\n// log2(\"Back to the future\")\n\n// let plog = new Proxy(console.debug, {\n// apply: function (target, that, args) {\n// target.apply(that, args)\n// // base.apply(that, args);\n// },\n// })\n\n// let cons = console.debug\n// let plog = (...args) => {\n// cons.apply(window.console, [\"|\", ...args])\n// }\n\n// plog(\"xxx\")\n\n// function a() {\n// var err = new Error()\n// var caller_line = err.stack.split(\"\\n\")[2]\n// var index = caller_line.indexOf(\"at \")\n// var clean = caller_line.slice(index + 2, caller_line.length)\n// clean = clean.replace(/\\?t=\\d+/, \"\").replace(\"@fs/\", \"\")\n// console.log(clean)\n// console.log(\n// \"http://localhost:8080/Users/dirk/work/viidoo/lib/src/browser/log-browser.ts:188:1 log-browser.ts:291:10\"\n// )\n// }\n// function b() {\n// a()\n// }\n// b()\n"],"mappings":"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","names":["defaultNamespaceFilter","i","len","prefix","Logger","namespaces","colors","_global","colors"]}
1
+ {"version":3,"sources":["../src/index.log.ts","../src/common/data/is.ts","../src/common/data/deep.ts","../src/common/log-filter.ts","../src/common/log-base.ts","../src/common/log-console.ts","../src/common/global.ts","../src/common/log.ts","../src/common/time.ts","../src/browser/log-colors.ts","../src/browser/log-browser.ts"],"names":["defaultNamespaceFilter","i","len","prefix","Logger","namespaces","colors","_global"],"mappings":"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","sourcesContent":["// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nexport * from \"./common/log\"\nexport * from \"./browser/log-browser\"\n","// 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\nexport function isUint8Array(obj: unknown): obj is Uint8Array {\n return isObject(obj) && obj.constructor.name === \"Uint8Array\"\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { isObject, isPrimitive } from \"./is\"\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\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","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { LogLevel, LogLevelAlias, LogLevelAliasType } 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 parseLogLevel(filter: LogLevelAliasType): LogLevel {\n if (filter === false) return LogLevel.off\n if (typeof filter === \"number\") return filter as number\n if (typeof filter === \"string\") {\n const l = LogLevelAlias[filter.toLocaleLowerCase().trim()]\n if (l != null) return l\n }\n return LogLevel.all\n}\n\nexport function useLevelFilter(\n filter: string | number | boolean | LogLevelAliasType = defaultLevelFilter\n): (level: LogLevel) => boolean {\n const filterLevel = parseLogLevel(filter)\n return (level) => level >= filterLevel\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 { parseLogLevel, 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 type LogLevelAliasKey = keyof typeof LogLevelAlias\nexport type LogLevelAliasType = LogLevel | boolean | LogLevelAliasKey\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 label: string\n}\n\nexport interface LoggerContextInterface {\n (name?: string, level?: LogLevelAliasType): 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(\n name: string = \"\",\n level?: LogLevelAliasType\n ): LoggerInterface {\n function log(...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.debug,\n })\n }\n\n log.label = name\n log.active = true\n log.level = parseLogLevel(level ?? LogLevel.all)\n\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 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 // https://www.typescriptlang.org/docs/handbook/release-notes/typescript-3-7.html#assertion-functions\n log.assert = function (cond: any, ...messages: any[]): asserts cond {\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(\n name: string = \"\",\n level?: LogLevelAliasType\n ): LoggerInterface {\n return logFactory(name, level)\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 { 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","// 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","// Taken from https://github.com/visionmedia/debug/blob/master/src/browser.js#L27\n\nconst colors = [\n \"#0000CC\",\n \"#0000FF\",\n \"#0033CC\",\n \"#0033FF\",\n \"#0066CC\",\n \"#0066FF\",\n \"#0099CC\",\n \"#0099FF\",\n \"#00CC00\",\n \"#00CC33\",\n \"#00CC66\",\n \"#00CC99\",\n \"#00CCCC\",\n \"#00CCFF\",\n \"#3300CC\",\n \"#3300FF\",\n \"#3333CC\",\n \"#3333FF\",\n \"#3366CC\",\n \"#3366FF\",\n \"#3399CC\",\n \"#3399FF\",\n \"#33CC00\",\n \"#33CC33\",\n \"#33CC66\",\n \"#33CC99\",\n \"#33CCCC\",\n \"#33CCFF\",\n \"#6600CC\",\n \"#6600FF\",\n \"#6633CC\",\n \"#6633FF\",\n \"#66CC00\",\n \"#66CC33\",\n \"#9900CC\",\n \"#9900FF\",\n \"#9933CC\",\n \"#9933FF\",\n \"#99CC00\",\n \"#99CC33\",\n \"#CC0000\",\n \"#CC0033\",\n \"#CC0066\",\n \"#CC0099\",\n \"#CC00CC\",\n \"#CC00FF\",\n \"#CC3300\",\n \"#CC3333\",\n \"#CC3366\",\n \"#CC3399\",\n \"#CC33CC\",\n \"#CC33FF\",\n \"#CC6600\",\n \"#CC6633\",\n \"#CC9900\",\n \"#CC9933\",\n \"#CCCC00\",\n \"#CCCC33\",\n \"#FF0000\",\n \"#FF0033\",\n \"#FF0066\",\n \"#FF0099\",\n \"#FF00CC\",\n \"#FF00FF\",\n \"#FF3300\",\n \"#FF3333\",\n \"#FF3366\",\n \"#FF3399\",\n \"#FF33CC\",\n \"#FF33FF\",\n \"#FF6600\",\n \"#FF6633\",\n \"#FF9900\",\n \"#FF9933\",\n \"#FFCC00\",\n \"#FFCC33\",\n]\n\nexport function supportsColors(): boolean {\n // NB: In an Electron preload script, document will be defined but not fully\n // initialized. Since we know we're in Chrome, we'll just detect this case\n // explicitly\n if (\n typeof window !== \"undefined\" &&\n window.process &&\n // @ts-ignore\n (window.process.type === \"renderer\" || window.process.__nwjs)\n ) {\n return true\n }\n\n // Internet Explorer and Edge do not support colors.\n if (\n typeof navigator !== \"undefined\" &&\n navigator.userAgent &&\n navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)\n ) {\n return false\n }\n\n // Is webkit? http://stackoverflow.com/a/16459606/376773\n // document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n return (\n (typeof document !== \"undefined\" &&\n document.documentElement &&\n document.documentElement.style &&\n // @ts-ignore\n document.documentElement.style.WebkitAppearance) ||\n // Is firebug? http://stackoverflow.com/a/398120/376773\n (typeof window !== \"undefined\" &&\n window.console &&\n // @ts-ignore\n (window.console.firebug ||\n // @ts-ignore\n (window.console.exception && window.console.table))) ||\n // Is firefox >= v31?\n // https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n (typeof navigator !== \"undefined\" &&\n navigator.userAgent &&\n navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/) &&\n parseInt(RegExp.$1, 10) >= 31) ||\n // Double check webkit in userAgent just in case we are in a worker\n (typeof navigator !== \"undefined\" &&\n navigator.userAgent &&\n navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/))\n )\n}\n\nexport function selectColor(namespace: string) {\n let hash = 0\n for (let i = 0; i < namespace.length; i++) {\n hash = (hash << 5) - hash + namespace.charCodeAt(i)\n hash |= 0 // Convert to 32bit integer\n }\n return colors[Math.abs(hash) % colors.length]\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { deepEqual } from \"../common/data/deep\"\nimport {\n LoggerInterface,\n LogHandler,\n LogHandlerOptions,\n LogLevel,\n LogMessage,\n} from \"../common/log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"../common/log-filter\"\nimport { formatMilliseconds, getTimestamp } from \"../common/time\"\nimport { selectColor, supportsColors } from \"./log-colors\"\n\nconst styleFont = `font-family: \"JetBrains Mono\", Menlo; font-size: 11px;`\nconst styleDefault = `${styleFont}`\nconst styleBold = `font-weight: 600; ${styleFont}`\nconst useColors = supportsColors()\n\nlet namespaces: Record<string, any> = {}\n\nlet time = getTimestamp()\n\nexport function LoggerBrowserHandler(opt: LogHandlerOptions = {}): LogHandler {\n const {\n filter = undefined,\n level = 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\n const timeNow = getTimestamp()\n let name = msg.name || \"\"\n let ninfo = namespaces[name || \"\"]\n if (ninfo == null) {\n ninfo = {\n color: selectColor(name),\n // time: timeNow\n }\n namespaces[name] = ninfo\n }\n const diff = formatMilliseconds(timeNow - time)\n let args: string[]\n\n if (padding > 0) {\n name = name.padEnd(16, \" \")\n }\n\n if (colors && useColors) {\n args = [`%c${name}%c \\t%s %c+${diff}`]\n args.push(`color:${ninfo.color}; ${styleBold}`)\n args.push(styleDefault)\n args.push(msg.messages?.[0] ?? \"\")\n args.push(`color:${ninfo.color};`)\n args.push(...msg.messages.slice(1))\n } else {\n args = [name, ...msg.messages, `+${diff}`]\n }\n\n // function consoleArgs(args: any[] = []): any[] {\n // return [\n // args\n // .filter((a) => typeof a === \"string\")\n // .map((a) => String(a))\n // .join(\" \"),\n // ...styles,\n // ...args.filter((a) => typeof a !== \"string\"),\n // ]\n // }\n\n switch (msg.level) {\n case LogLevel.info:\n if (opt.levelHelper) args[0] = `I|* ` + args[0]\n console.info(...args)\n break\n case LogLevel.warn:\n if (opt.levelHelper) args[0] = `W|** ` + args[0]\n console.warn(...args)\n break\n case LogLevel.error:\n if (opt.levelHelper) args[0] = `E|*** ` + args[0]\n console.error(...args)\n break\n default:\n if (opt.levelHelper) args[0] = `D| ` + args[0]\n console.debug(...args)\n break\n }\n }\n}\n\nexport function LoggerBrowserSetupDebugFactory(opt: LogHandlerOptions = {}) {\n const filter = opt.filter ?? localStorage.zeed ?? localStorage.debug\n\n /// The trick is, that console called directly provides a reference to the source code.\n /// For the regular implementation this information is lost. But this approach has other\n /// drawbacks, therefore only use it in the Browser when actively debugging.\n return function LoggerBrowserDebugFactory(\n name: string = \"\"\n ): LoggerInterface {\n let log: LoggerInterface\n\n const matches = useNamespaceFilter(filter)\n\n if (matches(name)) {\n let fixedArgs = []\n if (useColors) {\n const color = selectColor(name)\n fixedArgs.push(`%c${name.padEnd(16, \" \")}%c \\t%s`)\n fixedArgs.push(`color:${color}; ${styleBold}`)\n fixedArgs.push(styleDefault)\n } else {\n fixedArgs.push(`[${name}] \\t%s`)\n }\n\n // @ts-ignore\n // console.previous = {\n // debug: console.debug,\n // info: console.info,\n // warn: console.warn,\n // error: console.error,\n // assert: console.assert,\n // }\n\n log = console.debug.bind(console, ...fixedArgs) as LoggerInterface\n log.debug = console.debug.bind(console, ...fixedArgs)\n log.info = console.info.bind(console, ...fixedArgs)\n log.warn = console.warn.bind(console, ...fixedArgs)\n log.error = console.error.bind(console, ...fixedArgs)\n\n log.assert = console.assert.bind(console)\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 }\n }\n\n log.assertNotEqual = function (\n value: any,\n expected: any,\n ...args: any[]\n ) {\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 }\n }\n } else {\n const noop = () => {}\n log = noop as LoggerInterface\n log.debug = noop\n log.info = noop\n log.warn = noop\n log.error = noop\n\n log.assert = noop\n log.assertEqual = noop\n log.assertNotEqual = noop\n }\n\n log.extend = (subName: string) => {\n return LoggerBrowserDebugFactory(name ? `${name}:${subName}` : subName)\n }\n\n log.label = name\n\n return log\n }\n}\n\n/** @deprecated This output is default for initial use of Logger in browser environments. */\nexport function activateConsoleDebug(opt: LogHandlerOptions = {}) {\n console.info(\"activateConsoleDebug is activated by default in browsers\")\n // Logger.setHandlers([LoggerBrowserHandler(opt)]) // Fallback for previously registered Loggers\n // Logger.setFactory(LoggerBrowserSetupDebugFactory(opt))\n}\n\n// let klass = console\n// let debug = console.debug.bind(window.console, klass.toString() + \": \")\n\n// debug(\"test\")\n// console.debug(\"test2\")\n\n// let dd\n// if (Function.prototype.bind) {\n// dd = Function.prototype.bind.call(console.log, console)\n// } else {\n// dd = function () {\n// Function.prototype.apply.call(console.log, console, arguments)\n// }\n// }\n\n// dd(\"dd\")\n\n// let c = 1\n// Object.defineProperty(window, \"log2\", {\n// get: () => {\n// return console.log.bind(\n// window.console,\n// \"%c[log]%c %s\" + c++,\n// \"color:red\",\n// \"\"\n// )\n// },\n// })\n\n// // usage:\n// log2(\"Back to the future\")\n// log2(\"Back to the future\")\n\n// let plog = new Proxy(console.debug, {\n// apply: function (target, that, args) {\n// target.apply(that, args)\n// // base.apply(that, args);\n// },\n// })\n\n// let cons = console.debug\n// let plog = (...args) => {\n// cons.apply(window.console, [\"|\", ...args])\n// }\n\n// plog(\"xxx\")\n\n// function a() {\n// var err = new Error()\n// var caller_line = err.stack.split(\"\\n\")[2]\n// var index = caller_line.indexOf(\"at \")\n// var clean = caller_line.slice(index + 2, caller_line.length)\n// clean = clean.replace(/\\?t=\\d+/, \"\").replace(\"@fs/\", \"\")\n// console.log(clean)\n// console.log(\n// \"http://localhost:8080/Users/dirk/work/viidoo/lib/src/browser/log-browser.ts:188:1 log-browser.ts:291:10\"\n// )\n// }\n// function b() {\n// a()\n// }\n// b()\n"]}
package/dist/index.log.js CHANGED
@@ -1,15 +1,3 @@
1
- import {
2
- LoggerBrowserHandler,
3
- LoggerBrowserSetupDebugFactory,
4
- activateConsoleDebug
5
- } from "./chunk-OJCXV4BY.js";
6
- import {
7
- Logger
8
- } from "./chunk-AM7QCF4I.js";
9
- export {
10
- Logger,
11
- LoggerBrowserHandler,
12
- LoggerBrowserSetupDebugFactory,
13
- activateConsoleDebug
14
- };
1
+ export { LoggerBrowserHandler, LoggerBrowserSetupDebugFactory, activateConsoleDebug } from './chunk-OJCXV4BY.js';
2
+ export { Logger } from './chunk-AM7QCF4I.js';
15
3
  //# sourceMappingURL=index.log.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
1
+ {"version":3,"sources":[],"names":[],"mappings":""}
@@ -1,4 +1,5 @@
1
- "use strict";
1
+ 'use strict';
2
+
2
3
  var __create = Object.create;
3
4
  var __defProp = Object.defineProperty;
4
5
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
@@ -908,8 +909,7 @@ function Uint8ArrayToJson(data) {
908
909
  }
909
910
  __name(Uint8ArrayToJson, "Uint8ArrayToJson");
910
911
  function Uint8ArrayToHexDump(buffer, blockSize) {
911
- if (typeof buffer === "string") {
912
- } else if (buffer instanceof ArrayBuffer && buffer.byteLength !== void 0) {
912
+ if (typeof buffer === "string") ; else if (buffer instanceof ArrayBuffer && buffer.byteLength !== void 0) {
913
913
  buffer = String.fromCharCode.apply(
914
914
  String,
915
915
  [].slice.call(new Uint8Array(buffer))
@@ -1026,8 +1026,6 @@ __name(decrypt, "decrypt");
1026
1026
 
1027
1027
  // src/common/csv.ts
1028
1028
  var separator = ",";
1029
- var preventCast = false;
1030
- var ignoreNullOrUndefined = true;
1031
1029
  function filterFloat(value) {
1032
1030
  if (/^([-+])?([0-9]+(\.[0-9]+)?|Infinity)$/.test(value)) {
1033
1031
  return Number(value);
@@ -1036,12 +1034,9 @@ function filterFloat(value) {
1036
1034
  }
1037
1035
  __name(filterFloat, "filterFloat");
1038
1036
  function escape2(field) {
1039
- if (ignoreNullOrUndefined && field == void 0) {
1037
+ if (field == void 0) {
1040
1038
  return "";
1041
1039
  }
1042
- if (preventCast) {
1043
- return '="' + String(field).replace(/"/g, '""') + '"';
1044
- }
1045
1040
  if (!isNaN(filterFloat(field)) && isFinite(field)) {
1046
1041
  return parseFloat(field);
1047
1042
  }
@@ -3189,10 +3184,7 @@ var SerialQueue = class extends Emitter {
3189
3184
  }
3190
3185
  };
3191
3186
  __name(SerialQueue, "SerialQueue");
3192
-
3193
- // src/common/exec/throttle-debounce.ts
3194
- var DEBUG = false;
3195
- var log6 = DEBUG ? Logger("zeed:throttle") : () => {
3187
+ var log6 = () => {
3196
3188
  };
3197
3189
  function throttle(callback, opt = {}) {
3198
3190
  const { delay = 100, trailing = true, leading = true } = opt;
@@ -3225,10 +3217,8 @@ function throttle(callback, opt = {}) {
3225
3217
  __name(exec, "exec");
3226
3218
  trailingExec = exec;
3227
3219
  if (elapsed > delay || !timeoutID) {
3228
- DEBUG && log6("elapsed", debugElapsed());
3229
3220
  if (leading) {
3230
3221
  if (elapsed > delay) {
3231
- DEBUG && log6("\u{1F680} leading", debugElapsed());
3232
3222
  exec();
3233
3223
  } else {
3234
3224
  ++visited;
@@ -3239,16 +3229,13 @@ function throttle(callback, opt = {}) {
3239
3229
  clearExistingTimeout();
3240
3230
  checkpoint = now;
3241
3231
  timeoutID = setTimeout(() => {
3242
- DEBUG && log6("\u23F1 reached timeout", debugElapsed());
3243
3232
  timeoutID = 0;
3244
3233
  if (trailing && (!leading || visited > 0)) {
3245
- DEBUG && log6("\u{1F680} trailing", debugElapsed());
3246
3234
  trailingExec == null ? void 0 : trailingExec();
3247
3235
  }
3248
3236
  }, timeout2);
3249
3237
  } else {
3250
3238
  ++visited;
3251
- DEBUG && log6("visited", debugElapsed());
3252
3239
  }
3253
3240
  }
3254
3241
  __name(wrapper, "wrapper");
@@ -3846,7 +3833,7 @@ function useExitHandler(handler) {
3846
3833
  __name(useExitHandler, "useExitHandler");
3847
3834
 
3848
3835
  // src/common/storage/memstorage.ts
3849
- var log8 = Logger("zeed:memstorage");
3836
+ Logger("zeed:memstorage");
3850
3837
  var MemStorage = class {
3851
3838
  constructor(opt = {}) {
3852
3839
  this.store = {};
@@ -4490,280 +4477,4 @@ function LoggerNodeHandler(opt = {}) {
4490
4477
  };
4491
4478
  }
4492
4479
  __name(LoggerNodeHandler, "LoggerNodeHandler");
4493
- // Annotate the CommonJS export names for ESM import in node:
4494
- 0 && (module.exports = {
4495
- Channel,
4496
- CryptoEncoder,
4497
- Currency,
4498
- DAY_MS,
4499
- Day,
4500
- Emitter,
4501
- FileStorage,
4502
- JsonEncoder,
4503
- LocalChannel,
4504
- LogLevel,
4505
- LogLevelAlias,
4506
- Logger,
4507
- LoggerConsoleHandler,
4508
- LoggerContext,
4509
- LoggerFileHandler,
4510
- LoggerMemoryHandler,
4511
- LoggerNodeHandler,
4512
- MemStorage,
4513
- NoopEncoder,
4514
- PoolTaskIdConflictResolution,
4515
- PoolTaskState,
4516
- PubSub,
4517
- SerialQueue,
4518
- Uint8ArrayToHexDump,
4519
- Uint8ArrayToJson,
4520
- Uint8ArrayToString,
4521
- XRX,
4522
- _decodeUtf8Polyfill,
4523
- _encodeUtf8Polyfill,
4524
- arrayAvg,
4525
- arrayBatches,
4526
- arrayEmptyInPlace,
4527
- arrayFilterInPlace,
4528
- arrayFlatten,
4529
- arrayIntersection,
4530
- arrayIsEqual,
4531
- arrayMax,
4532
- arrayMin,
4533
- arrayMinus,
4534
- arrayRandomElement,
4535
- arrayRemoveElement,
4536
- arraySetElement,
4537
- arrayShuffle,
4538
- arrayShuffleForce,
4539
- arrayShuffleInPlace,
4540
- arraySorted,
4541
- arraySortedNumbers,
4542
- arraySum,
4543
- arraySymmetricDifference,
4544
- arrayToggleInPlace,
4545
- arrayUnion,
4546
- arrayUnique,
4547
- avg,
4548
- between,
4549
- cloneJsonObject,
4550
- cloneObject,
4551
- cmp,
4552
- colorString,
4553
- colorStringList,
4554
- composeOrderby,
4555
- createArray,
4556
- createLocalChannelPair,
4557
- createPromise,
4558
- createPromiseProxy,
4559
- csv,
4560
- currency,
4561
- dateStringToDays,
4562
- day,
4563
- dayDay,
4564
- dayDiff,
4565
- dayFromAny,
4566
- dayFromDate,
4567
- dayFromDateGMT,
4568
- dayFromParts,
4569
- dayFromString,
4570
- dayFromTimestamp,
4571
- dayFromToday,
4572
- dayMonth,
4573
- dayMonthStart,
4574
- dayOffset,
4575
- dayToDate,
4576
- dayToDateGMT,
4577
- dayToParts,
4578
- dayToString,
4579
- dayToTimestamp,
4580
- dayYear,
4581
- dayYearStart,
4582
- debounce,
4583
- decimal,
4584
- decimalCentsPart,
4585
- decimalFromCents,
4586
- decimalToCents,
4587
- decodeBase16,
4588
- decodeBase32,
4589
- decodeBase58,
4590
- decodeBase62,
4591
- decodeBase64,
4592
- decrypt,
4593
- deepEqual,
4594
- deepMerge,
4595
- deriveKeyPbkdf2,
4596
- detect,
4597
- digest,
4598
- empty,
4599
- encodeBase16,
4600
- encodeBase32,
4601
- encodeBase58,
4602
- encodeBase62,
4603
- encodeBase64,
4604
- encodeQuery,
4605
- encrypt,
4606
- endSortWeight,
4607
- ensureFolder,
4608
- ensureKey,
4609
- ensureKeyAsync,
4610
- equalBinary,
4611
- escapeHTML,
4612
- escapeRegExp,
4613
- exists,
4614
- fetchBasic,
4615
- fetchJson,
4616
- fetchOptionsBasicAuth,
4617
- fetchOptionsFormURLEncoded,
4618
- fetchOptionsJson,
4619
- fetchText,
4620
- fixBrokenUth8String,
4621
- forEachDay,
4622
- forTimes,
4623
- formatMessages,
4624
- formatMilliseconds,
4625
- fromBase64,
4626
- fromCamelCase,
4627
- getGlobal,
4628
- getGlobalContext,
4629
- getGlobalEmitter,
4630
- getNamespaceFilterString,
4631
- getNavigator,
4632
- getSecureRandom,
4633
- getSecureRandomIfPossible,
4634
- getSourceLocation,
4635
- getSourceLocationByPrecedingPattern,
4636
- getStack,
4637
- getStackLlocationList,
4638
- getTimestamp,
4639
- getWindow,
4640
- immediate,
4641
- isArray,
4642
- isBoolean,
4643
- isBrowser,
4644
- isEven,
4645
- isHalf,
4646
- isInteger,
4647
- isLocalHost,
4648
- isNullOrUndefined,
4649
- isNumber,
4650
- isObject,
4651
- isPrime,
4652
- isPrimeRX,
4653
- isPrimitive,
4654
- isPromise,
4655
- isRecord,
4656
- isSafeInteger,
4657
- isString,
4658
- isTimeout,
4659
- isUint8Array,
4660
- joinToUint8Array,
4661
- jsonStringify,
4662
- jsonToUint8Array,
4663
- last,
4664
- lazyListener,
4665
- linkifyPlainText,
4666
- loggerStackTraceDebug,
4667
- memoize,
4668
- messages,
4669
- moveSortWeight,
4670
- parseArgs,
4671
- parseBasicAuth,
4672
- parseDate,
4673
- parseLogLevel,
4674
- parseOrderby,
4675
- parseQuery,
4676
- pbcopy,
4677
- platform,
4678
- promisify,
4679
- qid,
4680
- randomBoolean,
4681
- randomFloat,
4682
- randomInt,
4683
- randomUint8Array,
4684
- readText,
4685
- regExpEscape,
4686
- regExpString,
4687
- removeFolder,
4688
- renderMessages,
4689
- roundDown,
4690
- roundHalfAwayFromZero,
4691
- roundHalfDown,
4692
- roundHalfEven,
4693
- roundHalfOdd,
4694
- roundHalfTowardsZero,
4695
- roundHalfUp,
4696
- roundUp,
4697
- setupEnv,
4698
- size,
4699
- sleep,
4700
- sortedItems,
4701
- sortedOrderby,
4702
- startSortWeight,
4703
- stringToBoolean,
4704
- stringToFloat,
4705
- stringToInteger,
4706
- stringToPath,
4707
- stringToUInt8Array,
4708
- suid,
4709
- suidBytes,
4710
- suidBytesDate,
4711
- suidDate,
4712
- sum,
4713
- throttle,
4714
- timeout,
4715
- timeoutReached,
4716
- timoutError,
4717
- toBase64,
4718
- toBase64Url,
4719
- toBool,
4720
- toCamelCase,
4721
- toCapitalize,
4722
- toCapitalizeWords,
4723
- toFloat,
4724
- toHex,
4725
- toHumanReadableFilePath,
4726
- toHumanReadableUrl,
4727
- toInt,
4728
- toPath,
4729
- toString,
4730
- toUint8Array,
4731
- toValidFilename,
4732
- today,
4733
- tryTimeout,
4734
- uname,
4735
- unescapeHTML,
4736
- useAsyncMutex,
4737
- useBase,
4738
- useDefer,
4739
- useDispose,
4740
- useDisposer,
4741
- useEventListener,
4742
- useExitHandler,
4743
- useInterval,
4744
- useLevelFilter,
4745
- useMessageHub,
4746
- useMutex,
4747
- useNamespaceFilter,
4748
- usePool,
4749
- usePubSub,
4750
- useRPC,
4751
- useTimeout,
4752
- uuid,
4753
- uuid32Decode,
4754
- uuid32Encode,
4755
- uuid32bit,
4756
- uuidB32,
4757
- uuidBytes,
4758
- uuidDecode,
4759
- uuidEncode,
4760
- uuidv4,
4761
- valueToBoolean,
4762
- valueToFloat,
4763
- valueToInteger,
4764
- valueToPath,
4765
- valueToString,
4766
- waitOn,
4767
- writeText
4768
- });
4769
4480
  //# sourceMappingURL=index.node.cjs.map