zeed 0.7.109 → 0.7.116

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.
@@ -2,15 +2,28 @@ import {
2
2
  cloneObject,
3
3
  renderMessages,
4
4
  toValidFilename
5
- } from "./chunk-VSLXMERB.js";
5
+ } from "./chunk-YPQCEOVC.js";
6
6
  import {
7
7
  Logger,
8
8
  __name,
9
+ __require,
9
10
  formatMilliseconds,
10
11
  getTimestamp,
11
12
  useLevelFilter,
12
13
  useNamespaceFilter
13
- } from "./chunk-DUGVRMRT.js";
14
+ } from "./chunk-G3LBBVZT.js";
15
+
16
+ // src/node/clipboard.ts
17
+ function pbcopy(data) {
18
+ return new Promise(function(resolve5, reject) {
19
+ const proc = __require("child_process").spawn("pbcopy");
20
+ proc.on("error", (err) => reject(err));
21
+ proc.on("close", (err) => resolve5(data));
22
+ proc.stdin.write(data);
23
+ proc.stdin.end();
24
+ });
25
+ }
26
+ __name(pbcopy, "pbcopy");
14
27
 
15
28
  // src/node/env.ts
16
29
  import fs from "fs";
@@ -514,6 +527,7 @@ __name(setupLogContextNode, "setupLogContextNode");
514
527
  setupLogContextNode();
515
528
 
516
529
  export {
530
+ pbcopy,
517
531
  stringToPath,
518
532
  valueToPath,
519
533
  toPath,
@@ -530,4 +544,4 @@ export {
530
544
  loggerStackTraceDebug,
531
545
  LoggerNodeHandler
532
546
  };
533
- //# sourceMappingURL=chunk-ZEQNU2UB.js.map
547
+ //# sourceMappingURL=chunk-4I4NSJEE.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/node/clipboard.ts","../src/node/env.ts","../src/node/filestorage.ts","../src/node/log-file.ts","../src/node/log-util.ts","../src/node/log-node.ts","../src/node/crypto.ts","../src/node/log-context-node.ts"],"sourcesContent":["/** Copy string to clipboard */\nexport function pbcopy(data: string) {\n return new Promise(function (resolve, reject) {\n const proc = require(\"child_process\").spawn(\"pbcopy\")\n proc.on(\"error\", (err: any) => reject(err))\n proc.on(\"close\", (err: any) => resolve(data))\n proc.stdin.write(data)\n proc.stdin.end()\n })\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\n// Adopted from https://github.com/motdotla/dotenv BSD-2\n\nimport { LogLevel } from \"../common/log-base\"\nimport { Logger } from \"../common/log\"\n\nimport fs from \"fs\"\nimport { resolve } from \"path\"\n\nconst log = Logger(\"zeed:env\")\n\nconst NEWLINE = \"\\n\"\nconst RE_INI_KEY_VAL = /^\\s*([\\w_.-]+)\\s*=\\s*(.*)?\\s*$/\nconst RE_NEWLINES = /\\\\n/g\nconst NEWLINES_MATCH = /\\n|\\r|\\r\\n/\n\ntype csvOptions = {\n /** @deprecated will probably be replaced by logLevel */\n debug?: boolean\n path?: string\n filename?: string\n encoding?: BufferEncoding\n prefix?: string\n env?: Record<string, string>\n}\n\n// Parses src into an Object\nfunction parse(src: string, options: csvOptions = {}) {\n let obj: Record<string, string> = {}\n\n // convert Buffers before splitting into lines and processing\n src\n .toString()\n .split(NEWLINES_MATCH)\n .forEach(function (line, idx) {\n // matching \"KEY' and 'VAL' in 'KEY=VAL'\n const keyValueArr = line.match(RE_INI_KEY_VAL)\n // matched?\n\n // log.debug(\"keyValueArr\", keyValueArr)\n\n if (keyValueArr != null) {\n const key = keyValueArr[1]\n // default undefined or missing values to empty string\n let val = keyValueArr[2] || \"\"\n const end = val.length - 1\n const isDoubleQuoted = val[0] === '\"' && val[end] === '\"'\n const isSingleQuoted = val[0] === \"'\" && val[end] === \"'\"\n\n // if single or double quoted, remove quotes\n if (isSingleQuoted || isDoubleQuoted) {\n val = val.substring(1, end)\n\n // if double quoted, expand newlines\n if (isDoubleQuoted) {\n val = val.replace(RE_NEWLINES, NEWLINE)\n }\n } else {\n // remove surrounding whitespace\n val = val.trim()\n }\n obj[key] = val\n } else {\n log.debug(\n `did not match key and value when parsing line ${idx + 1}: ${line}`\n )\n }\n })\n\n // log.debug(\"obj\", obj)\n return obj\n}\n\n/**\n * Return a path relative to the current working directory\n */\nexport function stringToPath(\n value?: string,\n defaultValue: string = \".\"\n): string {\n return resolve(process.cwd(), value ?? defaultValue)\n}\n\nexport function valueToPath(value?: any, defaultValue = \"\"): string {\n if (value == null) value = defaultValue\n return stringToPath(String(value).trim(), defaultValue)\n}\n\nexport const toPath = valueToPath\n\n// Populates process.env from .env file\nexport function setupEnv(options: csvOptions = {}) {\n const dotenvPath: string =\n options?.path ?? toPath(options?.filename ?? \".env\")\n const encoding: BufferEncoding = options?.encoding ?? \"utf8\"\n const debug = options?.debug || false\n\n if (debug !== true) log.level = LogLevel.off\n\n try {\n // specifying an encoding returns a string instead of a buffer\n const parsedEnv = fs.existsSync(dotenvPath)\n ? parse(fs.readFileSync(dotenvPath, { encoding }), { debug })\n : {}\n const parsedEnvLocal = fs.existsSync(dotenvPath + \".local\")\n ? parse(fs.readFileSync(dotenvPath + \".local\", { encoding }), { debug })\n : {}\n\n const parsed: Record<string, string> = Object.assign(\n {},\n parsedEnv,\n parsedEnvLocal\n )\n let env = options?.env ?? process.env\n\n Object.entries(parsed).forEach(([key, value]) => {\n if (typeof options?.prefix === \"string\") {\n key = options?.prefix + key\n }\n if (!Object.prototype.hasOwnProperty.call(env, key)) {\n if (value != null) {\n log.info(`set env.${key} = ${value}`)\n env[key] = value\n }\n } else {\n log.debug(`\"${key}\" is already defined and will not be overwritten`)\n }\n })\n return { parsed }\n } catch (e) {\n log.error(e)\n return { error: e }\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport {\n mkdirSync,\n readdirSync,\n readFileSync,\n rmSync,\n unlinkSync,\n writeFileSync,\n} from \"fs\"\nimport { dirname, resolve } from \"path\"\nimport { toValidFilename } from \"../common/data/path\"\nimport { cloneObject } from \"../common/data/utils\"\nimport { Logger } from \"../common/log\"\nimport { Json, ObjectStorage } from \"../common/types\"\n\nconst log = Logger(\"zeed:filestorage\")\n\nexport interface FileStorageOptions {\n pretty?: boolean\n path?: string\n extension?: string\n objectFromString?: (data: string) => any\n objectToString?: (data: any) => string\n keyToFilename?: (key: string) => string\n}\n\nexport class FileStorage<T = Json> implements ObjectStorage<T> {\n private store: Record<string, T | null> = {}\n private dirname: string\n private fileKeys?: string[] = undefined\n private pretty: boolean = false\n private extension: string\n private extensionLength: number\n private objectFromString: (data: string) => any\n private objectToString: (data: any) => string\n private keyToFilename: (key: string) => string\n\n constructor(opt: FileStorageOptions = {}) {\n this.dirname = resolve(process.cwd(), opt.path || \".fileStorage\")\n this.pretty = !!opt.pretty\n this.extension = opt.extension ?? \".json\"\n\n if (opt.extension && !this.extension.startsWith(\".\")) {\n this.extension = \".\" + this.extension\n }\n this.extensionLength = this.extension.length\n\n this.objectToString =\n opt.objectToString ??\n ((data: any): string => {\n return this.pretty\n ? JSON.stringify(data, null, 2)\n : JSON.stringify(data)\n })\n\n this.objectFromString =\n opt.objectFromString ??\n ((data: string) => {\n try {\n return JSON.parse(data)\n } catch (err) {\n log.warn(`fileStorage parse error '${err}' in`, data)\n }\n })\n\n this.keyToFilename = opt.keyToFilename ?? toValidFilename\n }\n\n setItem(key: string, value: T): void {\n this.store[key] = cloneObject(value)\n try {\n const data = this.objectToString(value)\n const path = this.getPath(key)\n mkdirSync(dirname(path), { recursive: true })\n writeFileSync(path, data, \"utf8\")\n } catch (err) {\n log.error(\"setItem error\", err)\n }\n }\n\n getPath(key: string): string {\n return resolve(this.dirname, this.keyToFilename(key) + this.extension)\n }\n\n getBuffer(key: string): Buffer {\n const path = this.getPath(key)\n return Buffer.from(readFileSync(path))\n }\n\n getItem(key: string): T | undefined {\n let value = this.store[key]\n\n // null is an indicator for not existing!\n if (value === null) return\n\n if (value != null) {\n return cloneObject(value) // this.objectFromString(value)\n }\n\n try {\n const path = this.getPath(key)\n const data = readFileSync(path, \"utf8\")\n if (data != null) {\n const value = this.objectFromString(data)\n this.store[key] = value\n return value\n }\n } catch (err) {\n log.warn(\"getItem error\", err)\n this.store[key] = null // do not retry next time\n }\n }\n\n removeItem(key: string): void {\n delete this.store[key]\n if (this.fileKeys != null) {\n const index: number = this.fileKeys.indexOf(key)\n if (index !== -1) {\n this.fileKeys.splice(index, 1)\n }\n }\n try {\n const path = this.getPath(key)\n unlinkSync(path)\n } catch (err) {}\n }\n\n clear(): void {\n this.fileKeys = []\n this.store = {}\n rmSync(this.dirname, { recursive: true, force: true })\n }\n\n allKeys(): string[] {\n if (this.fileKeys == null) {\n try {\n this.fileKeys =\n readdirSync(this.dirname, { withFileTypes: true })\n .filter(\n (item) =>\n !item.isDirectory() && item.name.endsWith(this.extension)\n )\n .map((item) => item.name.slice(0, -this.extensionLength)) || []\n } catch (err) {}\n }\n let keys = [...(this.fileKeys || [])]\n for (let key of Object.keys(this.store)) {\n if (!keys.includes(key)) {\n keys.push(key)\n }\n }\n keys.sort()\n return keys\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { createWriteStream, mkdirSync } from \"fs\"\nimport { dirname, resolve } from \"path\"\nimport { renderMessages } from \"../common/data/convert\"\nimport { LogHandlerOptions, LogLevel, LogMessage } from \"../common/log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"../common/log-filter\"\n\nlet namespaces: Record<string, any> = {}\n\nexport function LoggerFileHandler(path: string, opt: LogHandlerOptions = {}) {\n const { level = LogLevel.all, filter = \"*\" } = opt\n path = resolve(process.cwd(), path)\n mkdirSync(dirname(path), { recursive: true })\n var stream = createWriteStream(path, { flags: \"a\" })\n // stream.end()\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 time = new Date().toISOString()\n let name = msg.name || \"\"\n let ninfo = namespaces[name || \"\"]\n if (ninfo == null) {\n namespaces[name] = ninfo\n }\n\n let args: string[] = [\n `[${name || \"*\"}]`,\n renderMessages(msg.messages, { pretty: false }),\n ]\n\n function write(...args: string[]): void {\n stream.write(args.join(\"\\t\") + \"\\n\")\n }\n\n switch (msg.level) {\n case LogLevel.info:\n write(time, `I|* `, ...args)\n break\n case LogLevel.warn:\n write(time, `W|** `, ...args)\n break\n case LogLevel.error:\n write(time, `E|***`, ...args)\n break\n default:\n write(time, `D| `, ...args)\n break\n }\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { resolve } from \"path\"\n\nexport function getStackLlocationList(stack: string): any[] {\n if (typeof stack !== \"string\") return []\n // console.log(\"stack\", stack)\n return (\n stack\n ?.split(\"\\n\")\n ?.map((rawLine) => {\n let m = rawLine.match(/^\\s+at.*(\\((.*)\\)|file:\\/\\/(.*)$)/)\n if (m) {\n let line = m[3] || m[2]\n if (line.endsWith(\")\")) line = line.slice(0, -1)\n return line\n }\n })\n ?.filter((v) => v != null) || []\n )\n}\n\nconst cwd = resolve(process.cwd())\nconst home = process.env?.HOME ? resolve(process.env?.HOME) : \"\"\n// console.log(`cwd = ${cwd}, home = ${home}}`)\n\nfunction pathStripCwd(path: string) {\n // console.log(\">\", path)\n\n if (path.includes(\"/node_modules/\")) {\n return \"\"\n }\n\n const fileURL = \"file://\"\n if (path.startsWith(fileURL)) {\n return path.substr(fileURL.length)\n }\n\n if (cwd && path.startsWith(cwd)) {\n return path.substr(cwd.length + 1)\n }\n\n if (home && path.startsWith(home)) {\n path = \"~/\" + path.substr(home.length + 1)\n }\n\n return path\n}\n\nfunction extractFileInfo(stackLine: string): string {\n let m = stackLine.match(/^\\s*at.*(\\((.*)\\)|file:\\/\\/(.*)$)/)\n if (m) {\n let line = m[3] || m[2]\n if (line.endsWith(\")\")) line = line.slice(0, -1)\n return line\n }\n return \"\"\n}\n\n/**\n * Get the source code location of the caller\n * https://stackoverflow.com/a/47296370/140927\n *\n * @param level Number of levels to go down the stack trace\n * @param stripCwd Strip the current working directory, only reasonable for Node.js environment\n * @returns\n */\nexport function getSourceLocation(level = 2, stripCwd = true): string {\n let stack = new Error().stack || \"\"\n let line: string | undefined = getStackLlocationList(stack)?.[level]\n if (line && stripCwd) {\n line = pathStripCwd(line)\n }\n return line || \"\"\n}\n\nexport function getStack(): string {\n return new Error().stack || \"\"\n}\n\nexport function getSourceLocationByPrecedingPattern(\n patterns: string[],\n stripCwd = true\n) {\n let line = \"\"\n let stack = new Error().stack || \"\"\n if (typeof stack === \"string\") {\n const lines = stack.split(\"\\n\").map((l) => l.trim())\n // console.log(lines)\n const index = lines.findIndex((l) => patterns.some((p) => l.startsWith(p)))\n line = lines[index + 1]\n if (line) {\n line = extractFileInfo(line)\n }\n if (line && stripCwd) {\n line = pathStripCwd(line)\n }\n }\n return line\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport tty from \"tty\"\nimport { renderMessages } from \"../common/data/convert\"\nimport {\n LogHandler,\n LogHandlerOptions,\n LogLevel,\n LogMessage,\n} from \"../common/log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"../common/log-filter\"\nimport {\n getSourceLocation,\n getSourceLocationByPrecedingPattern,\n getStack,\n} from \"./log-util\"\nimport { formatMilliseconds, getTimestamp } from \"../common/time\"\n\nexport function isTTY(): boolean {\n try {\n return tty.isatty(process.stdout.fd)\n } catch (err) {}\n return false\n}\n\nconst colors = [6, 2, 3, 4, 5, 1]\n\nfunction 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\nlet namespaces: Record<string, any> = {}\n\nlet time = getTimestamp()\n\nconst useColors = tty.isatty(process.stderr.fd)\n\nfunction log(...args: any[]) {\n return process.stderr.write(renderMessages(args) + \"\\n\")\n}\n\n// export const BOLD = Symbol()\n// export const UNBOLD = Symbol()\n// export const BLUE = Symbol()\n// export const GREY = Symbol()\n// export const GREEN = Symbol()\n// export const RED = Symbol()\n// export const PURPLE = Symbol()\n// export const ORANGE = Symbol()\n// export const UNCOLOR = Symbol()\n\n// const _browserStyleMap = {\n// [BOLD]: pair.create(\"font-weight\", \"bold\"),\n// [UNBOLD]: pair.create(\"font-weight\", \"normal\"),\n// [BLUE]: pair.create(\"color\", \"blue\"),\n// [GREEN]: pair.create(\"color\", \"green\"),\n// [GREY]: pair.create(\"color\", \"grey\"),\n// [RED]: pair.create(\"color\", \"red\"),\n// [PURPLE]: pair.create(\"color\", \"purple\"),\n// [ORANGE]: pair.create(\"color\", \"orange\"), // not well supported in chrome when debugging node with inspector - TODO: deprecate\n// [UNCOLOR]: pair.create(\"color\", \"black\"),\n// }\n\nconst TTY_STYLE = {\n BOLD: \"\\u001b[1m\",\n UNBOLD: \"\\u001b[2m\",\n RED: \"\\u001b[31m\",\n GREEN: \"\\u001b[32m\",\n BLUE: \"\\u001b[34m\",\n PURPLE: \"\\u001b[35m\",\n GRAY: \"\\u001b[37m\",\n ORANGE: \"\\u001b[38;5;208m\",\n UNCOLOR: \"\\u001b[0m\",\n}\n\nenum COLOR {\n RED = 1,\n GREEN = 2,\n BLUE = 4,\n PURPLE = 5,\n GRAY = 7,\n ORANGE = 8,\n}\n\nconst colorEnd = \"\\u001B[0m\"\n\nexport function colorString(value: string, colorCode: number) {\n const colorStart =\n colorCode === COLOR.ORANGE\n ? TTY_STYLE.ORANGE\n : \"\\u001B[3\" + (colorCode < 8 ? colorCode : \"8;5;\" + colorCode) + \"m\"\n return `${colorStart}${value}${colorEnd}`\n}\n\nexport function colorStringList(\n list: Array<any>,\n style: string,\n bold: boolean = true\n) {\n return list.map((value) => {\n if (typeof value !== \"string\") return value\n let start = style\n let end = colorEnd\n if (bold) {\n start = `${TTY_STYLE.BOLD}${start}`\n end = `${end}${TTY_STYLE.BOLD}`\n }\n return `${start}${value}${end}`\n })\n}\n\nexport const loggerStackTraceDebug =\n \"loggerStackTraceDebug-7d38e5a9214b58d29734374cdb9521fd964d7485\"\n\nexport function LoggerNodeHandler(opt: LogHandlerOptions = {}): LogHandler {\n const {\n level = undefined,\n filter = undefined,\n colors = isTTY(),\n levelHelper = true,\n nameBrackets = true,\n padding = 0,\n fill = 0,\n stack = true,\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 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\n let args: string[]\n\n let displayName = nameBrackets ? `[${name}]` : name\n\n if (padding > 0) {\n displayName = displayName.padStart(padding, \" \")\n }\n\n if (fill > 0) {\n displayName = displayName.padEnd(fill, \" \")\n }\n\n if (colors && useColors) {\n const c = ninfo.color\n args = [colorString(displayName, c) + ` | `] // nameBrackets ? [`%c[${name}]`] : [`%c${name}`]\n if (msg.level === LogLevel.warn) {\n args.push(...colorStringList(msg.messages, TTY_STYLE.ORANGE))\n } else if (msg.level === LogLevel.error) {\n args.push(...colorStringList(msg.messages, TTY_STYLE.RED))\n } else {\n args.push(...msg.messages)\n }\n args.push(colorString(`+${diff}`, c))\n } else {\n args = [displayName, ...msg.messages]\n args.push(`+${diff}`)\n }\n\n if (msg.messages?.[0] === loggerStackTraceDebug) {\n console.log(getStack())\n }\n\n if (stack) {\n let line: string = \"\"\n if (typeof stack === \"boolean\") {\n line = getSourceLocationByPrecedingPattern(\n [\"at Function.\", \"at null.log (\", \"at log (\"],\n true\n )\n if (!line) {\n line = getSourceLocation(0, true)\n }\n } else {\n const depth = typeof stack === \"number\" ? stack : 3\n line = getSourceLocation(depth, true)\n }\n if (line) {\n args.push(colorString(`(${line})`, COLOR.GRAY))\n }\n }\n switch (msg.level) {\n case LogLevel.info:\n if (levelHelper) args[0] = `I|* ` + args[0]\n log(...args)\n break\n case LogLevel.warn:\n if (levelHelper)\n args[0] =\n (colors && useColors\n ? colorString(`W|** `, COLOR.ORANGE)\n : `W|** `) + args[0]\n log(...args)\n break\n case LogLevel.error:\n if (levelHelper)\n args[0] =\n (colors && useColors\n ? colorString(`E|*** `, COLOR.RED)\n : `E|*** `) + args[0]\n log(...args)\n break\n default:\n if (levelHelper) args[0] = `D| ` + args[0]\n log(...args)\n break\n }\n }\n}\n","// https://nodejs.org/api/webcrypto.html\nimport nodeCrypto from \"crypto\"\n\nexport {}\n\ndeclare module NodeJS {\n interface Global {\n crypto: Crypto\n }\n}\n\ntry {\n if (\n nodeCrypto &&\n nodeCrypto.webcrypto &&\n typeof globalThis !== \"undefined\" &&\n typeof globalThis.crypto === \"undefined\"\n ) {\n // @ts-ignore\n globalThis.crypto = nodeCrypto.webcrypto\n }\n} catch (err) {\n console.warn(\"Failed to polyfill webcrypto\", err)\n}\n","import { Logger } from \"../common/log\"\nimport { toPath } from \"./env\"\nimport { LoggerFileHandler } from \"./log-file\"\nimport { LoggerNodeHandler } from \"./log-node\"\n\nfunction setupLogContextNode() {\n let handlers = [\n LoggerNodeHandler({\n padding: 32,\n nameBrackets: false,\n // levelHelper: false,\n }),\n ]\n\n let logFilePath = process.env.ZEED_LOG ?? process.env.LOG\n if (logFilePath) {\n handlers.unshift(LoggerFileHandler(toPath(logFilePath)))\n }\n\n Logger.setHandlers(handlers)\n}\n\nsetupLogContextNode()\n"],"mappings":"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","names":[]}
@@ -18,6 +18,13 @@ var __spreadValues = (a, b) => {
18
18
  };
19
19
  var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
20
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
21
+ var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
22
+ get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
23
+ }) : x)(function(x) {
24
+ if (typeof require !== "undefined")
25
+ return require.apply(this, arguments);
26
+ throw new Error('Dynamic require of "' + x + '" is not supported');
27
+ });
21
28
 
22
29
  // src/common/data/is.ts
23
30
  function isObject(obj) {
@@ -482,6 +489,7 @@ export {
482
489
  __spreadValues,
483
490
  __spreadProps,
484
491
  __name,
492
+ __require,
485
493
  isObject,
486
494
  isPrimitive,
487
495
  isArray,
@@ -507,4 +515,4 @@ export {
507
515
  formatMilliseconds,
508
516
  parseDate
509
517
  };
510
- //# sourceMappingURL=chunk-DUGVRMRT.js.map
518
+ //# sourceMappingURL=chunk-G3LBBVZT.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 label: string\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.label = name\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 // 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(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 label: string\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.label = name\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 // 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(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":[]}
@@ -5,7 +5,7 @@ import {
5
5
  getTimestamp,
6
6
  useLevelFilter,
7
7
  useNamespaceFilter
8
- } from "./chunk-DUGVRMRT.js";
8
+ } from "./chunk-G3LBBVZT.js";
9
9
 
10
10
  // src/browser/log-colors.ts
11
11
  var colors = [
@@ -245,4 +245,4 @@ export {
245
245
  LoggerBrowserSetupDebugFactory,
246
246
  activateConsoleDebug
247
247
  };
248
- //# sourceMappingURL=chunk-MYUIYPZU.js.map
248
+ //# sourceMappingURL=chunk-QCK7R55W.js.map
@@ -3,10 +3,10 @@ import {
3
3
  LoggerBrowserSetupDebugFactory,
4
4
  selectColor,
5
5
  supportsColors
6
- } from "./chunk-MYUIYPZU.js";
6
+ } from "./chunk-QCK7R55W.js";
7
7
  import {
8
8
  isBrowser
9
- } from "./chunk-VSLXMERB.js";
9
+ } from "./chunk-YPQCEOVC.js";
10
10
  import {
11
11
  Logger,
12
12
  __name,
@@ -14,7 +14,7 @@ import {
14
14
  getTimestamp,
15
15
  useLevelFilter,
16
16
  useNamespaceFilter
17
- } from "./chunk-DUGVRMRT.js";
17
+ } from "./chunk-G3LBBVZT.js";
18
18
 
19
19
  // src/browser/base64.ts
20
20
  var { error } = Logger("zeed:base64");
@@ -330,4 +330,4 @@ export {
330
330
  LocalStorage,
331
331
  LoggerBrowserClassicHandler
332
332
  };
333
- //# sourceMappingURL=chunk-3METCLAK.js.map
333
+ //# sourceMappingURL=chunk-RPGPD5QC.js.map
@@ -5,7 +5,7 @@ import {
5
5
  __spreadValues,
6
6
  getGlobalContext,
7
7
  getTimestamp
8
- } from "./chunk-DUGVRMRT.js";
8
+ } from "./chunk-G3LBBVZT.js";
9
9
 
10
10
  // src/common/data/bin.ts
11
11
  var log = Logger("bin");
@@ -272,6 +272,14 @@ function between(min, value, max) {
272
272
  return Math.max(min, Math.min(max, value));
273
273
  }
274
274
  __name(between, "between");
275
+ function sum(array) {
276
+ return array.reduce((acc, value) => acc + value, 0);
277
+ }
278
+ __name(sum, "sum");
279
+ function avg(array) {
280
+ return sum(array) / array.length;
281
+ }
282
+ __name(avg, "avg");
275
283
 
276
284
  // src/common/data/orderby.ts
277
285
  function parseOrderby(value = "") {
@@ -417,6 +425,15 @@ function arrayMin(...array) {
417
425
  return arrayFlatten(array).reduce((acc, value) => acc != null ? value < acc ? value : acc : value, void 0);
418
426
  }
419
427
  __name(arrayMin, "arrayMin");
428
+ function arraySum(...array) {
429
+ return arrayFlatten(array).reduce((acc, value) => acc + value, 0);
430
+ }
431
+ __name(arraySum, "arraySum");
432
+ function arrayAvg(...array) {
433
+ let flatArray = arrayFlatten(array);
434
+ return flatArray.reduce((acc, value) => acc + value, 0) / flatArray.length;
435
+ }
436
+ __name(arrayAvg, "arrayAvg");
420
437
  function createArray(size2 = 0, item) {
421
438
  if (size2 <= 0)
422
439
  return [];
@@ -808,6 +825,7 @@ var Currency = _Currency;
808
825
  __name(Currency, "Currency");
809
826
  Currency.zero = new _Currency(0);
810
827
  Currency.one = new _Currency(1);
828
+ Currency.hundred = new _Currency(100);
811
829
  function parse(value, opts, useRounding = true) {
812
830
  let v = 0, { decimal, errorOnInvalid, precision: decimals, fromCents } = opts, precision = pow(decimals), isNumber = typeof value === "number";
813
831
  if (value instanceof Currency && fromCents) {
@@ -1046,7 +1064,6 @@ var Day = class {
1046
1064
  if (mm === 0)
1047
1065
  mm = 12;
1048
1066
  let yy = Math.floor((m - 1) / 12);
1049
- console.log("calc", m, mm, yy, [this.year + yy, mm, this.day]);
1050
1067
  return Day.from([this.year + yy, mm, this.day]);
1051
1068
  }
1052
1069
  daysUntil(otherDay) {
@@ -1282,6 +1299,128 @@ function cloneJsonObject(obj) {
1282
1299
  return JSON.parse(JSON.stringify(obj));
1283
1300
  }
1284
1301
  __name(cloneJsonObject, "cloneJsonObject");
1302
+ function memoize(fn) {
1303
+ let cache = /* @__PURE__ */ new Map();
1304
+ return (n) => {
1305
+ if (cache.has(n)) {
1306
+ return cache.get(n);
1307
+ }
1308
+ let result = fn(n);
1309
+ cache.set(n, result);
1310
+ return result;
1311
+ };
1312
+ }
1313
+ __name(memoize, "memoize");
1314
+
1315
+ // src/common/data/xrx.ts
1316
+ var RX_WHITESPACE = /\\\s|\s+|#[^\n]*\n?/gm;
1317
+ var RX_REAL_GROUPS = /\(\?P?<(\w[\w\d_]+)>|\((?!\?(:|\!|=|<=|<\!))/gm;
1318
+ var RX_LOOK_BEHIND = /^((?:\(\?[\w$]+\))?)\(\?<([=!])([\s\S]*?)\)/gm;
1319
+ function regExpString(rx) {
1320
+ return typeof rx === "string" ? rx : rx.source || "";
1321
+ }
1322
+ __name(regExpString, "regExpString");
1323
+ function regExpEscape(str) {
1324
+ return str.replace(/[-\[\]{}()*+?.,\\^$|#\s]/g, "\\$&");
1325
+ }
1326
+ __name(regExpEscape, "regExpEscape");
1327
+ var XRX = class {
1328
+ constructor(pattern2, flags) {
1329
+ this.namedGroups = {};
1330
+ this.names = [];
1331
+ let _flags = flags != null ? flags : "";
1332
+ let _rx;
1333
+ if (pattern2 instanceof RegExp) {
1334
+ if (flags == null) {
1335
+ _flags = pattern2.flags;
1336
+ }
1337
+ _rx = pattern2.source;
1338
+ } else {
1339
+ _rx = pattern2;
1340
+ }
1341
+ const extended = _flags && _flags.indexOf("x") !== -1;
1342
+ if (extended) {
1343
+ _flags = _flags.replace("x", "");
1344
+ _rx = _rx.replace(RX_WHITESPACE, (r) => {
1345
+ return r[0] === "\\" ? r : "";
1346
+ });
1347
+ }
1348
+ if (!(pattern2 instanceof RegExp)) {
1349
+ let index = 0;
1350
+ _rx = _rx.replace(RX_REAL_GROUPS, (str, name) => {
1351
+ index += 1;
1352
+ if (name) {
1353
+ if (name !== "index" && name !== "length" && !this.namedGroups[name]) {
1354
+ this.namedGroups[name] = index;
1355
+ } else {
1356
+ console.error(`Unallowed or duplicate group name: ${name}`);
1357
+ }
1358
+ return "(";
1359
+ }
1360
+ return str;
1361
+ });
1362
+ this.names = Object.keys(this.namedGroups);
1363
+ }
1364
+ _rx = regExpString(_rx);
1365
+ RX_LOOK_BEHIND.lastIndex = 0;
1366
+ let parts = RX_LOOK_BEHIND.exec(_rx);
1367
+ if (parts) {
1368
+ this.lookBehind = {
1369
+ rx: new RegExp(`${parts[3]}$(?!\\s)`),
1370
+ expect: parts ? parts[2] === "=" : !parts
1371
+ };
1372
+ _rx = _rx.substr(parts[0].length);
1373
+ }
1374
+ this.rx = new RegExp(_rx, _flags);
1375
+ }
1376
+ get lastIndex() {
1377
+ return this.rx.lastIndex;
1378
+ }
1379
+ set lastIndex(index) {
1380
+ this.rx.lastIndex = index;
1381
+ }
1382
+ _handleMatch(m) {
1383
+ if (this.lookBehind) {
1384
+ let leftContext = m.input.slice(0, m.index);
1385
+ if (this.lookBehind.expect !== this.lookBehind.rx.test(leftContext)) {
1386
+ return null;
1387
+ }
1388
+ }
1389
+ for (let name of this.names) {
1390
+ m[name] = m[this.namedGroups[name]];
1391
+ }
1392
+ return m;
1393
+ }
1394
+ exec(str) {
1395
+ let m;
1396
+ while (m = this.rx.exec(str)) {
1397
+ if (this.rx.lastIndex === m.index) {
1398
+ this.rx.lastIndex++;
1399
+ }
1400
+ m = this._handleMatch(m);
1401
+ if (m != null) {
1402
+ return m;
1403
+ }
1404
+ }
1405
+ }
1406
+ execAll(str) {
1407
+ let matches = [];
1408
+ let m;
1409
+ this.rx.lastIndex = 0;
1410
+ while (m = this.exec(str)) {
1411
+ matches.push(m);
1412
+ }
1413
+ this.rx.lastIndex = 0;
1414
+ return matches;
1415
+ }
1416
+ replace(str, replacement) {
1417
+ let fn = typeof replacement === "function" ? replacement : () => replacement;
1418
+ return str.replace(this.rx, (m) => {
1419
+ return fn(m);
1420
+ });
1421
+ }
1422
+ };
1423
+ __name(XRX, "XRX");
1285
1424
 
1286
1425
  // src/common/dispose-defer.ts
1287
1426
  var log3 = Logger("dispose");
@@ -1906,6 +2045,66 @@ function usePubSub(opt) {
1906
2045
  }
1907
2046
  __name(usePubSub, "usePubSub");
1908
2047
 
2048
+ // src/common/msg/rpc.ts
2049
+ var rpcCounter = 1;
2050
+ function useRPC(functions, options) {
2051
+ const {
2052
+ post,
2053
+ on,
2054
+ eventNames = [],
2055
+ serialize = /* @__PURE__ */ __name((i) => i, "serialize"),
2056
+ deserialize = /* @__PURE__ */ __name((i) => i, "deserialize")
2057
+ } = options;
2058
+ const rpcPromiseMap = /* @__PURE__ */ new Map();
2059
+ on(async (data) => {
2060
+ const msg = deserialize(data);
2061
+ const [mode, args, id, method] = msg;
2062
+ if (mode === 1 /* request */ || mode === 2 /* event */) {
2063
+ let result, error;
2064
+ try {
2065
+ result = await functions[method](...args);
2066
+ } catch (e) {
2067
+ error = String(e);
2068
+ }
2069
+ if (mode === 1 /* request */ && id) {
2070
+ if (error) {
2071
+ post(serialize([4 /* reject */, error, id]));
2072
+ } else {
2073
+ post(serialize([3 /* resolve */, result, id]));
2074
+ }
2075
+ }
2076
+ } else if (id) {
2077
+ const promise = rpcPromiseMap.get(id);
2078
+ if (mode === 4 /* reject */)
2079
+ promise == null ? void 0 : promise.reject(args);
2080
+ else
2081
+ promise == null ? void 0 : promise.resolve(args);
2082
+ rpcPromiseMap.delete(id);
2083
+ }
2084
+ });
2085
+ return new Proxy({}, {
2086
+ get(_, method) {
2087
+ const sendEvent = /* @__PURE__ */ __name((...args) => {
2088
+ post(serialize([2 /* event */, args, null, method]));
2089
+ }, "sendEvent");
2090
+ if (options.onlyEvents || eventNames.includes(method)) {
2091
+ sendEvent.asEvent = sendEvent;
2092
+ return sendEvent;
2093
+ }
2094
+ const sendCall = /* @__PURE__ */ __name((...args) => {
2095
+ return new Promise((resolve, reject) => {
2096
+ const id = rpcCounter++;
2097
+ rpcPromiseMap.set(id, { resolve, reject });
2098
+ post(serialize([1 /* request */, args, id, method]));
2099
+ });
2100
+ }, "sendCall");
2101
+ sendCall.asEvent = sendEvent;
2102
+ return sendCall;
2103
+ }
2104
+ });
2105
+ }
2106
+ __name(useRPC, "useRPC");
2107
+
1909
2108
  // src/common/mutex.ts
1910
2109
  function useMutex() {
1911
2110
  let token = true;
@@ -2391,6 +2590,8 @@ export {
2391
2590
  randomInt,
2392
2591
  randomFloat,
2393
2592
  between,
2593
+ sum,
2594
+ avg,
2394
2595
  parseOrderby,
2395
2596
  composeOrderby,
2396
2597
  cmp,
@@ -2415,6 +2616,8 @@ export {
2415
2616
  arrayRandomElement,
2416
2617
  arrayMax,
2417
2618
  arrayMin,
2619
+ arraySum,
2620
+ arrayAvg,
2418
2621
  createArray,
2419
2622
  useBase,
2420
2623
  encodeBase16,
@@ -2492,6 +2695,10 @@ export {
2492
2695
  empty,
2493
2696
  cloneObject,
2494
2697
  cloneJsonObject,
2698
+ memoize,
2699
+ regExpString,
2700
+ regExpEscape,
2701
+ XRX,
2495
2702
  useDispose,
2496
2703
  useDisposer,
2497
2704
  useDefer,
@@ -2526,6 +2733,7 @@ export {
2526
2733
  useMessageHub,
2527
2734
  PubSub,
2528
2735
  usePubSub,
2736
+ useRPC,
2529
2737
  useMutex,
2530
2738
  useAsyncMutex,
2531
2739
  fetchBasic,
@@ -2546,4 +2754,4 @@ export {
2546
2754
  throttle,
2547
2755
  debounce
2548
2756
  };
2549
- //# sourceMappingURL=chunk-VSLXMERB.js.map
2757
+ //# sourceMappingURL=chunk-YPQCEOVC.js.map