@visulima/pail 1.1.3 → 1.1.5

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/interactive/interactive-manager.ts","../src/interactive/interactive-stream-hook.ts","../src/util/ansi-escapes.ts","../src/reporter/raw/raw.server.ts","../src/pail.server.ts","../src/index.server.ts"],"names":["InteractiveManager","#stream","#isActive","#isSuspended","#lastLength","#outside","stdout","stderr","stream","count","hook","eraseRowCount","erase","separateHistory","rows","from","width","height","terminalSize","position","actualLength","outside","output","accumulator","row","wrapAnsi","status","StringDecoder","ESC","eraseScreen","eraseLine","cursorLeft","cursorUp","clearTerminal","cursorHide","cursorShow","eraseLines","clear","index","InteractiveStreamHook","_InteractiveStreamHook","#decoder","#history","#method","data","arguments_","callback","element","message","RawReporter","#stringify","#stdout","#stderr","#interactiveManager","#interactive","function_","manager","interactive","meta","context","groups","type","items","formattedMessage","value","streamType","groupSpaces","writeStream","PailServerImpl","PailBrowserImpl","options","rawReporter","reporters","rest","name","reporter","PailServer","_getDefaultLogLevel","createPail","MessageFormatterProcessor","ErrorProcessor","PrettyReporter","pail"],"mappings":"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","sourcesContent":["// eslint-disable-next-line import/no-extraneous-dependencies\nimport terminalSize from \"terminal-size\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport wrapAnsi from \"wrap-ansi\";\n\nimport type { InteractiveStreamHook } from \"./interactive-stream-hook\";\n\ntype StreamType = \"stderr\" | \"stdout\";\n\nexport class InteractiveManager {\n readonly #stream: {\n stderr: InteractiveStreamHook;\n stdout: InteractiveStreamHook;\n };\n\n #isActive = false;\n\n #isSuspended = false;\n\n #lastLength = 0;\n\n #outside = 0;\n\n public constructor(stdout: InteractiveStreamHook, stderr: InteractiveStreamHook) {\n this.#stream = {\n stderr,\n stdout,\n };\n }\n\n /**\n * Last printed rows count\n */\n public get lastLength(): number {\n return this.#lastLength;\n }\n\n /**\n * Rows count outside editable area\n */\n public get outside(): number {\n return this.#outside;\n }\n\n /**\n * Hook activity status\n */\n public get isHooked(): boolean {\n return this.#isActive;\n }\n\n /**\n * Suspend status for active hooks\n */\n public get isSuspended(): boolean {\n return this.#isSuspended;\n }\n\n /**\n * Removes from the bottom of output up the specified count of lines\n *\n * @param stream - Stream to remove lines from\n * @param count - lines count to remove\n */\n public erase(stream: StreamType, count = this.#lastLength): void {\n // eslint-disable-next-line security/detect-object-injection,@typescript-eslint/no-unnecessary-condition\n if (this.#stream[stream] === undefined) {\n throw new TypeError(`Stream \"${stream}\" is not available`);\n }\n\n // eslint-disable-next-line security/detect-object-injection\n this.#stream[stream].erase(count);\n }\n\n /**\n * Hook stdout and stderr streams\n * @returns Success status\n */\n public hook(): boolean {\n if (!this.#isActive) {\n Object.values(this.#stream).forEach((hook) => hook.active());\n\n this._clear(true);\n }\n\n return this.#isActive;\n }\n\n /**\n * Resume suspend hooks\n *\n * @param stream - Stream to resume\n * @param eraseRowCount - erase output rows count\n */\n public resume(stream: StreamType, eraseRowCount?: number): void {\n if (this.#isSuspended) {\n this.#isSuspended = false;\n\n if (eraseRowCount) {\n this.erase(stream, eraseRowCount);\n }\n\n this.#lastLength = 0;\n\n Object.values(this.#stream).forEach((hook) => hook.active());\n }\n }\n\n /**\n * Suspend active hooks for external output\n *\n * @param stream - Stream to suspend\n * @param erase - erase output\n */\n public suspend(stream: StreamType, erase = true): void {\n if (!this.#isSuspended) {\n this.#isSuspended = true;\n\n if (erase) {\n this.erase(stream);\n }\n\n Object.values(this.#stream).forEach((hook) => hook.renew());\n }\n }\n\n /**\n * Unhooks both stdout and stderr streams and print their story of logs\n *\n * @param separateHistory - If `true`, will add an empty line to the history output for individual recorded lines and console logs\n *\n * @returns Success status\n */\n public unhook(separateHistory = true): boolean {\n if (this.#isActive) {\n Object.values(this.#stream).forEach((hook) => hook.inactive(separateHistory));\n\n this._clear();\n }\n\n return !this.#isActive;\n }\n\n /**\n * Update output\n *\n * @param stream - Stream to write to\n * @param rows - Text lines to write to standard output\n * @param from - Index of the line starting from which the contents of the terminal are being overwritten\n */\n public update(stream: StreamType, rows: string[], from = 0): void {\n if (rows.length > 0) {\n // eslint-disable-next-line security/detect-object-injection,@typescript-eslint/no-unnecessary-condition\n if (this.#stream[stream] === undefined) {\n throw new TypeError(`Stream \"${stream}\" is not available`);\n }\n\n // eslint-disable-next-line security/detect-object-injection\n const hook = this.#stream[stream];\n\n const { columns: width, rows: height } = terminalSize();\n\n const position = from > height ? height - 1 : Math.max(0, Math.min(height - 1, from));\n const actualLength = this.lastLength - position;\n const outside = Math.max(actualLength - height, this.outside);\n\n // eslint-disable-next-line unicorn/no-array-reduce\n let output = rows.reduce<string[]>(\n (accumulator, row) => [\n ...accumulator,\n wrapAnsi(row, width, {\n hard: true,\n trim: false,\n wordWrap: true,\n }),\n ],\n [],\n );\n\n if (height <= actualLength) {\n hook.erase(height);\n\n if (position < outside) {\n output = output.slice(outside - position + 1);\n }\n } else if (actualLength) {\n hook.erase(actualLength);\n }\n\n hook.write(output.join(\"\\n\") + \"\\n\");\n\n this.#lastLength = outside ? outside + output.length + 1 : output.length;\n this.#outside = Math.max(this.lastLength - height, this.outside);\n }\n }\n\n private _clear(status = false): void {\n this.#isActive = status;\n this.#lastLength = 0;\n this.#outside = 0;\n }\n}\n","import { StringDecoder } from \"node:string_decoder\";\n\nimport { cursorHide, cursorShow, eraseLines } from \"../util/ansi-escapes\";\n\nexport class InteractiveStreamHook {\n public static readonly DRAIN = true;\n\n readonly #decoder = new StringDecoder();\n\n #history: string[] = [];\n\n readonly #method: NodeJS.WriteStream[\"write\"];\n\n readonly #stream: NodeJS.WriteStream;\n\n public constructor(stream: NodeJS.WriteStream) {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n this.#method = stream.write;\n this.#stream = stream;\n }\n\n public active(): void {\n this.write(cursorHide as string);\n\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment,@typescript-eslint/prefer-ts-expect-error\n // @ts-ignore - We are modifying the write method\n this.#stream.write = (data: Uint8Array | string, ...arguments_: [((error?: Error) => void)?] | [(string | undefined)?, ((error?: Error) => void)?]) => {\n const callback = arguments_.at(-1);\n\n this.#history.push(\n this.#decoder.write(\n typeof data === \"string\"\n ? Buffer.from(data, typeof arguments_[0] === \"string\" ? (arguments_[0] as BufferEncoding) : undefined)\n : Buffer.from(data),\n ),\n );\n\n if (typeof callback === \"function\") {\n callback();\n }\n\n return InteractiveStreamHook.DRAIN;\n };\n }\n\n public erase(count: number): void {\n if (count > 0) {\n this.write(eraseLines(count + 1) as string);\n }\n }\n\n public inactive(separateHistory = false): void {\n if (this.#history.length > 0) {\n if (separateHistory) {\n this.write(\"\\n\");\n }\n\n this.#history.forEach((element) => {\n this.write(element);\n });\n this.#history = [];\n }\n\n this.renew();\n }\n\n public renew(): void {\n this.#stream.write = this.#method;\n this.write(cursorShow as string);\n }\n\n public write(message: string): void {\n this.#method.apply(this.#stream, [message]);\n }\n}\n","const ESC = \"\\u001B[\";\n\nconst eraseScreen = ESC + \"2J\";\nconst eraseLine = ESC + \"2K\";\n\nconst cursorLeft = ESC + \"G\";\nconst cursorUp = (count = 1) => ESC + count + \"A\";\n\nexport const clearTerminal: string =\n process.platform === \"win32\"\n ? `${eraseScreen}${ESC}0f`\n : // 1. Erases the screen (Only done in case `2` is not supported)\n // 2. Erases the whole screen including scrollback buffer\n // 3. Moves cursor to the top-left position\n // More info: https://www.real-world-systems.com/docs/ANSIcode.html\n `${eraseScreen}${ESC}3J${ESC}H`;\n\nexport const cursorHide: string = ESC + \"?25l\";\nexport const cursorShow: string = ESC + \"?25h\";\n\nexport const eraseLines = (count: number): string => {\n let clear = \"\";\n\n // eslint-disable-next-line no-loops/no-loops,no-plusplus\n for (let index = 0; index < count; index++) {\n clear += eraseLine + (index < count - 1 ? cursorUp() : \"\");\n }\n\n if (count) {\n clear += cursorLeft;\n }\n\n return clear;\n};\n","import type { stringify } from \"safe-stable-stringify\";\n\nimport type { InteractiveManager } from \"../../interactive/interactive-manager\";\nimport type { ReadonlyMeta, StreamAwareReporter, StringifyAwareReporter } from \"../../types\";\nimport { writeStream } from \"../../util/write-stream\";\n\nexport class RawReporter<L extends string = never> implements StreamAwareReporter<L>, StringifyAwareReporter<L> {\n // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n #stringify: typeof stringify | undefined;\n\n #stdout: NodeJS.WriteStream;\n\n #stderr: NodeJS.WriteStream;\n\n #interactiveManager: InteractiveManager | undefined;\n\n #interactive = false;\n\n public constructor() {\n this.#stdout = process.stdout;\n this.#stderr = process.stderr;\n }\n\n // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n public setStdout(stdout: NodeJS.WriteStream) {\n this.#stdout = stdout;\n }\n\n // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n public setStderr(stderr: NodeJS.WriteStream) {\n this.#stderr = stderr;\n }\n\n // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types, @typescript-eslint/no-explicit-any\n public setStringify(function_: any): void {\n this.#stringify = function_;\n }\n\n public setInteractiveManager(manager?: InteractiveManager): void {\n this.#interactiveManager = manager;\n }\n\n public setIsInteractive(interactive: boolean): void {\n this.#interactive = interactive;\n }\n\n public log(meta: ReadonlyMeta<L>): void {\n const { context, groups, message, type } = meta;\n\n const items: string[] = [];\n\n const formattedMessage: string | undefined = typeof message === \"string\" ? message : (this.#stringify as typeof stringify)(message);\n\n items.push(formattedMessage + \"\");\n\n if (context) {\n items.push(\n ...context.map((value) => {\n if (typeof value === \"object\") {\n return \" \" + (this.#stringify as typeof stringify)(value);\n }\n\n return \" \" + value;\n }),\n );\n }\n\n const streamType = [\"error\", \"trace\", \"warn\"].includes(type.level as string) ? \"stderr\" : \"stdout\";\n const stream = streamType === \"stderr\" ? this.#stderr : this.#stdout;\n const groupSpaces: string = groups.map(() => \" \").join(\"\");\n\n if (this.#interactive && this.#interactiveManager !== undefined && stream.isTTY) {\n this.#interactiveManager.update(streamType, (groupSpaces + items.join(\"\")).split(\"\\n\"), 0);\n } else {\n writeStream(groupSpaces + items.join(\"\"), stream);\n }\n }\n}\n","import { InteractiveManager } from \"./interactive/interactive-manager\";\nimport { InteractiveStreamHook } from \"./interactive/interactive-stream-hook\";\nimport { PailBrowserImpl } from \"./pail.browser\";\nimport { RawReporter } from \"./reporter/raw/raw.server\";\nimport type {\n ConstructorOptions,\n DefaultLogTypes,\n InteractiveStreamReporter,\n LiteralUnion,\n LoggerFunction,\n LoggerTypesAwareReporter,\n Reporter,\n ServerConstructorOptions,\n StreamAwareReporter,\n StringifyAwareReporter,\n} from \"./types\";\nimport { clearTerminal } from \"./util/ansi-escapes\";\n\nclass PailServerImpl<T extends string = never, L extends string = never> extends PailBrowserImpl<T, L> {\n protected readonly stdout: NodeJS.WriteStream;\n\n protected readonly stderr: NodeJS.WriteStream;\n\n protected interactiveManager: InteractiveManager | undefined;\n\n protected readonly interactive: boolean;\n\n public constructor(public readonly options: ServerConstructorOptions<T, L> = {}) {\n const { interactive, rawReporter, reporters, stderr, stdout, ...rest } = options;\n\n super(rest as ConstructorOptions<T, L>);\n\n this.interactive = interactive ?? false;\n\n this.stdout = stdout as NodeJS.WriteStream;\n this.stderr = stderr as NodeJS.WriteStream;\n\n if (this.interactive) {\n this.interactiveManager = new InteractiveManager(new InteractiveStreamHook(this.stdout), new InteractiveStreamHook(this.stderr));\n }\n\n if (Array.isArray(reporters)) {\n this.registerReporters(reporters);\n }\n\n this.rawReporter = this.extendReporter(options.rawReporter ?? new RawReporter<L>());\n }\n\n public override scope<N extends string = T>(...name: string[]): PailServerType<N, L> {\n if (name.length === 0) {\n throw new Error(\"No scope name was defined.\");\n }\n\n this.scopeName = name.flat();\n\n return this as unknown as PailServerType<N, L>;\n }\n\n public getInteractiveManager(): InteractiveManager | undefined {\n return this.interactiveManager;\n }\n\n public wrapStd() {\n this._wrapStream(this.stdout, \"log\");\n this._wrapStream(this.stderr, \"log\");\n }\n\n public restoreStd() {\n this._restoreStream(this.stdout);\n this._restoreStream(this.stderr);\n }\n\n public wrapAll(): void {\n this.wrapConsole();\n this.wrapStd();\n }\n\n public restoreAll(): void {\n this.restoreConsole();\n this.restoreStd();\n }\n\n public override clear(): void {\n this.stdout.write(clearTerminal as string);\n this.stderr.write(clearTerminal as string);\n }\n\n protected override extendReporter(reporter: Reporter<L>): Reporter<L> {\n if (typeof (reporter as StreamAwareReporter<L>).setStdout === \"function\") {\n (reporter as StreamAwareReporter<L>).setStdout(this.stdout);\n }\n\n if (typeof (reporter as StreamAwareReporter<L>).setStderr === \"function\") {\n (reporter as StreamAwareReporter<L>).setStderr(this.stderr);\n }\n\n if (typeof (reporter as LoggerTypesAwareReporter<T, L>).setLoggerTypes === \"function\") {\n (reporter as LoggerTypesAwareReporter<T, L>).setLoggerTypes(this.types);\n }\n\n if (typeof (reporter as StringifyAwareReporter<L>).setStringify === \"function\") {\n (reporter as StringifyAwareReporter<L>).setStringify(this.stringify);\n }\n\n if (typeof (reporter as InteractiveStreamReporter<L>).setIsInteractive === \"function\") {\n (reporter as InteractiveStreamReporter<L>).setIsInteractive(this.interactive);\n }\n\n if (this.interactive && typeof (reporter as InteractiveStreamReporter<L>).setInteractiveManager === \"function\") {\n (reporter as InteractiveStreamReporter<L>).setInteractiveManager(this.interactiveManager);\n }\n\n return reporter;\n }\n\n private _wrapStream(stream: NodeJS.WriteStream | undefined, type: LiteralUnion<DefaultLogTypes, L>) {\n if (!stream) {\n return;\n }\n\n // Backup original value\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if (!(stream as any).__write) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any,no-param-reassign,@typescript-eslint/unbound-method\n (stream as any).__write = stream.write;\n }\n\n // Override\n // eslint-disable-next-line @typescript-eslint/no-explicit-any,no-param-reassign\n (stream as any).write = (data: any): void => {\n // @TODO: Fix typings\n // @ts-expect-error - dynamic property\n // eslint-disable-next-line security/detect-object-injection\n (this as unknown as PailServerImpl)[type].log(String(data).trim());\n };\n }\n\n // eslint-disable-next-line class-methods-use-this\n private _restoreStream(stream?: NodeJS.WriteStream): void {\n if (!stream) {\n return;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if ((stream as any).__write) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any,no-param-reassign\n stream.write = (stream as any).__write;\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any,no-param-reassign\n delete (stream as any).__write;\n }\n }\n}\n\nexport type PailServerType<T extends string = never, L extends string = never> = PailServerImpl<T, L> &\n Record<DefaultLogTypes, LoggerFunction> &\n Record<T, LoggerFunction> &\n (new<TC extends string = never, LC extends string = never>(options?: ServerConstructorOptions<TC, LC>) => PailServerType<TC, LC>);\n\nexport type PailConstructor<T extends string = never, L extends string = never> = new (options?: ServerConstructorOptions<T, L>) => PailServerType<T, L>;\n\nexport const PailServer = PailServerImpl as unknown as PailServerType;\n","import type { PailServerType } from \"./pail.server\";\nimport { PailServer } from \"./pail.server\";\nimport { ErrorProcessor } from \"./processor/error/error-processor\";\nimport { MessageFormatterProcessor } from \"./processor/message-formatter-processor\";\nimport { PrettyReporter } from \"./reporter/pretty/pretty.server\";\nimport type { ConstructorOptions, ExtendedRfc5424LogLevels } from \"./types\";\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nconst _getDefaultLogLevel = (): ExtendedRfc5424LogLevels => {\n if (process.env[\"NODE_ENV\"] === \"debug\" || process.env[\"DEBUG\"] !== undefined) {\n return \"debug\";\n }\n\n if (process.env[\"NODE_ENV\"] === \"test\") {\n return \"warning\";\n }\n\n return \"informational\";\n};\n\nexport const createPail = <T extends string = never, L extends string = never>(options?: ConstructorOptions<T, L>): PailServerType<T, L> =>\n new PailServer<T, L>({\n logLevel: _getDefaultLogLevel(),\n processors: [new MessageFormatterProcessor<L>(), new ErrorProcessor<L>()],\n reporters: [new PrettyReporter()],\n stderr: process.stderr,\n stdout: process.stdout,\n ...options,\n });\n\nexport const pail = createPail();\n\nexport type { PailServerType as Pail } from \"./pail.server\";\nexport type {\n ConstructorOptions,\n DefaultLoggerTypes,\n DefaultLogTypes,\n ExtendedRfc5424LogLevels,\n LoggerConfiguration,\n LoggerFunction,\n LoggerTypesAwareReporter,\n LoggerTypesConfig,\n Processor,\n Reporter,\n StreamAwareReporter,\n} from \"./shared\";\n"]}
1
+ {"version":3,"sources":["../src/interactive/interactive-manager.ts","../src/interactive/interactive-stream-hook.ts","../src/util/ansi-escapes.ts","../src/reporter/raw/raw.server.ts","../src/pail.server.ts","../src/index.server.ts"],"names":["InteractiveManager","#stream","#isActive","#isSuspended","#lastLength","#outside","stdout","stderr","stream","count","hook","eraseRowCount","erase","separateHistory","rows","from","width","height","terminalSize","position","actualLength","outside","output","accumulator","row","wrapAnsi","status","StringDecoder","ESC","eraseScreen","eraseLine","cursorLeft","cursorUp","clearTerminal","cursorHide","cursorShow","eraseLines","clear","index","InteractiveStreamHook","_InteractiveStreamHook","#decoder","#history","#method","data","arguments_","callback","element","message","RawReporter","#stringify","#stdout","#stderr","#interactiveManager","#interactive","function_","manager","interactive","meta","context","groups","type","items","formattedMessage","value","streamType","groupSpaces","writeStream","PailServerImpl","PailBrowserImpl","options","rawReporter","reporters","rest","name","reporter","PailServer","_getDefaultLogLevel","createPail","MessageFormatterProcessor","ErrorProcessor","PrettyReporter","pail"],"mappings":"wOASO,IAAMA,EAAN,KAAyB,CACnBC,GAKTC,GAAY,GAEZC,GAAe,GAEfC,GAAc,EAEdC,GAAW,EAEJ,YAAYC,EAA+BC,EAA+B,CAC7E,KAAKN,GAAU,CACX,OAAAM,EACA,OAAAD,CACJ,CACJ,CAKA,IAAW,YAAqB,CAC5B,OAAO,KAAKF,EAChB,CAKA,IAAW,SAAkB,CACzB,OAAO,KAAKC,EAChB,CAKA,IAAW,UAAoB,CAC3B,OAAO,KAAKH,EAChB,CAKA,IAAW,aAAuB,CAC9B,OAAO,KAAKC,EAChB,CAQO,MAAMK,EAAoBC,EAAQ,KAAKL,GAAmB,CAE7D,GAAI,KAAKH,GAAQO,CAAM,IAAM,OACzB,MAAM,IAAI,UAAU,WAAWA,CAAM,oBAAoB,EAI7D,KAAKP,GAAQO,CAAM,EAAE,MAAMC,CAAK,CACpC,CAMO,MAAgB,CACnB,OAAK,KAAKP,KACN,OAAO,OAAO,KAAKD,EAAO,EAAE,QAASS,GAASA,EAAK,OAAO,CAAC,EAE3D,KAAK,OAAO,EAAI,GAGb,KAAKR,EAChB,CAQO,OAAOM,EAAoBG,EAA8B,CACxD,KAAKR,KACL,KAAKA,GAAe,GAEhBQ,GACA,KAAK,MAAMH,EAAQG,CAAa,EAGpC,KAAKP,GAAc,EAEnB,OAAO,OAAO,KAAKH,EAAO,EAAE,QAASS,GAASA,EAAK,OAAO,CAAC,EAEnE,CAQO,QAAQF,EAAoBI,EAAQ,GAAY,CAC9C,KAAKT,KACN,KAAKA,GAAe,GAEhBS,GACA,KAAK,MAAMJ,CAAM,EAGrB,OAAO,OAAO,KAAKP,EAAO,EAAE,QAASS,GAASA,EAAK,MAAM,CAAC,EAElE,CASO,OAAOG,EAAkB,GAAe,CAC3C,OAAI,KAAKX,KACL,OAAO,OAAO,KAAKD,EAAO,EAAE,QAASS,GAASA,EAAK,SAASG,CAAe,CAAC,EAE5E,KAAK,OAAO,GAGT,CAAC,KAAKX,EACjB,CASO,OAAOM,EAAoBM,EAAgBC,EAAO,EAAS,CAC9D,GAAID,EAAK,OAAS,EAAG,CAEjB,GAAI,KAAKb,GAAQO,CAAM,IAAM,OACzB,MAAM,IAAI,UAAU,WAAWA,CAAM,oBAAoB,EAI7D,IAAME,EAAO,KAAKT,GAAQO,CAAM,EAE1B,CAAE,QAASQ,EAAO,KAAMC,CAAO,EAAIC,EAAa,EAEhDC,EAAWJ,EAAOE,EAASA,EAAS,EAAI,KAAK,IAAI,EAAG,KAAK,IAAIA,EAAS,EAAGF,CAAI,CAAC,EAC9EK,EAAe,KAAK,WAAaD,EACjCE,EAAU,KAAK,IAAID,EAAeH,EAAQ,KAAK,OAAO,EAGxDK,EAASR,EAAK,OACd,CAACS,EAAaC,IAAQ,CAClB,GAAGD,EACHE,EAASD,EAAKR,EAAO,CACjB,KAAM,GACN,KAAM,GACN,SAAU,EACd,CAAC,CACL,EACA,CAAC,CACL,EAEIC,GAAUG,GACVV,EAAK,MAAMO,CAAM,EAEbE,EAAWE,IACXC,EAASA,EAAO,MAAMD,EAAUF,EAAW,CAAC,IAEzCC,GACPV,EAAK,MAAMU,CAAY,EAG3BV,EAAK,MAAMY,EAAO,KAAK;AAAA,CAAI,EAAI;AAAA,CAAI,EAEnC,KAAKlB,GAAciB,EAAUA,EAAUC,EAAO,OAAS,EAAIA,EAAO,OAClE,KAAKjB,GAAW,KAAK,IAAI,KAAK,WAAaY,EAAQ,KAAK,OAAO,CACnE,CACJ,CAEQ,OAAOS,EAAS,GAAa,CACjC,KAAKxB,GAAYwB,EACjB,KAAKtB,GAAc,EACnB,KAAKC,GAAW,CACpB,CACJ,ECzMA,OAAS,iBAAAsB,MAAqB,sBCA9B,IAAMC,EAAM,QAENC,EAAcD,EAAM,KACpBE,EAAYF,EAAM,KAElBG,EAAaH,EAAM,IACnBI,EAAW,CAACvB,EAAQ,IAAMmB,EAAMnB,EAAQ,IAEjCwB,EACT,QAAQ,WAAa,QACf,GAAGJ,CAAW,GAAGD,CAAG,KAKpB,GAAGC,CAAW,GAAGD,CAAG,KAAKA,CAAG,IAEzBM,EAAqBN,EAAM,OAC3BO,EAAqBP,EAAM,OAE3BQ,EAAc3B,GAA0B,CACjD,IAAI4B,EAAQ,GAGZ,QAASC,EAAQ,EAAGA,EAAQ7B,EAAO6B,IAC/BD,GAASP,GAAaQ,EAAQ7B,EAAQ,EAAIuB,EAAS,EAAI,IAG3D,OAAIvB,IACA4B,GAASN,GAGNM,CACX,ED7BO,IAAME,EAAN,MAAMC,CAAsB,CAC/B,OAAuB,MAAQ,GAEtBC,GAAW,IAAId,EAExBe,GAAqB,CAAC,EAEbC,GAEA1C,GAEF,YAAYO,EAA4B,CAE3C,KAAKmC,GAAUnC,EAAO,MACtB,KAAKP,GAAUO,CACnB,CAEO,QAAe,CAClB,KAAK,MAAM0B,CAAoB,EAI/B,KAAKjC,GAAQ,MAAQ,CAAC2C,KAA8BC,IAAmG,CACnJ,IAAMC,EAAWD,EAAW,GAAG,EAAE,EAEjC,YAAKH,GAAS,KACV,KAAKD,GAAS,MACV,OAAOG,GAAS,SACV,OAAO,KAAKA,EAAM,OAAOC,EAAW,CAAC,GAAM,SAAYA,EAAW,CAAC,EAAuB,MAAS,EACnG,OAAO,KAAKD,CAAI,CAC1B,CACJ,EAEI,OAAOE,GAAa,YACpBA,EAAS,EAGNN,EAAsB,KACjC,CACJ,CAEO,MAAM/B,EAAqB,CAC1BA,EAAQ,GACR,KAAK,MAAM2B,EAAW3B,EAAQ,CAAC,CAAW,CAElD,CAEO,SAASI,EAAkB,GAAa,CACvC,KAAK6B,GAAS,OAAS,IACnB7B,GACA,KAAK,MAAM;AAAA,CAAI,EAGnB,KAAK6B,GAAS,QAASK,GAAY,CAC/B,KAAK,MAAMA,CAAO,CACtB,CAAC,EACD,KAAKL,GAAW,CAAC,GAGrB,KAAK,MAAM,CACf,CAEO,OAAc,CACjB,KAAKzC,GAAQ,MAAQ,KAAK0C,GAC1B,KAAK,MAAMR,CAAoB,CACnC,CAEO,MAAMa,EAAuB,CAChC,KAAKL,GAAQ,MAAM,KAAK1C,GAAS,CAAC+C,CAAO,CAAC,CAC9C,CACJ,EEpEO,IAAMC,EAAN,KAAyG,CAE5GC,GAEAC,GAEAC,GAEAC,GAEAC,GAAe,GAER,aAAc,CACjB,KAAKH,GAAU,QAAQ,OACvB,KAAKC,GAAU,QAAQ,MAC3B,CAGO,UAAU9C,EAA4B,CACzC,KAAK6C,GAAU7C,CACnB,CAGO,UAAUC,EAA4B,CACzC,KAAK6C,GAAU7C,CACnB,CAGO,aAAagD,EAAsB,CACtC,KAAKL,GAAaK,CACtB,CAEO,sBAAsBC,EAAoC,CAC7D,KAAKH,GAAsBG,CAC/B,CAEO,iBAAiBC,EAA4B,CAChD,KAAKH,GAAeG,CACxB,CAEO,IAAIC,EAA6B,CACpC,GAAM,CAAE,QAAAC,EAAS,OAAAC,EAAQ,QAAAZ,EAAS,KAAAa,CAAK,EAAIH,EAErCI,EAAkB,CAAC,EAEnBC,EAAuC,OAAOf,GAAY,SAAWA,EAAW,KAAKE,GAAgCF,CAAO,EAElIc,EAAM,KAAKC,EAAmB,EAAE,EAE5BJ,GACAG,EAAM,KACF,GAAGH,EAAQ,IAAKK,GACR,OAAOA,GAAU,SACV,IAAO,KAAKd,GAAgCc,CAAK,EAGrD,IAAMA,CAChB,CACL,EAGJ,IAAMC,EAAa,CAAC,QAAS,QAAS,MAAM,EAAE,SAASJ,EAAK,KAAe,EAAI,SAAW,SACpFrD,EAASyD,IAAe,SAAW,KAAKb,GAAU,KAAKD,GACvDe,EAAsBN,EAAO,IAAI,IAAM,MAAM,EAAE,KAAK,EAAE,EAExD,KAAKN,IAAgB,KAAKD,KAAwB,QAAa7C,EAAO,MACtE,KAAK6C,GAAoB,OAAOY,GAAaC,EAAcJ,EAAM,KAAK,EAAE,GAAG,MAAM;AAAA,CAAI,EAAG,CAAC,EAEzFK,EAAYD,EAAcJ,EAAM,KAAK,EAAE,EAAGtD,CAAM,CAExD,CACJ,EC3DA,IAAM4D,EAAN,cAAiFC,CAAsB,CAS5F,YAA4BC,EAA0C,CAAC,EAAG,CAC7E,GAAM,CAAE,YAAAb,EAAa,YAAAc,EAAa,UAAAC,EAAW,OAAAjE,EAAQ,OAAAD,EAAQ,GAAGmE,CAAK,EAAIH,EAEzE,MAAMG,CAAgC,EAHP,aAAAH,EAK/B,KAAK,YAAcb,GAAe,GAElC,KAAK,OAASnD,EACd,KAAK,OAASC,EAEV,KAAK,cACL,KAAK,mBAAqB,IAAIP,EAAmB,IAAIuC,EAAsB,KAAK,MAAM,EAAG,IAAIA,EAAsB,KAAK,MAAM,CAAC,GAG/H,MAAM,QAAQiC,CAAS,GACvB,KAAK,kBAAkBA,CAAS,EAGpC,KAAK,YAAc,KAAK,eAAeF,EAAQ,aAAe,IAAIrB,CAAgB,CACtF,CA3BmB,OAEA,OAET,mBAES,YAuBH,SAA+ByB,EAAsC,CACjF,GAAIA,EAAK,SAAW,EAChB,MAAM,IAAI,MAAM,4BAA4B,EAGhD,YAAK,UAAYA,EAAK,KAAK,EAEpB,IACX,CAEO,uBAAwD,CAC3D,OAAO,KAAK,kBAChB,CAEO,SAAU,CACb,KAAK,YAAY,KAAK,OAAQ,KAAK,EACnC,KAAK,YAAY,KAAK,OAAQ,KAAK,CACvC,CAEO,YAAa,CAChB,KAAK,eAAe,KAAK,MAAM,EAC/B,KAAK,eAAe,KAAK,MAAM,CACnC,CAEO,SAAgB,CACnB,KAAK,YAAY,EACjB,KAAK,QAAQ,CACjB,CAEO,YAAmB,CACtB,KAAK,eAAe,EACpB,KAAK,WAAW,CACpB,CAEgB,OAAc,CAC1B,KAAK,OAAO,MAAMzC,CAAuB,EACzC,KAAK,OAAO,MAAMA,CAAuB,CAC7C,CAEmB,eAAe0C,EAAoC,CAClE,OAAI,OAAQA,EAAoC,WAAc,YACzDA,EAAoC,UAAU,KAAK,MAAM,EAG1D,OAAQA,EAAoC,WAAc,YACzDA,EAAoC,UAAU,KAAK,MAAM,EAG1D,OAAQA,EAA4C,gBAAmB,YACtEA,EAA4C,eAAe,KAAK,KAAK,EAGtE,OAAQA,EAAuC,cAAiB,YAC/DA,EAAuC,aAAa,KAAK,SAAS,EAGnE,OAAQA,EAA0C,kBAAqB,YACtEA,EAA0C,iBAAiB,KAAK,WAAW,EAG5E,KAAK,aAAe,OAAQA,EAA0C,uBAA0B,YAC/FA,EAA0C,sBAAsB,KAAK,kBAAkB,EAGrFA,CACX,CAEQ,YAAYnE,EAAwCqD,EAAwC,CAC3FrD,IAMCA,EAAe,UAEhBA,EAAe,QAAUA,EAAO,OAKpCA,EAAe,MAASoC,GAAoB,CAIxC,KAAmCiB,CAAI,EAAE,IAAI,OAAOjB,CAAI,EAAE,KAAK,CAAC,CACrE,EACJ,CAGQ,eAAepC,EAAmC,CACjDA,GAKAA,EAAe,UAEhBA,EAAO,MAASA,EAAe,QAG/B,OAAQA,EAAe,QAE/B,CACJ,EASaoE,EAAaR,ECzJ1B,IAAMS,EAAsB,IACgB,QAAQ,IAAI,QAAU,OACnD,QAOJ,gBAGEC,EAAkER,GAC3E,IAAIM,EAAiB,CACjB,SAAUC,EAAoB,EAC9B,WAAY,CAAC,IAAIE,EAAgC,IAAIC,CAAmB,EACxE,UAAW,CAAC,IAAIC,CAAgB,EAChC,OAAQ,QAAQ,OAChB,OAAQ,QAAQ,OAChB,GAAGX,CACP,CAAC,EAEQY,GAAOJ,EAAW","sourcesContent":["// eslint-disable-next-line import/no-extraneous-dependencies\nimport terminalSize from \"terminal-size\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport wrapAnsi from \"wrap-ansi\";\n\nimport type { InteractiveStreamHook } from \"./interactive-stream-hook\";\n\ntype StreamType = \"stderr\" | \"stdout\";\n\nexport class InteractiveManager {\n readonly #stream: {\n stderr: InteractiveStreamHook;\n stdout: InteractiveStreamHook;\n };\n\n #isActive = false;\n\n #isSuspended = false;\n\n #lastLength = 0;\n\n #outside = 0;\n\n public constructor(stdout: InteractiveStreamHook, stderr: InteractiveStreamHook) {\n this.#stream = {\n stderr,\n stdout,\n };\n }\n\n /**\n * Last printed rows count\n */\n public get lastLength(): number {\n return this.#lastLength;\n }\n\n /**\n * Rows count outside editable area\n */\n public get outside(): number {\n return this.#outside;\n }\n\n /**\n * Hook activity status\n */\n public get isHooked(): boolean {\n return this.#isActive;\n }\n\n /**\n * Suspend status for active hooks\n */\n public get isSuspended(): boolean {\n return this.#isSuspended;\n }\n\n /**\n * Removes from the bottom of output up the specified count of lines\n *\n * @param stream - Stream to remove lines from\n * @param count - lines count to remove\n */\n public erase(stream: StreamType, count = this.#lastLength): void {\n // eslint-disable-next-line security/detect-object-injection,@typescript-eslint/no-unnecessary-condition\n if (this.#stream[stream] === undefined) {\n throw new TypeError(`Stream \"${stream}\" is not available`);\n }\n\n // eslint-disable-next-line security/detect-object-injection\n this.#stream[stream].erase(count);\n }\n\n /**\n * Hook stdout and stderr streams\n * @returns Success status\n */\n public hook(): boolean {\n if (!this.#isActive) {\n Object.values(this.#stream).forEach((hook) => hook.active());\n\n this._clear(true);\n }\n\n return this.#isActive;\n }\n\n /**\n * Resume suspend hooks\n *\n * @param stream - Stream to resume\n * @param eraseRowCount - erase output rows count\n */\n public resume(stream: StreamType, eraseRowCount?: number): void {\n if (this.#isSuspended) {\n this.#isSuspended = false;\n\n if (eraseRowCount) {\n this.erase(stream, eraseRowCount);\n }\n\n this.#lastLength = 0;\n\n Object.values(this.#stream).forEach((hook) => hook.active());\n }\n }\n\n /**\n * Suspend active hooks for external output\n *\n * @param stream - Stream to suspend\n * @param erase - erase output\n */\n public suspend(stream: StreamType, erase = true): void {\n if (!this.#isSuspended) {\n this.#isSuspended = true;\n\n if (erase) {\n this.erase(stream);\n }\n\n Object.values(this.#stream).forEach((hook) => hook.renew());\n }\n }\n\n /**\n * Unhooks both stdout and stderr streams and print their story of logs\n *\n * @param separateHistory - If `true`, will add an empty line to the history output for individual recorded lines and console logs\n *\n * @returns Success status\n */\n public unhook(separateHistory = true): boolean {\n if (this.#isActive) {\n Object.values(this.#stream).forEach((hook) => hook.inactive(separateHistory));\n\n this._clear();\n }\n\n return !this.#isActive;\n }\n\n /**\n * Update output\n *\n * @param stream - Stream to write to\n * @param rows - Text lines to write to standard output\n * @param from - Index of the line starting from which the contents of the terminal are being overwritten\n */\n public update(stream: StreamType, rows: string[], from = 0): void {\n if (rows.length > 0) {\n // eslint-disable-next-line security/detect-object-injection,@typescript-eslint/no-unnecessary-condition\n if (this.#stream[stream] === undefined) {\n throw new TypeError(`Stream \"${stream}\" is not available`);\n }\n\n // eslint-disable-next-line security/detect-object-injection\n const hook = this.#stream[stream];\n\n const { columns: width, rows: height } = terminalSize();\n\n const position = from > height ? height - 1 : Math.max(0, Math.min(height - 1, from));\n const actualLength = this.lastLength - position;\n const outside = Math.max(actualLength - height, this.outside);\n\n // eslint-disable-next-line unicorn/no-array-reduce\n let output = rows.reduce<string[]>(\n (accumulator, row) => [\n ...accumulator,\n wrapAnsi(row, width, {\n hard: true,\n trim: false,\n wordWrap: true,\n }),\n ],\n [],\n );\n\n if (height <= actualLength) {\n hook.erase(height);\n\n if (position < outside) {\n output = output.slice(outside - position + 1);\n }\n } else if (actualLength) {\n hook.erase(actualLength);\n }\n\n hook.write(output.join(\"\\n\") + \"\\n\");\n\n this.#lastLength = outside ? outside + output.length + 1 : output.length;\n this.#outside = Math.max(this.lastLength - height, this.outside);\n }\n }\n\n private _clear(status = false): void {\n this.#isActive = status;\n this.#lastLength = 0;\n this.#outside = 0;\n }\n}\n","import { StringDecoder } from \"node:string_decoder\";\n\nimport { cursorHide, cursorShow, eraseLines } from \"../util/ansi-escapes\";\n\nexport class InteractiveStreamHook {\n public static readonly DRAIN = true;\n\n readonly #decoder = new StringDecoder();\n\n #history: string[] = [];\n\n readonly #method: NodeJS.WriteStream[\"write\"];\n\n readonly #stream: NodeJS.WriteStream;\n\n public constructor(stream: NodeJS.WriteStream) {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n this.#method = stream.write;\n this.#stream = stream;\n }\n\n public active(): void {\n this.write(cursorHide as string);\n\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment,@typescript-eslint/prefer-ts-expect-error\n // @ts-ignore - We are modifying the write method\n this.#stream.write = (data: Uint8Array | string, ...arguments_: [((error?: Error) => void)?] | [(string | undefined)?, ((error?: Error) => void)?]) => {\n const callback = arguments_.at(-1);\n\n this.#history.push(\n this.#decoder.write(\n typeof data === \"string\"\n ? Buffer.from(data, typeof arguments_[0] === \"string\" ? (arguments_[0] as BufferEncoding) : undefined)\n : Buffer.from(data),\n ),\n );\n\n if (typeof callback === \"function\") {\n callback();\n }\n\n return InteractiveStreamHook.DRAIN;\n };\n }\n\n public erase(count: number): void {\n if (count > 0) {\n this.write(eraseLines(count + 1) as string);\n }\n }\n\n public inactive(separateHistory = false): void {\n if (this.#history.length > 0) {\n if (separateHistory) {\n this.write(\"\\n\");\n }\n\n this.#history.forEach((element) => {\n this.write(element);\n });\n this.#history = [];\n }\n\n this.renew();\n }\n\n public renew(): void {\n this.#stream.write = this.#method;\n this.write(cursorShow as string);\n }\n\n public write(message: string): void {\n this.#method.apply(this.#stream, [message]);\n }\n}\n","const ESC = \"\\u001B[\";\n\nconst eraseScreen = ESC + \"2J\";\nconst eraseLine = ESC + \"2K\";\n\nconst cursorLeft = ESC + \"G\";\nconst cursorUp = (count = 1) => ESC + count + \"A\";\n\nexport const clearTerminal: string =\n process.platform === \"win32\"\n ? `${eraseScreen}${ESC}0f`\n : // 1. Erases the screen (Only done in case `2` is not supported)\n // 2. Erases the whole screen including scrollback buffer\n // 3. Moves cursor to the top-left position\n // More info: https://www.real-world-systems.com/docs/ANSIcode.html\n `${eraseScreen}${ESC}3J${ESC}H`;\n\nexport const cursorHide: string = ESC + \"?25l\";\nexport const cursorShow: string = ESC + \"?25h\";\n\nexport const eraseLines = (count: number): string => {\n let clear = \"\";\n\n // eslint-disable-next-line no-loops/no-loops,no-plusplus\n for (let index = 0; index < count; index++) {\n clear += eraseLine + (index < count - 1 ? cursorUp() : \"\");\n }\n\n if (count) {\n clear += cursorLeft;\n }\n\n return clear;\n};\n","import type { stringify } from \"safe-stable-stringify\";\n\nimport type { InteractiveManager } from \"../../interactive/interactive-manager\";\nimport type { ReadonlyMeta, StreamAwareReporter, StringifyAwareReporter } from \"../../types\";\nimport { writeStream } from \"../../util/write-stream\";\n\nexport class RawReporter<L extends string = never> implements StreamAwareReporter<L>, StringifyAwareReporter<L> {\n // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n #stringify: typeof stringify | undefined;\n\n #stdout: NodeJS.WriteStream;\n\n #stderr: NodeJS.WriteStream;\n\n #interactiveManager: InteractiveManager | undefined;\n\n #interactive = false;\n\n public constructor() {\n this.#stdout = process.stdout;\n this.#stderr = process.stderr;\n }\n\n // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n public setStdout(stdout: NodeJS.WriteStream) {\n this.#stdout = stdout;\n }\n\n // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n public setStderr(stderr: NodeJS.WriteStream) {\n this.#stderr = stderr;\n }\n\n // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types, @typescript-eslint/no-explicit-any\n public setStringify(function_: any): void {\n this.#stringify = function_;\n }\n\n public setInteractiveManager(manager?: InteractiveManager): void {\n this.#interactiveManager = manager;\n }\n\n public setIsInteractive(interactive: boolean): void {\n this.#interactive = interactive;\n }\n\n public log(meta: ReadonlyMeta<L>): void {\n const { context, groups, message, type } = meta;\n\n const items: string[] = [];\n\n const formattedMessage: string | undefined = typeof message === \"string\" ? message : (this.#stringify as typeof stringify)(message);\n\n items.push(formattedMessage + \"\");\n\n if (context) {\n items.push(\n ...context.map((value) => {\n if (typeof value === \"object\") {\n return \" \" + (this.#stringify as typeof stringify)(value);\n }\n\n return \" \" + value;\n }),\n );\n }\n\n const streamType = [\"error\", \"trace\", \"warn\"].includes(type.level as string) ? \"stderr\" : \"stdout\";\n const stream = streamType === \"stderr\" ? this.#stderr : this.#stdout;\n const groupSpaces: string = groups.map(() => \" \").join(\"\");\n\n if (this.#interactive && this.#interactiveManager !== undefined && stream.isTTY) {\n this.#interactiveManager.update(streamType, (groupSpaces + items.join(\"\")).split(\"\\n\"), 0);\n } else {\n writeStream(groupSpaces + items.join(\"\"), stream);\n }\n }\n}\n","import { InteractiveManager } from \"./interactive/interactive-manager\";\nimport { InteractiveStreamHook } from \"./interactive/interactive-stream-hook\";\nimport { PailBrowserImpl } from \"./pail.browser\";\nimport { RawReporter } from \"./reporter/raw/raw.server\";\nimport type {\n ConstructorOptions,\n DefaultLogTypes,\n InteractiveStreamReporter,\n LiteralUnion,\n LoggerFunction,\n LoggerTypesAwareReporter,\n Reporter,\n ServerConstructorOptions,\n StreamAwareReporter,\n StringifyAwareReporter,\n} from \"./types\";\nimport { clearTerminal } from \"./util/ansi-escapes\";\n\nclass PailServerImpl<T extends string = never, L extends string = never> extends PailBrowserImpl<T, L> {\n protected readonly stdout: NodeJS.WriteStream;\n\n protected readonly stderr: NodeJS.WriteStream;\n\n protected interactiveManager: InteractiveManager | undefined;\n\n protected readonly interactive: boolean;\n\n public constructor(public readonly options: ServerConstructorOptions<T, L> = {}) {\n const { interactive, rawReporter, reporters, stderr, stdout, ...rest } = options;\n\n super(rest as ConstructorOptions<T, L>);\n\n this.interactive = interactive ?? false;\n\n this.stdout = stdout as NodeJS.WriteStream;\n this.stderr = stderr as NodeJS.WriteStream;\n\n if (this.interactive) {\n this.interactiveManager = new InteractiveManager(new InteractiveStreamHook(this.stdout), new InteractiveStreamHook(this.stderr));\n }\n\n if (Array.isArray(reporters)) {\n this.registerReporters(reporters);\n }\n\n this.rawReporter = this.extendReporter(options.rawReporter ?? new RawReporter<L>());\n }\n\n public override scope<N extends string = T>(...name: string[]): PailServerType<N, L> {\n if (name.length === 0) {\n throw new Error(\"No scope name was defined.\");\n }\n\n this.scopeName = name.flat();\n\n return this as unknown as PailServerType<N, L>;\n }\n\n public getInteractiveManager(): InteractiveManager | undefined {\n return this.interactiveManager;\n }\n\n public wrapStd() {\n this._wrapStream(this.stdout, \"log\");\n this._wrapStream(this.stderr, \"log\");\n }\n\n public restoreStd() {\n this._restoreStream(this.stdout);\n this._restoreStream(this.stderr);\n }\n\n public wrapAll(): void {\n this.wrapConsole();\n this.wrapStd();\n }\n\n public restoreAll(): void {\n this.restoreConsole();\n this.restoreStd();\n }\n\n public override clear(): void {\n this.stdout.write(clearTerminal as string);\n this.stderr.write(clearTerminal as string);\n }\n\n protected override extendReporter(reporter: Reporter<L>): Reporter<L> {\n if (typeof (reporter as StreamAwareReporter<L>).setStdout === \"function\") {\n (reporter as StreamAwareReporter<L>).setStdout(this.stdout);\n }\n\n if (typeof (reporter as StreamAwareReporter<L>).setStderr === \"function\") {\n (reporter as StreamAwareReporter<L>).setStderr(this.stderr);\n }\n\n if (typeof (reporter as LoggerTypesAwareReporter<T, L>).setLoggerTypes === \"function\") {\n (reporter as LoggerTypesAwareReporter<T, L>).setLoggerTypes(this.types);\n }\n\n if (typeof (reporter as StringifyAwareReporter<L>).setStringify === \"function\") {\n (reporter as StringifyAwareReporter<L>).setStringify(this.stringify);\n }\n\n if (typeof (reporter as InteractiveStreamReporter<L>).setIsInteractive === \"function\") {\n (reporter as InteractiveStreamReporter<L>).setIsInteractive(this.interactive);\n }\n\n if (this.interactive && typeof (reporter as InteractiveStreamReporter<L>).setInteractiveManager === \"function\") {\n (reporter as InteractiveStreamReporter<L>).setInteractiveManager(this.interactiveManager);\n }\n\n return reporter;\n }\n\n private _wrapStream(stream: NodeJS.WriteStream | undefined, type: LiteralUnion<DefaultLogTypes, L>) {\n if (!stream) {\n return;\n }\n\n // Backup original value\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if (!(stream as any).__write) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any,no-param-reassign,@typescript-eslint/unbound-method\n (stream as any).__write = stream.write;\n }\n\n // Override\n // eslint-disable-next-line @typescript-eslint/no-explicit-any,no-param-reassign\n (stream as any).write = (data: any): void => {\n // @TODO: Fix typings\n // @ts-expect-error - dynamic property\n // eslint-disable-next-line security/detect-object-injection\n (this as unknown as PailServerImpl)[type].log(String(data).trim());\n };\n }\n\n // eslint-disable-next-line class-methods-use-this\n private _restoreStream(stream?: NodeJS.WriteStream): void {\n if (!stream) {\n return;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if ((stream as any).__write) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any,no-param-reassign\n stream.write = (stream as any).__write;\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any,no-param-reassign\n delete (stream as any).__write;\n }\n }\n}\n\nexport type PailServerType<T extends string = never, L extends string = never> = PailServerImpl<T, L> &\n Record<DefaultLogTypes, LoggerFunction> &\n Record<T, LoggerFunction> &\n (new<TC extends string = never, LC extends string = never>(options?: ServerConstructorOptions<TC, LC>) => PailServerType<TC, LC>);\n\nexport type PailConstructor<T extends string = never, L extends string = never> = new (options?: ServerConstructorOptions<T, L>) => PailServerType<T, L>;\n\nexport const PailServer = PailServerImpl as unknown as PailServerType;\n","import type { PailServerType } from \"./pail.server\";\nimport { PailServer } from \"./pail.server\";\nimport { ErrorProcessor } from \"./processor/error/error-processor\";\nimport { MessageFormatterProcessor } from \"./processor/message-formatter-processor\";\nimport { PrettyReporter } from \"./reporter/pretty/pretty.server\";\nimport type { ConstructorOptions, ExtendedRfc5424LogLevels } from \"./types\";\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nconst _getDefaultLogLevel = (): ExtendedRfc5424LogLevels => {\n if (process.env.NODE_ENV === \"debug\" || process.env.DEBUG !== undefined) {\n return \"debug\";\n }\n\n if (process.env.NODE_ENV === \"test\") {\n return \"warning\";\n }\n\n return \"informational\";\n};\n\nexport const createPail = <T extends string = never, L extends string = never>(options?: ConstructorOptions<T, L>): PailServerType<T, L> =>\n new PailServer<T, L>({\n logLevel: _getDefaultLogLevel(),\n processors: [new MessageFormatterProcessor<L>(), new ErrorProcessor<L>()],\n reporters: [new PrettyReporter()],\n stderr: process.stderr,\n stdout: process.stdout,\n ...options,\n });\n\nexport const pail = createPail();\n\nexport type { PailServerType as Pail } from \"./pail.server\";\nexport type {\n ConstructorOptions,\n DefaultLoggerTypes,\n DefaultLogTypes,\n ExtendedRfc5424LogLevels,\n LoggerConfiguration,\n LoggerFunction,\n LoggerTypesAwareReporter,\n LoggerTypesConfig,\n Processor,\n Reporter,\n StreamAwareReporter,\n} from \"./shared\";\n"]}
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var chunkXQP4GKQU_cjs = require('./chunk-XQP4GKQU.cjs');
3
+ var chunkK4LLYFBH_cjs = require('./chunk-K4LLYFBH.cjs');
4
4
  var chunkZJMTPHZR_cjs = require('./chunk-ZJMTPHZR.cjs');
5
5
  require('./chunk-YP3U3DTV.cjs');
6
6
  require('./chunk-QINSQ6TU.cjs');
@@ -12,12 +12,12 @@ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
12
12
  var c__default = /*#__PURE__*/_interopDefault(c);
13
13
 
14
14
  var a=class{_ready=!0;_stream;_name;constructor(t,r){this._stream=t,this._name=r;}write(t){this.writeStream(t);}end(...t){this._stream.end(...t);}writeStream(t){if(!this._ready){console.warn("Stream busy: "+this._name+'. Write will be dropped: "'+t+'"');return}this._ready=!1,this._stream.on("error",r=>{throw r}),this._stream.on("drain",()=>{this._ready=!0;}),this._stream.on("finish",()=>{this._ready=!0;}),this._ready=this._stream.write(t,()=>{});}};var n=class{_filePath;_immediate;_stream;_options;constructor(t,r=!1,e={}){this._filePath=t,this._immediate=r,this._options=e,this._immediate||(this._stream=rotatingFileStream.createStream(this._filePath,e));}write(t){let r=this._stream;this._immediate&&(r=rotatingFileStream.createStream(this._filePath,this._options));let e=new a(r,this._filePath);e.write(t),this._immediate&&e.end();}end(){this._stream!==void 0&&this._stream.end();}};var s=class{_stream;constructor(t){let{filePath:r,writeImmediately:e=!1,...h}=t;this._stream=new n(r,e,h);}log(t){this._stream.write(this._formatMessage(t)+`
15
- `);}};var p=class extends s{#t;constructor(t){super({compress:"gzip",interval:"1d",size:"10M",...t});}setStringify(t){this.#t=t;}_formatMessage(t){let{type:r,...e}=t;return e.label&&(e.label=e.label.trim()),e.file&&(e.file=e.file.name+":"+e.file.line+(e.file.column?":"+e.file.column:"")),this.#t(e)}};var m=class extends chunkZJMTPHZR_cjs.a{#t;#e;constructor(){super(),this.#t=c__default.default.stdout,this.#e=c__default.default.stderr;}setStdout(t){this.#t=t;}setStderr(t){this.#e=t;}_log(t,r){let e=["error","warn"].includes(r)?this.#e:this.#t;chunkXQP4GKQU_cjs.c(t+`
15
+ `);}};var p=class extends s{#t;constructor(t){super({compress:"gzip",interval:"1d",size:"10M",...t});}setStringify(t){this.#t=t;}_formatMessage(t){let{type:r,...e}=t;return e.label&&(e.label=e.label.trim()),e.file&&(e.file=e.file.name+":"+e.file.line+(e.file.column?":"+e.file.column:"")),this.#t(e)}};var m=class extends chunkZJMTPHZR_cjs.a{#t;#e;constructor(){super(),this.#t=c__default.default.stdout,this.#e=c__default.default.stderr;}setStdout(t){this.#t=t;}setStderr(t){this.#e=t;}_log(t,r){let e=["error","warn"].includes(r)?this.#e:this.#t;chunkK4LLYFBH_cjs.c(t+`
16
16
  `,e);}};
17
17
 
18
18
  Object.defineProperty(exports, 'PrettyReporter', {
19
19
  enumerable: true,
20
- get: function () { return chunkXQP4GKQU_cjs.d; }
20
+ get: function () { return chunkK4LLYFBH_cjs.d; }
21
21
  });
22
22
  exports.AbstractFileReporter = s;
23
23
  exports.JsonFileReporter = p;
@@ -1,5 +1,5 @@
1
- import { c } from './chunk-JGZNXQSY.js';
2
- export { d as PrettyReporter } from './chunk-JGZNXQSY.js';
1
+ import { c } from './chunk-XCDBMDTZ.js';
2
+ export { d as PrettyReporter } from './chunk-XCDBMDTZ.js';
3
3
  import { a } from './chunk-TAH23BHM.js';
4
4
  import './chunk-ZB7IIFHO.js';
5
5
  import './chunk-NF47XQ47.js';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@visulima/pail",
3
- "version": "1.1.3",
3
+ "version": "1.1.5",
4
4
  "description": "Find a file or directory by walking up parent directories.",
5
5
  "keywords": [
6
6
  "anolilab",
@@ -187,7 +187,7 @@
187
187
  "@anolilab/eslint-config": "^15.0.3",
188
188
  "@anolilab/prettier-config": "^5.0.14",
189
189
  "@anolilab/semantic-release-preset": "^8.0.3",
190
- "@babel/core": "^7.24.3",
190
+ "@babel/core": "^7.24.4",
191
191
  "@rushstack/eslint-plugin-security": "^0.8.1",
192
192
  "@secretlint/secretlint-rule-preset-recommend": "^8.1.2",
193
193
  "@total-typescript/ts-reset": "^0.5.1",
@@ -200,18 +200,18 @@
200
200
  "eslint-plugin-etc": "^2.0.3",
201
201
  "eslint-plugin-import": "npm:eslint-plugin-i@^2.29.1",
202
202
  "eslint-plugin-mdx": "^3.1.5",
203
- "eslint-plugin-vitest": "^0.3.26",
203
+ "eslint-plugin-vitest": "^0.4.1",
204
204
  "eslint-plugin-vitest-globals": "^1.5.0",
205
205
  "prettier": "^3.2.5",
206
206
  "rimraf": "^5.0.5",
207
207
  "rotating-file-stream": "^3.2.1",
208
208
  "secretlint": "8.1.2",
209
- "semantic-release": "^23.0.5",
210
- "sort-package-json": "^2.8.0",
209
+ "semantic-release": "^23.0.7",
210
+ "sort-package-json": "^2.10.0",
211
211
  "string-length": "^6.0.0",
212
212
  "terminal-size": "^4.0.0",
213
213
  "tsup": "^8.0.2",
214
- "typescript": "^5.4.3",
214
+ "typescript": "^5.4.4",
215
215
  "vitest": "^1.4.0",
216
216
  "wrap-ansi": "^9.0.0"
217
217
  },
@@ -1,13 +0,0 @@
1
- 'use strict';
2
-
3
- var chunkN2UPJYJR_cjs = require('./chunk-N2UPJYJR.cjs');
4
- var chunkQINSQ6TU_cjs = require('./chunk-QINSQ6TU.cjs');
5
- var safeStableStringify = require('safe-stable-stringify');
6
-
7
- var u=class{log(e){let{context:r=[],message:t,type:o}=e;chunkN2UPJYJR_cjs.a(o.level)(t,...r);}};var w=s=>s===void 0?[]:Array.isArray(s)?s:[s];var v=(s,e)=>{let r={...s};return Object.keys(e).forEach(t=>{r[t]={...r[t],...e[t]};}),r};var x=(s,e)=>s.length>=e?s:s.padEnd(e);var P={badge:void 0,context:void 0,error:void 0,label:void 0,message:void 0,prefix:void 0,repeated:void 0,scope:void 0,suffix:void 0},L=class{timersMap;countMap;seqTimers;lastLog;logLevels;disabled;scopeName;types;longestLabel;processors;generalLogLevel;reporters;throttle;throttleMin;stringify;groups;startTimerMessage;endTimerMessage;rawReporter;constructor(e){this.throttle=e.throttle??1e3,this.throttleMin=e.throttleMin??5,this.stringify=safeStableStringify.configure({strict:!0}),this.startTimerMessage=e.messages?.timerStart??"Initialized timer...",this.endTimerMessage=e.messages?.timerEnd??"Timer run for:",this.types=v(chunkQINSQ6TU_cjs.b,e.types??{}),this.longestLabel=chunkQINSQ6TU_cjs.c(this.types),this.logLevels={...chunkQINSQ6TU_cjs.a,...e.logLevels},this.generalLogLevel=this._normalizeLogLevel(e.logLevel),this.reporters=new Set,this.processors=new Set,this.disabled=e.disabled??!1,this.scopeName=w(e.scope).filter(Boolean),this.timersMap=new Map,this.countMap=new Map,this.groups=[],this.seqTimers=new Set;for(let r in this.types)this[r]=this._logger.bind(this,r,!1);this.lastLog={},Array.isArray(e.reporters)&&this.registerReporters(e.reporters),this.rawReporter=this.extendReporter(e.rawReporter??new u),Array.isArray(e.processors)&&this.registerProcessors(e.processors);}wrapConsole(){for(let e in this.types)console["__"+e]||(console["__"+e]=console[e]),console[e]=this[e].log;}restoreConsole(){for(let e in this.types)console["__"+e]&&(console[e]=console["__"+e],delete console["__"+e]);}wrapException(){process.on("uncaughtException",e=>{this.error(e);}),process.on("unhandledRejection",e=>{this.error(e);});}disable(){this.disabled=!0;}enable(){this.disabled=!1;}isEnabled(){return !this.disabled}scope(...e){if(e.length===0)throw new Error("No scope name was defined.");return this.scopeName=e.flat(),this}unscope(){this.scopeName=[];}time(e="default"){this.seqTimers.has(e)?this._logger("warn",!1,{message:"Timer '"+e+"' already exists",prefix:e}):(this.seqTimers.add(e),this.timersMap.set(e,Date.now()),this._logger("start",!1,{message:this.startTimerMessage,prefix:e}));}timeLog(e,...r){if(!e&&this.seqTimers.size>0&&(e=[...this.seqTimers].pop()),e&&this.timersMap.has(e)){let t=Date.now()-this.timersMap.get(e);this._logger("info",!1,{context:r,message:t<1e3?t+" ms":(t/1e3).toFixed(2)+" s",prefix:e});}else this._logger("warn",!1,{context:r,message:"Timer not found",prefix:e});}timeEnd(e){if(!e&&this.seqTimers.size>0&&(e=[...this.seqTimers].pop()),e&&this.timersMap.has(e)){let r=Date.now()-this.timersMap.get(e);this.timersMap.delete(e),this._logger("stop",!1,{message:this.endTimerMessage+" "+(r<1e3?r+" ms":(r/1e3).toFixed(2)+" s"),prefix:e});}}group(e="console.group"){typeof window>"u"?console.group(e):this.groups.push(e);}groupEnd(){typeof window>"u"?console.groupEnd():this.groups.pop();}count(e="default"){let r=this.countMap.get(e)??0;this.countMap.set(e,r+1),this._logger("log",!1,{message:e+": "+(r+1),prefix:e});}countReset(e="default"){this.countMap.has(e)?this.countMap.delete(e):this._logger("warn",!1,{message:"Count for "+e+" does not exist",prefix:e});}clear(){console.clear();}raw(e,...r){this.disabled||this._logger("log",!0,{context:r,message:e});}extendReporter(e){return typeof e.setLoggerTypes=="function"&&e.setLoggerTypes(this.types),typeof e.setStringify=="function"&&e.setStringify(this.stringify),e}registerReporters(e){for(let r of e)this.reporters.add(this.extendReporter(r));}_report(e,r){if(r)this.rawReporter.log(Object.freeze(e));else for(let t of this.reporters)t.log(Object.freeze(e));}registerProcessors(e){for(let r of e)typeof r.setStringify=="function"&&r.setStringify(this.stringify),this.processors.add(r);}_normalizeLogLevel(e){return e&&this.logLevels[e]?e:"debug"}_buildMeta(e,r,...t){let o={...P};if(o.type={level:r.logLevel,name:e},o.groups=this.groups,o.scope=this.scopeName,o.date=new Date,t.length===1&&typeof t[0]=="object"&&t[0]!==null)if(t[0]instanceof Error)o.error=t[0];else if("message"in t[0]){let{context:i,message:c,prefix:d,suffix:n}=t[0];i&&(o.context=i),d&&(o.prefix=d),n&&(o.suffix=n),o.message=c;}else o.message=t[0];else t.length>1&&typeof t[0]=="string"?(o.message=t[0],o.context=t.slice(1)):o.message=t[0];return r.logLevel==="trace"&&(o.traceError=new Error("Trace")),r.badge&&(o.badge=x(r.badge,r.badge.length+1)),r.label&&(o.label=r.label),o}_logger(e,r,...t){if(this.disabled)return;let o=this._normalizeLogLevel(this.types[e].logLevel);if(this.logLevels[o]>=this.logLevels[this.generalLogLevel]){let i=this._buildMeta(e,this.types[e],...t),c=(n=!1)=>{let p=(this.lastLog.count||0)-this.throttleMin;if(this.lastLog.object&&p>0){let f={...this.lastLog.object};p>1&&(f.repeated=p),this._report(f,r),this.lastLog.count=1;}if(n){for(let f of this.processors)i={...f.process(i)};this.lastLog.object=i,this._report(i,r);}};clearTimeout(this.lastLog.timeout);let d=this.lastLog.time&&i.date?new Date(i.date).getTime()-this.lastLog.time.getTime():0;if(this.lastLog.time=new Date(i.date),d<this.throttle)try{let n=JSON.stringify([i.label,i.scope,i.type,i.message,i.prefix,i.suffix,i.context]),p=this.lastLog.serialized===n;if(this.lastLog.serialized=n,p&&(this.lastLog.count=(this.lastLog.count||0)+1,this.lastLog.count>this.throttleMin)){this.lastLog.timeout=setTimeout(c,this.throttle);return}}catch{}c(!0);}}},V=L;var l=Symbol("circular-reference-tag"),y=Symbol("raw-error-ref"),E=Object.create({},{aggregateErrors:{enumerable:!0,value:void 0,writable:!0},cause:{enumerable:!0,value:void 0,writable:!0},code:{enumerable:!0,value:void 0,writable:!0},message:{enumerable:!0,value:void 0,writable:!0},name:{enumerable:!0,value:void 0,writable:!0},raw:{enumerable:!1,get(){return this[y]},set(s){this[y]=s;}},stack:{enumerable:!0,value:void 0,writable:!0}});Object.defineProperty(E,y,{value:{},writable:!0});var M=E;var g=(s,e={})=>{s[l]=void 0;let r=Object.create(M);r.name=Object.prototype.toString.call(s.constructor)==="[object Function]"?s.constructor.name:s.name,r.message=s.message,r.stack=s.stack,Array.isArray(s.errors)&&(r.aggregateErrors=s.errors.map(t=>g(t,e))),s.cause instanceof Error&&!Object.prototype.hasOwnProperty.call(s.cause,l)&&(r.cause=g(s.cause,e));for(let t in s)if(r[t]===void 0){let o=s[t];if(o instanceof Error)Object.prototype.hasOwnProperty.call(o,l)||(r[t]=g(o,e));else if(typeof o=="function")r[t]="[Function: "+(o.name||"anonymous");else try{r[t]=o;}catch{}}return delete s[l],r.raw=s,r};var R=class{_options;constructor(e={}){this._options={maxDepth:Number.POSITIVE_INFINITY,useToJSON:!0,...e};}process(e){return e.error&&(e.error=g(e.error,this._options)),e}};
8
-
9
- exports.a = L;
10
- exports.b = V;
11
- exports.c = R;
12
- //# sourceMappingURL=out.js.map
13
- //# sourceMappingURL=chunk-2SZMC2SJ.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/pail.browser.ts","../src/reporter/raw/raw.browser.ts","../src/util/arrayify.ts","../src/util/merge-types.ts","../src/util/pad-end.ts","../src/processor/error/error-proto.ts","../src/processor/error/error-with-cause-serializer.ts","../src/processor/error/error-processor.ts"],"names":["stringifyConfigure","RawReporter","meta","context","message","type","writeConsoleLogBasedOnLevel","arrayify","x","mergeTypes","standard","custom","types","padEnd","string_","targetLength","EMPTY_META","PailBrowserImpl","options","LOG_TYPES","getLongestLabel","EXTENDED_RFC_5424_LOG_LEVELS","error","name","label","data","span","current","arguments_","reporter","reporters","raw","processors","processor","level","typeName","prefix","suffix","messageObject","logLevel","resolveLog","newLog","repeated","lastMeta","diffTime","serializedLog","isSameLog","PailBrowser","seen","rawSymbol","errorProto","value","ErrorProto","errorWithCauseSerializer","protoError","error_","key","ErrorProcessor"],"mappings":"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","sourcesContent":["import type { stringify } from \"safe-stable-stringify\";\nimport { configure as stringifyConfigure } from \"safe-stable-stringify\";\n\nimport { EXTENDED_RFC_5424_LOG_LEVELS, LOG_TYPES } from \"./constants\";\nimport { RawReporter } from \"./reporter/raw/raw.browser\";\nimport type {\n ConstructorOptions,\n DefaultLogTypes,\n ExtendedRfc5424LogLevels,\n LiteralUnion,\n LoggerConfiguration,\n LoggerFunction,\n LoggerTypesAwareReporter,\n LoggerTypesConfig,\n Message,\n Meta,\n Primitive,\n Processor,\n Reporter,\n StringifyAwareProcessor,\n StringifyAwareReporter,\n} from \"./types\";\nimport { arrayify } from \"./util/arrayify\";\nimport { getLongestLabel } from \"./util/get-longest-label\";\nimport { mergeTypes } from \"./util/merge-types\";\nimport { padEnd } from \"./util/pad-end\";\n\nconst EMPTY_META = {\n badge: undefined,\n context: undefined,\n error: undefined,\n label: undefined,\n message: undefined,\n prefix: undefined,\n repeated: undefined,\n scope: undefined,\n suffix: undefined,\n};\n\nexport class PailBrowserImpl<T extends string = never, L extends string = never> {\n protected timersMap: Map<string, number>;\n\n protected countMap: Map<string, number>;\n\n protected seqTimers: Set<string>;\n\n protected readonly lastLog: {\n count?: number;\n object?: Meta<L>;\n serialized?: string;\n time?: Date;\n timeout?: ReturnType<typeof setTimeout>;\n };\n\n protected readonly logLevels: Record<string, number>;\n\n protected disabled: boolean;\n\n protected scopeName: string[];\n\n protected readonly types: LoggerTypesConfig<LiteralUnion<DefaultLogTypes, T>, L>;\n\n protected readonly longestLabel: string;\n\n protected readonly processors: Set<Processor<L>>;\n\n protected readonly generalLogLevel: LiteralUnion<ExtendedRfc5424LogLevels, L>;\n\n protected reporters: Set<Reporter<L>>;\n\n protected readonly throttle: number;\n\n protected readonly throttleMin: number;\n\n protected readonly stringify: typeof stringify;\n\n protected groups: string[];\n\n protected readonly startTimerMessage: string;\n\n protected readonly endTimerMessage: string;\n\n protected rawReporter: Reporter<L>;\n\n public constructor(options: ConstructorOptions<T, L>) {\n this.throttle = options.throttle ?? 1000;\n this.throttleMin = options.throttleMin ?? 5;\n\n this.stringify = stringifyConfigure({\n strict: true,\n });\n\n this.startTimerMessage = options.messages?.timerStart ?? \"Initialized timer...\";\n this.endTimerMessage = options.messages?.timerEnd ?? \"Timer run for:\";\n this.types = mergeTypes<L, T>(LOG_TYPES, (options.types ?? {}) as LoggerTypesConfig<LiteralUnion<DefaultLogTypes, T>, L>);\n this.longestLabel = getLongestLabel<L, T>(this.types);\n\n this.logLevels = { ...EXTENDED_RFC_5424_LOG_LEVELS, ...options.logLevels };\n this.generalLogLevel = this._normalizeLogLevel(options.logLevel);\n\n this.reporters = new Set();\n this.processors = new Set();\n\n this.disabled = options.disabled ?? false;\n\n this.scopeName = arrayify(options.scope).filter(Boolean) as string[];\n\n this.timersMap = new Map();\n this.countMap = new Map();\n\n this.groups = [];\n\n this.seqTimers = new Set();\n\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax,guard-for-in\n for (const type in this.types) {\n // @ts-expect-error - dynamic property\n // eslint-disable-next-line security/detect-object-injection\n this[type] = this._logger.bind(this, type as T, false);\n }\n\n // Track of last log\n this.lastLog = {};\n\n if (Array.isArray(options.reporters)) {\n this.registerReporters(options.reporters);\n }\n\n this.rawReporter = this.extendReporter(options.rawReporter ?? new RawReporter<L>());\n\n if (Array.isArray(options.processors)) {\n this.registerProcessors(options.processors);\n }\n }\n\n public wrapConsole(): void {\n // eslint-disable-next-line guard-for-in,no-loops/no-loops,no-restricted-syntax\n for (const type in this.types) {\n // Backup original value\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if (!(console as any)[\"__\" + type]) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any,security/detect-object-injection\n (console as any)[\"__\" + type] = (console as any)[type];\n }\n // Override\n // @TODO: Fix typings\n // @ts-expect-error - dynamic property\n // eslint-disable-next-line @typescript-eslint/no-explicit-any,security/detect-object-injection\n (console as any)[type] = (this as unknown as PailBrowserImpl<T, L>)[type as keyof PailBrowserImpl<T, L>].log;\n }\n }\n\n public restoreConsole(): void {\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax\n for (const type in this.types) {\n // Restore if backup is available\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if ((console as any)[\"__\" + type]) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any,security/detect-object-injection\n (console as any)[type] = (console as any)[\"__\" + type];\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any,@typescript-eslint/no-dynamic-delete\n delete (console as any)[\"__\" + type];\n }\n }\n }\n\n public wrapException(): void {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n process.on(\"uncaughtException\", (error: any) => {\n // @TODO: Fix typings\n // @ts-expect-error - dynamic property\n (this as unknown as PailBrowserImpl<T, L>).error(error);\n });\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n process.on(\"unhandledRejection\", (error: any) => {\n // @TODO: Fix typings\n // @ts-expect-error - dynamic property\n (this as unknown as PailBrowserImpl<T, L>).error(error);\n });\n }\n\n /**\n * Disables logging\n */\n public disable(): void {\n this.disabled = true;\n }\n\n /**\n * Enables logging\n */\n public enable(): void {\n this.disabled = false;\n }\n\n public isEnabled(): boolean {\n return !this.disabled;\n }\n\n public scope<N extends string = T>(...name: string[]): PailBrowserType<N, L> {\n if (name.length === 0) {\n throw new Error(\"No scope name was defined.\");\n }\n\n this.scopeName = name.flat();\n\n return this as unknown as PailBrowserType<N, L>;\n }\n\n public unscope(): void {\n this.scopeName = [];\n }\n\n public time(label = \"default\"): void {\n if (this.seqTimers.has(label)) {\n this._logger(\"warn\", false, {\n message: \"Timer '\" + label + \"' already exists\",\n prefix: label,\n });\n } else {\n this.seqTimers.add(label);\n this.timersMap.set(label, Date.now());\n\n this._logger(\"start\", false, {\n message: this.startTimerMessage,\n prefix: label,\n });\n }\n }\n\n public timeLog(label?: string, ...data: unknown[]): void {\n if (!label && this.seqTimers.size > 0) {\n // eslint-disable-next-line no-param-reassign\n label = [...this.seqTimers].pop();\n }\n\n if (label && this.timersMap.has(label)) {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const span = Date.now() - this.timersMap.get(label)!;\n\n this._logger(\"info\", false, {\n context: data,\n message: span < 1000 ? span + \" ms\" : (span / 1000).toFixed(2) + \" s\",\n prefix: label,\n });\n } else {\n this._logger(\"warn\", false, {\n context: data,\n message: \"Timer not found\",\n prefix: label,\n });\n }\n }\n\n public timeEnd(label?: string): void {\n if (!label && this.seqTimers.size > 0) {\n // eslint-disable-next-line no-param-reassign\n label = [...this.seqTimers].pop();\n }\n\n if (label && this.timersMap.has(label)) {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const span = Date.now() - this.timersMap.get(label)!;\n\n this.timersMap.delete(label);\n\n this._logger(\"stop\", false, {\n message: this.endTimerMessage + \" \" + (span < 1000 ? span + \" ms\" : (span / 1000).toFixed(2) + \" s\"),\n prefix: label,\n });\n }\n }\n\n public group(label = \"console.group\"): void {\n if (typeof window === \"undefined\") {\n // eslint-disable-next-line no-console\n console.group(label);\n } else {\n this.groups.push(label);\n }\n }\n\n public groupEnd(): void {\n if (typeof window === \"undefined\") {\n // eslint-disable-next-line no-console\n console.groupEnd();\n } else {\n this.groups.pop();\n }\n }\n\n public count(label = \"default\"): void {\n const current = this.countMap.get(label) ?? 0;\n\n this.countMap.set(label, current + 1);\n\n this._logger(\"log\", false, {\n message: label + \": \" + (current + 1),\n prefix: label,\n });\n }\n\n public countReset(label = \"default\"): void {\n if (this.countMap.has(label)) {\n this.countMap.delete(label);\n } else {\n this._logger(\"warn\", false, {\n message: \"Count for \" + label + \" does not exist\",\n prefix: label,\n });\n }\n }\n\n // eslint-disable-next-line class-methods-use-this\n public clear(): void {\n // eslint-disable-next-line no-console\n console.clear();\n }\n\n public raw(message: string, ...arguments_: unknown[]): void {\n if (this.disabled) {\n return;\n }\n\n this._logger(\"log\", true, {\n context: arguments_,\n message,\n });\n }\n\n protected extendReporter(reporter: Reporter<L>): Reporter<L> {\n if (typeof (reporter as LoggerTypesAwareReporter<T, L>).setLoggerTypes === \"function\") {\n (reporter as LoggerTypesAwareReporter<T, L>).setLoggerTypes(this.types);\n }\n\n if (typeof (reporter as StringifyAwareReporter<L>).setStringify === \"function\") {\n (reporter as StringifyAwareReporter<L>).setStringify(this.stringify);\n }\n\n return reporter;\n }\n\n protected registerReporters(reporters: Reporter<L>[]): void {\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax\n for (const reporter of reporters) {\n this.reporters.add(this.extendReporter(reporter));\n }\n }\n\n private _report(meta: Meta<L>, raw: boolean): void {\n if (raw) {\n this.rawReporter.log(Object.freeze(meta));\n } else {\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax\n for (const reporter of this.reporters) {\n reporter.log(Object.freeze(meta));\n }\n }\n }\n\n private registerProcessors(processors: Processor<L>[]): void {\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax\n for (const processor of processors) {\n if (typeof (processor as StringifyAwareProcessor<L>).setStringify === \"function\") {\n (processor as StringifyAwareProcessor<L>).setStringify(this.stringify);\n }\n\n this.processors.add(processor as Processor<L>);\n }\n }\n\n private _normalizeLogLevel(level: LiteralUnion<ExtendedRfc5424LogLevels, L> | undefined): LiteralUnion<ExtendedRfc5424LogLevels, L> {\n // eslint-disable-next-line security/detect-object-injection\n return level && this.logLevels[level] ? level : \"debug\";\n }\n\n // eslint-disable-next-line sonarjs/cognitive-complexity,@typescript-eslint/no-explicit-any\n private _buildMeta(typeName: string, type: Partial<LoggerConfiguration<L>>, ...arguments_: any[]): Meta<L> {\n const meta = { ...EMPTY_META } as Meta<L>;\n\n meta.type = {\n level: type.logLevel as LiteralUnion<ExtendedRfc5424LogLevels, L>,\n name: typeName,\n };\n\n meta.groups = this.groups;\n meta.scope = this.scopeName;\n meta.date = new Date();\n\n if (arguments_.length === 1 && typeof arguments_[0] === \"object\" && arguments_[0] !== null) {\n if (arguments_[0] instanceof Error) {\n // eslint-disable-next-line prefer-destructuring\n meta.error = arguments_[0];\n } else if (\"message\" in arguments_[0]) {\n const { context, message, prefix, suffix } = arguments_[0] as Message;\n\n if (context) {\n meta.context = context;\n }\n\n if (prefix) {\n meta.prefix = prefix;\n }\n\n if (suffix) {\n meta.suffix = suffix;\n }\n\n meta.message = message;\n } else {\n meta.message = arguments_[0] as Primitive | ReadonlyArray<unknown> | Record<PropertyKey, unknown>;\n }\n } else if (arguments_.length > 1 && typeof arguments_[0] === \"string\") {\n meta.message = arguments_[0] as string;\n meta.context = arguments_.slice(1);\n } else {\n // eslint-disable-next-line prefer-destructuring\n meta.message = arguments_[0];\n }\n\n if (type.logLevel === \"trace\") {\n meta.traceError = new Error(\"Trace\");\n }\n\n if (type.badge) {\n meta.badge = padEnd(type.badge, type.badge.length + 1);\n }\n\n if (type.label) {\n meta.label = type.label;\n }\n\n return meta;\n }\n\n // eslint-disable-next-line sonarjs/cognitive-complexity,@typescript-eslint/no-explicit-any\n private _logger(type: LiteralUnion<DefaultLogTypes, T>, raw: boolean, ...messageObject: any[]): void {\n if (this.disabled) {\n return;\n }\n\n // eslint-disable-next-line security/detect-object-injection\n const logLevel = this._normalizeLogLevel(this.types[type].logLevel);\n\n // eslint-disable-next-line security/detect-object-injection\n if ((this.logLevels[logLevel] as number) >= (this.logLevels[this.generalLogLevel] as number)) {\n // eslint-disable-next-line security/detect-object-injection\n let meta = this._buildMeta(type, this.types[type], ...messageObject);\n\n /**\n * @param newLog false if the throttle expired and we don't want to log a duplicate\n */\n const resolveLog = (newLog = false) => {\n // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n const repeated = (this.lastLog.count || 0) - this.throttleMin;\n\n if (this.lastLog.object && repeated > 0) {\n const lastMeta = { ...this.lastLog.object };\n\n if (repeated > 1) {\n lastMeta.repeated = repeated;\n }\n\n this._report(lastMeta, raw);\n\n this.lastLog.count = 1;\n }\n\n if (newLog) {\n // Apply global processors\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax\n for (const processor of this.processors) {\n meta = { ...processor.process(meta) };\n }\n\n this.lastLog.object = meta;\n\n this._report(meta, raw);\n }\n };\n\n clearTimeout(this.lastLog.timeout);\n\n const diffTime = this.lastLog.time && meta.date ? new Date(meta.date as Date | string).getTime() - this.lastLog.time.getTime() : 0;\n\n this.lastLog.time = new Date(meta.date as Date | string);\n\n if (diffTime < this.throttle) {\n try {\n const serializedLog = JSON.stringify([meta.label, meta.scope, meta.type, meta.message, meta.prefix, meta.suffix, meta.context]);\n const isSameLog = this.lastLog.serialized === serializedLog;\n\n this.lastLog.serialized = serializedLog;\n\n if (isSameLog) {\n // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n this.lastLog.count = (this.lastLog.count || 0) + 1;\n\n if (this.lastLog.count > this.throttleMin) {\n // Auto-resolve when throttle is timed out\n this.lastLog.timeout = setTimeout(resolveLog, this.throttle);\n\n return; // SPAM!\n }\n }\n } catch {\n // Circular References\n }\n }\n\n resolveLog(true);\n }\n }\n}\n\nexport type PailBrowserType<T extends string = never, L extends string = never> = PailBrowserImpl<T, L> &\n Record<DefaultLogTypes, LoggerFunction> &\n Record<T, LoggerFunction> &\n (new<TC extends string = never, LC extends string = never>(options?: ConstructorOptions<TC, LC>) => PailBrowserType<TC, LC>);\n\nexport type PailConstructor<T extends string = never, L extends string = never> = new (options?: ConstructorOptions<T, L>) => PailBrowserType<T, L>;\n\nexport const PailBrowser = PailBrowserImpl as unknown as PailBrowserType;\n","import type { ReadonlyMeta, Reporter } from \"../../types\";\nimport { writeConsoleLogBasedOnLevel } from \"../../util/write-console-log\";\n\nexport class RawReporter<L extends string = never> implements Reporter<L> {\n // eslint-disable-next-line class-methods-use-this\n public log(meta: ReadonlyMeta<L>): void {\n const { context = [], message, type } = meta;\n\n const consoleLogFunction = writeConsoleLogBasedOnLevel(type.level);\n\n consoleLogFunction(message, ...context);\n }\n}\n","export const arrayify = <T>(x: T | T[]): T[] => {\n if (x === undefined) {\n return [] as T[];\n }\n\n return Array.isArray(x) ? x : ([x] as T[]);\n};\n","import type { DefaultLoggerTypes, DefaultLogTypes, LiteralUnion, LoggerTypesConfig } from \"../types\";\n\nexport const mergeTypes = <L extends string, T extends string>(\n standard: DefaultLoggerTypes<L>,\n custom: LoggerTypesConfig<T, L>,\n): LoggerTypesConfig<LiteralUnion<DefaultLogTypes, T>, L> => {\n const types = { ...standard } as LoggerTypesConfig<LiteralUnion<DefaultLogTypes, T>, L>;\n\n Object.keys(custom).forEach((type) => {\n types[type as T] = { ...types[type as T], ...custom[type as T] };\n });\n\n return types;\n};\n","export const padEnd = (string_: string, targetLength: number): string => {\n if (string_.length >= targetLength) {\n return string_;\n }\n\n return string_.padEnd(targetLength);\n};\n","// eslint-disable-next-line import/exports-last\nexport const seen = Symbol(\"circular-reference-tag\");\n\n// eslint-disable-next-line import/exports-last,import/no-unused-modules\nexport const rawSymbol = Symbol(\"raw-error-ref\");\n\nconst errorProto = Object.create(\n {},\n {\n aggregateErrors: {\n enumerable: true,\n value: undefined,\n writable: true,\n },\n cause: {\n enumerable: true,\n value: undefined,\n writable: true,\n },\n code: {\n enumerable: true,\n value: undefined,\n writable: true,\n },\n message: {\n enumerable: true,\n value: undefined,\n writable: true,\n },\n name: {\n enumerable: true,\n value: undefined,\n writable: true,\n },\n raw: {\n enumerable: false,\n get() {\n // eslint-disable-next-line security/detect-object-injection\n return this[rawSymbol];\n },\n set(value) {\n // eslint-disable-next-line security/detect-object-injection\n this[rawSymbol] = value;\n },\n },\n stack: {\n enumerable: true,\n value: undefined,\n writable: true,\n },\n },\n) as SerializedError;\n\nObject.defineProperty(errorProto, rawSymbol, {\n value: {},\n writable: true,\n});\n\nexport const ErrorProto = errorProto;\n\nexport type SerializedError<ErrorType = Error> = Record<PropertyKey, unknown> & {\n aggregateErrors?: SerializedError<ErrorType>[];\n cause?: unknown;\n code?: string;\n message: string;\n name: string;\n raw?: ErrorType;\n stack?: string;\n};\n","import type { SerializedError } from \"./error-proto\";\nimport { ErrorProto, seen } from \"./error-proto\";\n\ntype CauseError = Error & {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n cause: any;\n};\n\ntype Options = {\n readonly maxDepth?: number;\n readonly useToJSON?: boolean;\n};\n\n/**\n * Serialize an `Error` object into a plain object.\n *\n * - Non-error values are passed through.\n * - Custom properties are preserved.\n * - Buffer properties are replaced with `[object Buffer]`.\n * - Circular references are handled.\n * - If the input object has a `.toJSON()` method, then it's called instead of serializing the object's properties.\n * - It's up to `.toJSON()` implementation to handle circular references and enumerability of the properties.\n */\n// eslint-disable-next-line sonarjs/cognitive-complexity\nexport const errorWithCauseSerializer = (error: AggregateError | Error, options: Options = {}): SerializedError => {\n // @ts-expect-error - dynamic property\n // eslint-disable-next-line no-param-reassign\n error[seen as keyof Error] = undefined; // tag to prevent re-looking at this\n\n const protoError = Object.create(ErrorProto as object) as SerializedError;\n\n protoError.name = Object.prototype.toString.call(error.constructor) === \"[object Function]\" ? error.constructor.name : error.name;\n protoError.message = error.message;\n protoError.stack = error.stack;\n\n if (Array.isArray((error as AggregateError).errors)) {\n protoError.aggregateErrors = (error as AggregateError).errors.map((error_: AggregateError | Error) => errorWithCauseSerializer(error_, options));\n }\n\n // Handle aggregate errors\n if ((error as CauseError).cause instanceof Error && !Object.prototype.hasOwnProperty.call((error as CauseError).cause, seen as PropertyKey)) {\n protoError.cause = errorWithCauseSerializer((error as CauseError).cause, options);\n }\n\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax\n for (const key in error) {\n // eslint-disable-next-line security/detect-object-injection\n if (protoError[key] === undefined) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const value = error[key as keyof Error] as any;\n\n if (value instanceof Error) {\n if (!Object.prototype.hasOwnProperty.call(value, seen as PropertyKey)) {\n // eslint-disable-next-line security/detect-object-injection\n protoError[key] = errorWithCauseSerializer(value, options);\n }\n } else if (typeof value === \"function\") {\n // eslint-disable-next-line security/detect-object-injection\n protoError[key] = \"[Function: \" + (value.name || \"anonymous\");\n } else {\n // Gracefully handle non-configurable errors like `DOMException`.\n try {\n // eslint-disable-next-line security/detect-object-injection\n protoError[key] = value;\n } catch {\n /* empty */\n }\n }\n }\n }\n\n // eslint-disable-next-line no-param-reassign,@typescript-eslint/no-dynamic-delete\n delete error[seen as unknown as keyof Error]; // clean up tag in case err is serialized again later\n\n protoError.raw = error;\n\n return protoError;\n};\n","import type { Meta, Processor } from \"../../types\";\nimport type { SerializedError } from \"./error-proto\";\nimport { errorWithCauseSerializer } from \"./error-with-cause-serializer\";\n\ndeclare global {\n // eslint-disable-next-line @typescript-eslint/no-namespace\n namespace VisulimaPail {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n interface CustomMeta<L> {\n error: SerializedError | undefined;\n }\n }\n}\n\nexport class ErrorProcessor<L extends string = never> implements Processor<L> {\n private readonly _options: { maxDepth: number; useToJSON: boolean };\n\n public constructor(options: { maxDepth?: number; useToJSON?: boolean } = {}) {\n this._options = {\n maxDepth: Number.POSITIVE_INFINITY,\n useToJSON: true,\n ...options,\n };\n }\n\n public process(meta: Meta<L>): Meta<L> {\n if (meta.error) {\n // eslint-disable-next-line no-param-reassign\n meta.error = errorWithCauseSerializer(meta.error, this._options);\n }\n\n return meta;\n }\n}\n"]}
@@ -1,9 +0,0 @@
1
- import { a as a$1 } from './chunk-AFMDCM5W.js';
2
- import { b, c as c$1, a } from './chunk-NF47XQ47.js';
3
- import { configure } from 'safe-stable-stringify';
4
-
5
- var L=class{log(e){let{context:r=[],message:t,type:o}=e;a$1(o.level)(t,...r);}};var v=s=>s===void 0?[]:Array.isArray(s)?s:[s];var x=(s,e)=>{let r={...s};return Object.keys(e).forEach(t=>{r[t]={...r[t],...e[t]};}),r};var E=(s,e)=>s.length>=e?s:s.padEnd(e);var C={badge:void 0,context:void 0,error:void 0,label:void 0,message:void 0,prefix:void 0,repeated:void 0,scope:void 0,suffix:void 0},y=class{timersMap;countMap;seqTimers;lastLog;logLevels;disabled;scopeName;types;longestLabel;processors;generalLogLevel;reporters;throttle;throttleMin;stringify;groups;startTimerMessage;endTimerMessage;rawReporter;constructor(e){this.throttle=e.throttle??1e3,this.throttleMin=e.throttleMin??5,this.stringify=configure({strict:!0}),this.startTimerMessage=e.messages?.timerStart??"Initialized timer...",this.endTimerMessage=e.messages?.timerEnd??"Timer run for:",this.types=x(b,e.types??{}),this.longestLabel=c$1(this.types),this.logLevels={...a,...e.logLevels},this.generalLogLevel=this._normalizeLogLevel(e.logLevel),this.reporters=new Set,this.processors=new Set,this.disabled=e.disabled??!1,this.scopeName=v(e.scope).filter(Boolean),this.timersMap=new Map,this.countMap=new Map,this.groups=[],this.seqTimers=new Set;for(let r in this.types)this[r]=this._logger.bind(this,r,!1);this.lastLog={},Array.isArray(e.reporters)&&this.registerReporters(e.reporters),this.rawReporter=this.extendReporter(e.rawReporter??new L),Array.isArray(e.processors)&&this.registerProcessors(e.processors);}wrapConsole(){for(let e in this.types)console["__"+e]||(console["__"+e]=console[e]),console[e]=this[e].log;}restoreConsole(){for(let e in this.types)console["__"+e]&&(console[e]=console["__"+e],delete console["__"+e]);}wrapException(){process.on("uncaughtException",e=>{this.error(e);}),process.on("unhandledRejection",e=>{this.error(e);});}disable(){this.disabled=!0;}enable(){this.disabled=!1;}isEnabled(){return !this.disabled}scope(...e){if(e.length===0)throw new Error("No scope name was defined.");return this.scopeName=e.flat(),this}unscope(){this.scopeName=[];}time(e="default"){this.seqTimers.has(e)?this._logger("warn",!1,{message:"Timer '"+e+"' already exists",prefix:e}):(this.seqTimers.add(e),this.timersMap.set(e,Date.now()),this._logger("start",!1,{message:this.startTimerMessage,prefix:e}));}timeLog(e,...r){if(!e&&this.seqTimers.size>0&&(e=[...this.seqTimers].pop()),e&&this.timersMap.has(e)){let t=Date.now()-this.timersMap.get(e);this._logger("info",!1,{context:r,message:t<1e3?t+" ms":(t/1e3).toFixed(2)+" s",prefix:e});}else this._logger("warn",!1,{context:r,message:"Timer not found",prefix:e});}timeEnd(e){if(!e&&this.seqTimers.size>0&&(e=[...this.seqTimers].pop()),e&&this.timersMap.has(e)){let r=Date.now()-this.timersMap.get(e);this.timersMap.delete(e),this._logger("stop",!1,{message:this.endTimerMessage+" "+(r<1e3?r+" ms":(r/1e3).toFixed(2)+" s"),prefix:e});}}group(e="console.group"){typeof window>"u"?console.group(e):this.groups.push(e);}groupEnd(){typeof window>"u"?console.groupEnd():this.groups.pop();}count(e="default"){let r=this.countMap.get(e)??0;this.countMap.set(e,r+1),this._logger("log",!1,{message:e+": "+(r+1),prefix:e});}countReset(e="default"){this.countMap.has(e)?this.countMap.delete(e):this._logger("warn",!1,{message:"Count for "+e+" does not exist",prefix:e});}clear(){console.clear();}raw(e,...r){this.disabled||this._logger("log",!0,{context:r,message:e});}extendReporter(e){return typeof e.setLoggerTypes=="function"&&e.setLoggerTypes(this.types),typeof e.setStringify=="function"&&e.setStringify(this.stringify),e}registerReporters(e){for(let r of e)this.reporters.add(this.extendReporter(r));}_report(e,r){if(r)this.rawReporter.log(Object.freeze(e));else for(let t of this.reporters)t.log(Object.freeze(e));}registerProcessors(e){for(let r of e)typeof r.setStringify=="function"&&r.setStringify(this.stringify),this.processors.add(r);}_normalizeLogLevel(e){return e&&this.logLevels[e]?e:"debug"}_buildMeta(e,r,...t){let o={...C};if(o.type={level:r.logLevel,name:e},o.groups=this.groups,o.scope=this.scopeName,o.date=new Date,t.length===1&&typeof t[0]=="object"&&t[0]!==null)if(t[0]instanceof Error)o.error=t[0];else if("message"in t[0]){let{context:i,message:d,prefix:f,suffix:n}=t[0];i&&(o.context=i),f&&(o.prefix=f),n&&(o.suffix=n),o.message=d;}else o.message=t[0];else t.length>1&&typeof t[0]=="string"?(o.message=t[0],o.context=t.slice(1)):o.message=t[0];return r.logLevel==="trace"&&(o.traceError=new Error("Trace")),r.badge&&(o.badge=E(r.badge,r.badge.length+1)),r.label&&(o.label=r.label),o}_logger(e,r,...t){if(this.disabled)return;let o=this._normalizeLogLevel(this.types[e].logLevel);if(this.logLevels[o]>=this.logLevels[this.generalLogLevel]){let i=this._buildMeta(e,this.types[e],...t),d=(n=!1)=>{let l=(this.lastLog.count||0)-this.throttleMin;if(this.lastLog.object&&l>0){let u={...this.lastLog.object};l>1&&(u.repeated=l),this._report(u,r),this.lastLog.count=1;}if(n){for(let u of this.processors)i={...u.process(i)};this.lastLog.object=i,this._report(i,r);}};clearTimeout(this.lastLog.timeout);let f=this.lastLog.time&&i.date?new Date(i.date).getTime()-this.lastLog.time.getTime():0;if(this.lastLog.time=new Date(i.date),f<this.throttle)try{let n=JSON.stringify([i.label,i.scope,i.type,i.message,i.prefix,i.suffix,i.context]),l=this.lastLog.serialized===n;if(this.lastLog.serialized=n,l&&(this.lastLog.count=(this.lastLog.count||0)+1,this.lastLog.count>this.throttleMin)){this.lastLog.timeout=setTimeout(d,this.throttle);return}}catch{}d(!0);}}},Y=y;var g=Symbol("circular-reference-tag"),m=Symbol("raw-error-ref"),M=Object.create({},{aggregateErrors:{enumerable:!0,value:void 0,writable:!0},cause:{enumerable:!0,value:void 0,writable:!0},code:{enumerable:!0,value:void 0,writable:!0},message:{enumerable:!0,value:void 0,writable:!0},name:{enumerable:!0,value:void 0,writable:!0},raw:{enumerable:!1,get(){return this[m]},set(s){this[m]=s;}},stack:{enumerable:!0,value:void 0,writable:!0}});Object.defineProperty(M,m,{value:{},writable:!0});var R=M;var c=(s,e={})=>{s[g]=void 0;let r=Object.create(R);r.name=Object.prototype.toString.call(s.constructor)==="[object Function]"?s.constructor.name:s.name,r.message=s.message,r.stack=s.stack,Array.isArray(s.errors)&&(r.aggregateErrors=s.errors.map(t=>c(t,e))),s.cause instanceof Error&&!Object.prototype.hasOwnProperty.call(s.cause,g)&&(r.cause=c(s.cause,e));for(let t in s)if(r[t]===void 0){let o=s[t];if(o instanceof Error)Object.prototype.hasOwnProperty.call(o,g)||(r[t]=c(o,e));else if(typeof o=="function")r[t]="[Function: "+(o.name||"anonymous");else try{r[t]=o;}catch{}}return delete s[g],r.raw=s,r};var S=class{_options;constructor(e={}){this._options={maxDepth:Number.POSITIVE_INFINITY,useToJSON:!0,...e};}process(e){return e.error&&(e.error=c(e.error,this._options)),e}};
6
-
7
- export { y as a, Y as b, S as c };
8
- //# sourceMappingURL=out.js.map
9
- //# sourceMappingURL=chunk-576JQ6DN.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/pail.browser.ts","../src/reporter/raw/raw.browser.ts","../src/util/arrayify.ts","../src/util/merge-types.ts","../src/util/pad-end.ts","../src/processor/error/error-proto.ts","../src/processor/error/error-with-cause-serializer.ts","../src/processor/error/error-processor.ts"],"names":["stringifyConfigure","RawReporter","meta","context","message","type","writeConsoleLogBasedOnLevel","arrayify","x","mergeTypes","standard","custom","types","padEnd","string_","targetLength","EMPTY_META","PailBrowserImpl","options","LOG_TYPES","getLongestLabel","EXTENDED_RFC_5424_LOG_LEVELS","error","name","label","data","span","current","arguments_","reporter","reporters","raw","processors","processor","level","typeName","prefix","suffix","messageObject","logLevel","resolveLog","newLog","repeated","lastMeta","diffTime","serializedLog","isSameLog","PailBrowser","seen","rawSymbol","errorProto","value","ErrorProto","errorWithCauseSerializer","protoError","error_","key","ErrorProcessor"],"mappings":"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","sourcesContent":["import type { stringify } from \"safe-stable-stringify\";\nimport { configure as stringifyConfigure } from \"safe-stable-stringify\";\n\nimport { EXTENDED_RFC_5424_LOG_LEVELS, LOG_TYPES } from \"./constants\";\nimport { RawReporter } from \"./reporter/raw/raw.browser\";\nimport type {\n ConstructorOptions,\n DefaultLogTypes,\n ExtendedRfc5424LogLevels,\n LiteralUnion,\n LoggerConfiguration,\n LoggerFunction,\n LoggerTypesAwareReporter,\n LoggerTypesConfig,\n Message,\n Meta,\n Primitive,\n Processor,\n Reporter,\n StringifyAwareProcessor,\n StringifyAwareReporter,\n} from \"./types\";\nimport { arrayify } from \"./util/arrayify\";\nimport { getLongestLabel } from \"./util/get-longest-label\";\nimport { mergeTypes } from \"./util/merge-types\";\nimport { padEnd } from \"./util/pad-end\";\n\nconst EMPTY_META = {\n badge: undefined,\n context: undefined,\n error: undefined,\n label: undefined,\n message: undefined,\n prefix: undefined,\n repeated: undefined,\n scope: undefined,\n suffix: undefined,\n};\n\nexport class PailBrowserImpl<T extends string = never, L extends string = never> {\n protected timersMap: Map<string, number>;\n\n protected countMap: Map<string, number>;\n\n protected seqTimers: Set<string>;\n\n protected readonly lastLog: {\n count?: number;\n object?: Meta<L>;\n serialized?: string;\n time?: Date;\n timeout?: ReturnType<typeof setTimeout>;\n };\n\n protected readonly logLevels: Record<string, number>;\n\n protected disabled: boolean;\n\n protected scopeName: string[];\n\n protected readonly types: LoggerTypesConfig<LiteralUnion<DefaultLogTypes, T>, L>;\n\n protected readonly longestLabel: string;\n\n protected readonly processors: Set<Processor<L>>;\n\n protected readonly generalLogLevel: LiteralUnion<ExtendedRfc5424LogLevels, L>;\n\n protected reporters: Set<Reporter<L>>;\n\n protected readonly throttle: number;\n\n protected readonly throttleMin: number;\n\n protected readonly stringify: typeof stringify;\n\n protected groups: string[];\n\n protected readonly startTimerMessage: string;\n\n protected readonly endTimerMessage: string;\n\n protected rawReporter: Reporter<L>;\n\n public constructor(options: ConstructorOptions<T, L>) {\n this.throttle = options.throttle ?? 1000;\n this.throttleMin = options.throttleMin ?? 5;\n\n this.stringify = stringifyConfigure({\n strict: true,\n });\n\n this.startTimerMessage = options.messages?.timerStart ?? \"Initialized timer...\";\n this.endTimerMessage = options.messages?.timerEnd ?? \"Timer run for:\";\n this.types = mergeTypes<L, T>(LOG_TYPES, (options.types ?? {}) as LoggerTypesConfig<LiteralUnion<DefaultLogTypes, T>, L>);\n this.longestLabel = getLongestLabel<L, T>(this.types);\n\n this.logLevels = { ...EXTENDED_RFC_5424_LOG_LEVELS, ...options.logLevels };\n this.generalLogLevel = this._normalizeLogLevel(options.logLevel);\n\n this.reporters = new Set();\n this.processors = new Set();\n\n this.disabled = options.disabled ?? false;\n\n this.scopeName = arrayify(options.scope).filter(Boolean) as string[];\n\n this.timersMap = new Map();\n this.countMap = new Map();\n\n this.groups = [];\n\n this.seqTimers = new Set();\n\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax,guard-for-in\n for (const type in this.types) {\n // @ts-expect-error - dynamic property\n // eslint-disable-next-line security/detect-object-injection\n this[type] = this._logger.bind(this, type as T, false);\n }\n\n // Track of last log\n this.lastLog = {};\n\n if (Array.isArray(options.reporters)) {\n this.registerReporters(options.reporters);\n }\n\n this.rawReporter = this.extendReporter(options.rawReporter ?? new RawReporter<L>());\n\n if (Array.isArray(options.processors)) {\n this.registerProcessors(options.processors);\n }\n }\n\n public wrapConsole(): void {\n // eslint-disable-next-line guard-for-in,no-loops/no-loops,no-restricted-syntax\n for (const type in this.types) {\n // Backup original value\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if (!(console as any)[\"__\" + type]) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any,security/detect-object-injection\n (console as any)[\"__\" + type] = (console as any)[type];\n }\n // Override\n // @TODO: Fix typings\n // @ts-expect-error - dynamic property\n // eslint-disable-next-line @typescript-eslint/no-explicit-any,security/detect-object-injection\n (console as any)[type] = (this as unknown as PailBrowserImpl<T, L>)[type as keyof PailBrowserImpl<T, L>].log;\n }\n }\n\n public restoreConsole(): void {\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax\n for (const type in this.types) {\n // Restore if backup is available\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if ((console as any)[\"__\" + type]) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any,security/detect-object-injection\n (console as any)[type] = (console as any)[\"__\" + type];\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any,@typescript-eslint/no-dynamic-delete\n delete (console as any)[\"__\" + type];\n }\n }\n }\n\n public wrapException(): void {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n process.on(\"uncaughtException\", (error: any) => {\n // @TODO: Fix typings\n // @ts-expect-error - dynamic property\n (this as unknown as PailBrowserImpl<T, L>).error(error);\n });\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n process.on(\"unhandledRejection\", (error: any) => {\n // @TODO: Fix typings\n // @ts-expect-error - dynamic property\n (this as unknown as PailBrowserImpl<T, L>).error(error);\n });\n }\n\n /**\n * Disables logging\n */\n public disable(): void {\n this.disabled = true;\n }\n\n /**\n * Enables logging\n */\n public enable(): void {\n this.disabled = false;\n }\n\n public isEnabled(): boolean {\n return !this.disabled;\n }\n\n public scope<N extends string = T>(...name: string[]): PailBrowserType<N, L> {\n if (name.length === 0) {\n throw new Error(\"No scope name was defined.\");\n }\n\n this.scopeName = name.flat();\n\n return this as unknown as PailBrowserType<N, L>;\n }\n\n public unscope(): void {\n this.scopeName = [];\n }\n\n public time(label = \"default\"): void {\n if (this.seqTimers.has(label)) {\n this._logger(\"warn\", false, {\n message: \"Timer '\" + label + \"' already exists\",\n prefix: label,\n });\n } else {\n this.seqTimers.add(label);\n this.timersMap.set(label, Date.now());\n\n this._logger(\"start\", false, {\n message: this.startTimerMessage,\n prefix: label,\n });\n }\n }\n\n public timeLog(label?: string, ...data: unknown[]): void {\n if (!label && this.seqTimers.size > 0) {\n // eslint-disable-next-line no-param-reassign\n label = [...this.seqTimers].pop();\n }\n\n if (label && this.timersMap.has(label)) {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const span = Date.now() - this.timersMap.get(label)!;\n\n this._logger(\"info\", false, {\n context: data,\n message: span < 1000 ? span + \" ms\" : (span / 1000).toFixed(2) + \" s\",\n prefix: label,\n });\n } else {\n this._logger(\"warn\", false, {\n context: data,\n message: \"Timer not found\",\n prefix: label,\n });\n }\n }\n\n public timeEnd(label?: string): void {\n if (!label && this.seqTimers.size > 0) {\n // eslint-disable-next-line no-param-reassign\n label = [...this.seqTimers].pop();\n }\n\n if (label && this.timersMap.has(label)) {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const span = Date.now() - this.timersMap.get(label)!;\n\n this.timersMap.delete(label);\n\n this._logger(\"stop\", false, {\n message: this.endTimerMessage + \" \" + (span < 1000 ? span + \" ms\" : (span / 1000).toFixed(2) + \" s\"),\n prefix: label,\n });\n }\n }\n\n public group(label = \"console.group\"): void {\n if (typeof window === \"undefined\") {\n // eslint-disable-next-line no-console\n console.group(label);\n } else {\n this.groups.push(label);\n }\n }\n\n public groupEnd(): void {\n if (typeof window === \"undefined\") {\n // eslint-disable-next-line no-console\n console.groupEnd();\n } else {\n this.groups.pop();\n }\n }\n\n public count(label = \"default\"): void {\n const current = this.countMap.get(label) ?? 0;\n\n this.countMap.set(label, current + 1);\n\n this._logger(\"log\", false, {\n message: label + \": \" + (current + 1),\n prefix: label,\n });\n }\n\n public countReset(label = \"default\"): void {\n if (this.countMap.has(label)) {\n this.countMap.delete(label);\n } else {\n this._logger(\"warn\", false, {\n message: \"Count for \" + label + \" does not exist\",\n prefix: label,\n });\n }\n }\n\n // eslint-disable-next-line class-methods-use-this\n public clear(): void {\n // eslint-disable-next-line no-console\n console.clear();\n }\n\n public raw(message: string, ...arguments_: unknown[]): void {\n if (this.disabled) {\n return;\n }\n\n this._logger(\"log\", true, {\n context: arguments_,\n message,\n });\n }\n\n protected extendReporter(reporter: Reporter<L>): Reporter<L> {\n if (typeof (reporter as LoggerTypesAwareReporter<T, L>).setLoggerTypes === \"function\") {\n (reporter as LoggerTypesAwareReporter<T, L>).setLoggerTypes(this.types);\n }\n\n if (typeof (reporter as StringifyAwareReporter<L>).setStringify === \"function\") {\n (reporter as StringifyAwareReporter<L>).setStringify(this.stringify);\n }\n\n return reporter;\n }\n\n protected registerReporters(reporters: Reporter<L>[]): void {\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax\n for (const reporter of reporters) {\n this.reporters.add(this.extendReporter(reporter));\n }\n }\n\n private _report(meta: Meta<L>, raw: boolean): void {\n if (raw) {\n this.rawReporter.log(Object.freeze(meta));\n } else {\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax\n for (const reporter of this.reporters) {\n reporter.log(Object.freeze(meta));\n }\n }\n }\n\n private registerProcessors(processors: Processor<L>[]): void {\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax\n for (const processor of processors) {\n if (typeof (processor as StringifyAwareProcessor<L>).setStringify === \"function\") {\n (processor as StringifyAwareProcessor<L>).setStringify(this.stringify);\n }\n\n this.processors.add(processor as Processor<L>);\n }\n }\n\n private _normalizeLogLevel(level: LiteralUnion<ExtendedRfc5424LogLevels, L> | undefined): LiteralUnion<ExtendedRfc5424LogLevels, L> {\n // eslint-disable-next-line security/detect-object-injection\n return level && this.logLevels[level] ? level : \"debug\";\n }\n\n // eslint-disable-next-line sonarjs/cognitive-complexity,@typescript-eslint/no-explicit-any\n private _buildMeta(typeName: string, type: Partial<LoggerConfiguration<L>>, ...arguments_: any[]): Meta<L> {\n const meta = { ...EMPTY_META } as Meta<L>;\n\n meta.type = {\n level: type.logLevel as LiteralUnion<ExtendedRfc5424LogLevels, L>,\n name: typeName,\n };\n\n meta.groups = this.groups;\n meta.scope = this.scopeName;\n meta.date = new Date();\n\n if (arguments_.length === 1 && typeof arguments_[0] === \"object\" && arguments_[0] !== null) {\n if (arguments_[0] instanceof Error) {\n // eslint-disable-next-line prefer-destructuring\n meta.error = arguments_[0];\n } else if (\"message\" in arguments_[0]) {\n const { context, message, prefix, suffix } = arguments_[0] as Message;\n\n if (context) {\n meta.context = context;\n }\n\n if (prefix) {\n meta.prefix = prefix;\n }\n\n if (suffix) {\n meta.suffix = suffix;\n }\n\n meta.message = message;\n } else {\n meta.message = arguments_[0] as Primitive | ReadonlyArray<unknown> | Record<PropertyKey, unknown>;\n }\n } else if (arguments_.length > 1 && typeof arguments_[0] === \"string\") {\n meta.message = arguments_[0] as string;\n meta.context = arguments_.slice(1);\n } else {\n // eslint-disable-next-line prefer-destructuring\n meta.message = arguments_[0];\n }\n\n if (type.logLevel === \"trace\") {\n meta.traceError = new Error(\"Trace\");\n }\n\n if (type.badge) {\n meta.badge = padEnd(type.badge, type.badge.length + 1);\n }\n\n if (type.label) {\n meta.label = type.label;\n }\n\n return meta;\n }\n\n // eslint-disable-next-line sonarjs/cognitive-complexity,@typescript-eslint/no-explicit-any\n private _logger(type: LiteralUnion<DefaultLogTypes, T>, raw: boolean, ...messageObject: any[]): void {\n if (this.disabled) {\n return;\n }\n\n // eslint-disable-next-line security/detect-object-injection\n const logLevel = this._normalizeLogLevel(this.types[type].logLevel);\n\n // eslint-disable-next-line security/detect-object-injection\n if ((this.logLevels[logLevel] as number) >= (this.logLevels[this.generalLogLevel] as number)) {\n // eslint-disable-next-line security/detect-object-injection\n let meta = this._buildMeta(type, this.types[type], ...messageObject);\n\n /**\n * @param newLog false if the throttle expired and we don't want to log a duplicate\n */\n const resolveLog = (newLog = false) => {\n // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n const repeated = (this.lastLog.count || 0) - this.throttleMin;\n\n if (this.lastLog.object && repeated > 0) {\n const lastMeta = { ...this.lastLog.object };\n\n if (repeated > 1) {\n lastMeta.repeated = repeated;\n }\n\n this._report(lastMeta, raw);\n\n this.lastLog.count = 1;\n }\n\n if (newLog) {\n // Apply global processors\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax\n for (const processor of this.processors) {\n meta = { ...processor.process(meta) };\n }\n\n this.lastLog.object = meta;\n\n this._report(meta, raw);\n }\n };\n\n clearTimeout(this.lastLog.timeout);\n\n const diffTime = this.lastLog.time && meta.date ? new Date(meta.date as Date | string).getTime() - this.lastLog.time.getTime() : 0;\n\n this.lastLog.time = new Date(meta.date as Date | string);\n\n if (diffTime < this.throttle) {\n try {\n const serializedLog = JSON.stringify([meta.label, meta.scope, meta.type, meta.message, meta.prefix, meta.suffix, meta.context]);\n const isSameLog = this.lastLog.serialized === serializedLog;\n\n this.lastLog.serialized = serializedLog;\n\n if (isSameLog) {\n // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n this.lastLog.count = (this.lastLog.count || 0) + 1;\n\n if (this.lastLog.count > this.throttleMin) {\n // Auto-resolve when throttle is timed out\n this.lastLog.timeout = setTimeout(resolveLog, this.throttle);\n\n return; // SPAM!\n }\n }\n } catch {\n // Circular References\n }\n }\n\n resolveLog(true);\n }\n }\n}\n\nexport type PailBrowserType<T extends string = never, L extends string = never> = PailBrowserImpl<T, L> &\n Record<DefaultLogTypes, LoggerFunction> &\n Record<T, LoggerFunction> &\n (new<TC extends string = never, LC extends string = never>(options?: ConstructorOptions<TC, LC>) => PailBrowserType<TC, LC>);\n\nexport type PailConstructor<T extends string = never, L extends string = never> = new (options?: ConstructorOptions<T, L>) => PailBrowserType<T, L>;\n\nexport const PailBrowser = PailBrowserImpl as unknown as PailBrowserType;\n","import type { ReadonlyMeta, Reporter } from \"../../types\";\nimport { writeConsoleLogBasedOnLevel } from \"../../util/write-console-log\";\n\nexport class RawReporter<L extends string = never> implements Reporter<L> {\n // eslint-disable-next-line class-methods-use-this\n public log(meta: ReadonlyMeta<L>): void {\n const { context = [], message, type } = meta;\n\n const consoleLogFunction = writeConsoleLogBasedOnLevel(type.level);\n\n consoleLogFunction(message, ...context);\n }\n}\n","export const arrayify = <T>(x: T | T[]): T[] => {\n if (x === undefined) {\n return [] as T[];\n }\n\n return Array.isArray(x) ? x : ([x] as T[]);\n};\n","import type { DefaultLoggerTypes, DefaultLogTypes, LiteralUnion, LoggerTypesConfig } from \"../types\";\n\nexport const mergeTypes = <L extends string, T extends string>(\n standard: DefaultLoggerTypes<L>,\n custom: LoggerTypesConfig<T, L>,\n): LoggerTypesConfig<LiteralUnion<DefaultLogTypes, T>, L> => {\n const types = { ...standard } as LoggerTypesConfig<LiteralUnion<DefaultLogTypes, T>, L>;\n\n Object.keys(custom).forEach((type) => {\n types[type as T] = { ...types[type as T], ...custom[type as T] };\n });\n\n return types;\n};\n","export const padEnd = (string_: string, targetLength: number): string => {\n if (string_.length >= targetLength) {\n return string_;\n }\n\n return string_.padEnd(targetLength);\n};\n","// eslint-disable-next-line import/exports-last\nexport const seen = Symbol(\"circular-reference-tag\");\n\n// eslint-disable-next-line import/exports-last,import/no-unused-modules\nexport const rawSymbol = Symbol(\"raw-error-ref\");\n\nconst errorProto = Object.create(\n {},\n {\n aggregateErrors: {\n enumerable: true,\n value: undefined,\n writable: true,\n },\n cause: {\n enumerable: true,\n value: undefined,\n writable: true,\n },\n code: {\n enumerable: true,\n value: undefined,\n writable: true,\n },\n message: {\n enumerable: true,\n value: undefined,\n writable: true,\n },\n name: {\n enumerable: true,\n value: undefined,\n writable: true,\n },\n raw: {\n enumerable: false,\n get() {\n // eslint-disable-next-line security/detect-object-injection\n return this[rawSymbol];\n },\n set(value) {\n // eslint-disable-next-line security/detect-object-injection\n this[rawSymbol] = value;\n },\n },\n stack: {\n enumerable: true,\n value: undefined,\n writable: true,\n },\n },\n) as SerializedError;\n\nObject.defineProperty(errorProto, rawSymbol, {\n value: {},\n writable: true,\n});\n\nexport const ErrorProto = errorProto;\n\nexport type SerializedError<ErrorType = Error> = Record<PropertyKey, unknown> & {\n aggregateErrors?: SerializedError<ErrorType>[];\n cause?: unknown;\n code?: string;\n message: string;\n name: string;\n raw?: ErrorType;\n stack?: string;\n};\n","import type { SerializedError } from \"./error-proto\";\nimport { ErrorProto, seen } from \"./error-proto\";\n\ntype CauseError = Error & {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n cause: any;\n};\n\ntype Options = {\n readonly maxDepth?: number;\n readonly useToJSON?: boolean;\n};\n\n/**\n * Serialize an `Error` object into a plain object.\n *\n * - Non-error values are passed through.\n * - Custom properties are preserved.\n * - Buffer properties are replaced with `[object Buffer]`.\n * - Circular references are handled.\n * - If the input object has a `.toJSON()` method, then it's called instead of serializing the object's properties.\n * - It's up to `.toJSON()` implementation to handle circular references and enumerability of the properties.\n */\n// eslint-disable-next-line sonarjs/cognitive-complexity\nexport const errorWithCauseSerializer = (error: AggregateError | Error, options: Options = {}): SerializedError => {\n // @ts-expect-error - dynamic property\n // eslint-disable-next-line no-param-reassign\n error[seen as keyof Error] = undefined; // tag to prevent re-looking at this\n\n const protoError = Object.create(ErrorProto as object) as SerializedError;\n\n protoError.name = Object.prototype.toString.call(error.constructor) === \"[object Function]\" ? error.constructor.name : error.name;\n protoError.message = error.message;\n protoError.stack = error.stack;\n\n if (Array.isArray((error as AggregateError).errors)) {\n protoError.aggregateErrors = (error as AggregateError).errors.map((error_: AggregateError | Error) => errorWithCauseSerializer(error_, options));\n }\n\n // Handle aggregate errors\n if ((error as CauseError).cause instanceof Error && !Object.prototype.hasOwnProperty.call((error as CauseError).cause, seen as PropertyKey)) {\n protoError.cause = errorWithCauseSerializer((error as CauseError).cause, options);\n }\n\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax\n for (const key in error) {\n // eslint-disable-next-line security/detect-object-injection\n if (protoError[key] === undefined) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const value = error[key as keyof Error] as any;\n\n if (value instanceof Error) {\n if (!Object.prototype.hasOwnProperty.call(value, seen as PropertyKey)) {\n // eslint-disable-next-line security/detect-object-injection\n protoError[key] = errorWithCauseSerializer(value, options);\n }\n } else if (typeof value === \"function\") {\n // eslint-disable-next-line security/detect-object-injection\n protoError[key] = \"[Function: \" + (value.name || \"anonymous\");\n } else {\n // Gracefully handle non-configurable errors like `DOMException`.\n try {\n // eslint-disable-next-line security/detect-object-injection\n protoError[key] = value;\n } catch {\n /* empty */\n }\n }\n }\n }\n\n // eslint-disable-next-line no-param-reassign,@typescript-eslint/no-dynamic-delete\n delete error[seen as unknown as keyof Error]; // clean up tag in case err is serialized again later\n\n protoError.raw = error;\n\n return protoError;\n};\n","import type { Meta, Processor } from \"../../types\";\nimport type { SerializedError } from \"./error-proto\";\nimport { errorWithCauseSerializer } from \"./error-with-cause-serializer\";\n\ndeclare global {\n // eslint-disable-next-line @typescript-eslint/no-namespace\n namespace VisulimaPail {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n interface CustomMeta<L> {\n error: SerializedError | undefined;\n }\n }\n}\n\nexport class ErrorProcessor<L extends string = never> implements Processor<L> {\n private readonly _options: { maxDepth: number; useToJSON: boolean };\n\n public constructor(options: { maxDepth?: number; useToJSON?: boolean } = {}) {\n this._options = {\n maxDepth: Number.POSITIVE_INFINITY,\n useToJSON: true,\n ...options,\n };\n }\n\n public process(meta: Meta<L>): Meta<L> {\n if (meta.error) {\n // eslint-disable-next-line no-param-reassign\n meta.error = errorWithCauseSerializer(meta.error, this._options);\n }\n\n return meta;\n }\n}\n"]}
@@ -1,29 +0,0 @@
1
- import { b as b$1, a } from './chunk-ZB7IIFHO.js';
2
- import { c } from './chunk-NF47XQ47.js';
3
- import vD, { white, grey, bgGrey, underline, red, cyan, bold } from '@visulima/colorize';
4
- import y from 'node:process';
5
- import { execFileSync } from 'node:child_process';
6
- import N from 'node:fs';
7
- import cD from 'node:tty';
8
-
9
- function I({onlyFirst:D=!1}={}){let u=["[\\u001B\\u009B][[\\]()#;?]*(?:(?:(?:(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]+)*|[a-zA-Z\\d]+(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]*)*)?\\u0007)","(?:(?:\\d{1,4}(?:;\\d{0,4})*)?[\\dA-PR-TZcf-ntqry=><~]))"].join("|");return new RegExp(u,D?void 0:"g")}var lD=I();function h(D){if(typeof D!="string")throw new TypeError(`Expected a \`string\`, got \`${typeof D}\``);return D.replace(lD,"")}var AD=new Intl.Segmenter;function w(D,{countAnsiEscapeCodes:u=!1}={}){if(D===""||(u||(D=h(D)),D===""))return 0;let F=0;for(let e of AD.segment(D))F++;return F}var V=80,q=24,R=(D,u,{shell:F,env:e}={})=>execFileSync(D,u,{encoding:"utf8",stdio:["ignore","pipe","ignore"],timeout:500,shell:F,env:e}).trim(),_=(D,u)=>({columns:Number.parseInt(D,10),rows:Number.parseInt(u,10)}),H=(D,u)=>{let{columns:F,rows:e}=_(D,u);if(!(Number.isNaN(F)||Number.isNaN(e))&&!(F===V&&e===q))return {columns:F,rows:e}};function W(){let{env:D,stdout:u,stderr:F}=y;if(u?.columns&&u?.rows)return _(u.columns,u.rows);if(F?.columns&&F?.rows)return _(F.columns,F.rows);if(D.COLUMNS&&D.LINES)return _(D.COLUMNS,D.LINES);let e={columns:V,rows:q};return y.platform==="win32"?O()??e:y.platform==="darwin"?Z()??O()??e:Z()??O()??gD()??e}var Z=()=>{try{let D=y.platform==="darwin"?N.constants.O_EVTONLY|N.constants.O_NONBLOCK:N.constants.O_NONBLOCK,{columns:u,rows:F}=cD.WriteStream(N.openSync("/dev/tty",D));return {columns:u,rows:F}}catch{}},O=()=>{try{let D=R("tput",["cols"],{env:{TERM:"dumb",...y.env}}),u=R("tput",["lines"],{env:{TERM:"dumb",...y.env}});if(D&&u)return H(D,u)}catch{}},gD=()=>{try{let D=R("resize",["-u"]).match(/\d+/g);if(D.length===2)return H(D[0],D[1])}catch{}};function Q(D){return D===161||D===164||D===167||D===168||D===170||D===173||D===174||D>=176&&D<=180||D>=182&&D<=186||D>=188&&D<=191||D===198||D===208||D===215||D===216||D>=222&&D<=225||D===230||D>=232&&D<=234||D===236||D===237||D===240||D===242||D===243||D>=247&&D<=250||D===252||D===254||D===257||D===273||D===275||D===283||D===294||D===295||D===299||D>=305&&D<=307||D===312||D>=319&&D<=322||D===324||D>=328&&D<=331||D===333||D===338||D===339||D===358||D===359||D===363||D===462||D===464||D===466||D===468||D===470||D===472||D===474||D===476||D===593||D===609||D===708||D===711||D>=713&&D<=715||D===717||D===720||D>=728&&D<=731||D===733||D===735||D>=768&&D<=879||D>=913&&D<=929||D>=931&&D<=937||D>=945&&D<=961||D>=963&&D<=969||D===1025||D>=1040&&D<=1103||D===1105||D===8208||D>=8211&&D<=8214||D===8216||D===8217||D===8220||D===8221||D>=8224&&D<=8226||D>=8228&&D<=8231||D===8240||D===8242||D===8243||D===8245||D===8251||D===8254||D===8308||D===8319||D>=8321&&D<=8324||D===8364||D===8451||D===8453||D===8457||D===8467||D===8470||D===8481||D===8482||D===8486||D===8491||D===8531||D===8532||D>=8539&&D<=8542||D>=8544&&D<=8555||D>=8560&&D<=8569||D===8585||D>=8592&&D<=8601||D===8632||D===8633||D===8658||D===8660||D===8679||D===8704||D===8706||D===8707||D===8711||D===8712||D===8715||D===8719||D===8721||D===8725||D===8730||D>=8733&&D<=8736||D===8739||D===8741||D>=8743&&D<=8748||D===8750||D>=8756&&D<=8759||D===8764||D===8765||D===8776||D===8780||D===8786||D===8800||D===8801||D>=8804&&D<=8807||D===8810||D===8811||D===8814||D===8815||D===8834||D===8835||D===8838||D===8839||D===8853||D===8857||D===8869||D===8895||D===8978||D>=9312&&D<=9449||D>=9451&&D<=9547||D>=9552&&D<=9587||D>=9600&&D<=9615||D>=9618&&D<=9621||D===9632||D===9633||D>=9635&&D<=9641||D===9650||D===9651||D===9654||D===9655||D===9660||D===9661||D===9664||D===9665||D>=9670&&D<=9672||D===9675||D>=9678&&D<=9681||D>=9698&&D<=9701||D===9711||D===9733||D===9734||D===9737||D===9742||D===9743||D===9756||D===9758||D===9792||D===9794||D===9824||D===9825||D>=9827&&D<=9829||D>=9831&&D<=9834||D===9836||D===9837||D===9839||D===9886||D===9887||D===9919||D>=9926&&D<=9933||D>=9935&&D<=9939||D>=9941&&D<=9953||D===9955||D===9960||D===9961||D>=9963&&D<=9969||D===9972||D>=9974&&D<=9977||D===9979||D===9980||D===9982||D===9983||D===10045||D>=10102&&D<=10111||D>=11094&&D<=11097||D>=12872&&D<=12879||D>=57344&&D<=63743||D>=65024&&D<=65039||D===65533||D>=127232&&D<=127242||D>=127248&&D<=127277||D>=127280&&D<=127337||D>=127344&&D<=127373||D===127375||D===127376||D>=127387&&D<=127404||D>=917760&&D<=917999||D>=983040&&D<=1048573||D>=1048576&&D<=1114109}function X(D){return D===12288||D>=65281&&D<=65376||D>=65504&&D<=65510}function DD(D){return D>=4352&&D<=4447||D===8986||D===8987||D===9001||D===9002||D>=9193&&D<=9196||D===9200||D===9203||D===9725||D===9726||D===9748||D===9749||D>=9800&&D<=9811||D===9855||D===9875||D===9889||D===9898||D===9899||D===9917||D===9918||D===9924||D===9925||D===9934||D===9940||D===9962||D===9970||D===9971||D===9973||D===9978||D===9981||D===9989||D===9994||D===9995||D===10024||D===10060||D===10062||D>=10067&&D<=10069||D===10071||D>=10133&&D<=10135||D===10160||D===10175||D===11035||D===11036||D===11088||D===11093||D>=11904&&D<=11929||D>=11931&&D<=12019||D>=12032&&D<=12245||D>=12272&&D<=12287||D>=12289&&D<=12350||D>=12353&&D<=12438||D>=12441&&D<=12543||D>=12549&&D<=12591||D>=12593&&D<=12686||D>=12688&&D<=12771||D>=12783&&D<=12830||D>=12832&&D<=12871||D>=12880&&D<=19903||D>=19968&&D<=42124||D>=42128&&D<=42182||D>=43360&&D<=43388||D>=44032&&D<=55203||D>=63744&&D<=64255||D>=65040&&D<=65049||D>=65072&&D<=65106||D>=65108&&D<=65126||D>=65128&&D<=65131||D>=94176&&D<=94180||D===94192||D===94193||D>=94208&&D<=100343||D>=100352&&D<=101589||D>=101632&&D<=101640||D>=110576&&D<=110579||D>=110581&&D<=110587||D===110589||D===110590||D>=110592&&D<=110882||D===110898||D>=110928&&D<=110930||D===110933||D>=110948&&D<=110951||D>=110960&&D<=111355||D===126980||D===127183||D===127374||D>=127377&&D<=127386||D>=127488&&D<=127490||D>=127504&&D<=127547||D>=127552&&D<=127560||D===127568||D===127569||D>=127584&&D<=127589||D>=127744&&D<=127776||D>=127789&&D<=127797||D>=127799&&D<=127868||D>=127870&&D<=127891||D>=127904&&D<=127946||D>=127951&&D<=127955||D>=127968&&D<=127984||D===127988||D>=127992&&D<=128062||D===128064||D>=128066&&D<=128252||D>=128255&&D<=128317||D>=128331&&D<=128334||D>=128336&&D<=128359||D===128378||D===128405||D===128406||D===128420||D>=128507&&D<=128591||D>=128640&&D<=128709||D===128716||D>=128720&&D<=128722||D>=128725&&D<=128727||D>=128732&&D<=128735||D===128747||D===128748||D>=128756&&D<=128764||D>=128992&&D<=129003||D===129008||D>=129292&&D<=129338||D>=129340&&D<=129349||D>=129351&&D<=129535||D>=129648&&D<=129660||D>=129664&&D<=129672||D>=129680&&D<=129725||D>=129727&&D<=129733||D>=129742&&D<=129755||D>=129760&&D<=129768||D>=129776&&D<=129784||D>=131072&&D<=196605||D>=196608&&D<=262141}function pD(D){if(!Number.isSafeInteger(D))throw new TypeError(`Expected a code point, got \`${typeof D}\`.`)}function uD(D,{ambiguousAsWide:u=!1}={}){return pD(D),X(D)||DD(D)||u&&Q(D)?2:1}var FD=()=>/[#*0-9]\uFE0F?\u20E3|[\xA9\xAE\u203C\u2049\u2122\u2139\u2194-\u2199\u21A9\u21AA\u231A\u231B\u2328\u23CF\u23ED-\u23EF\u23F1\u23F2\u23F8-\u23FA\u24C2\u25AA\u25AB\u25B6\u25C0\u25FB\u25FC\u25FE\u2600-\u2604\u260E\u2611\u2614\u2615\u2618\u2620\u2622\u2623\u2626\u262A\u262E\u262F\u2638-\u263A\u2640\u2642\u2648-\u2653\u265F\u2660\u2663\u2665\u2666\u2668\u267B\u267E\u267F\u2692\u2694-\u2697\u2699\u269B\u269C\u26A0\u26A7\u26AA\u26B0\u26B1\u26BD\u26BE\u26C4\u26C8\u26CF\u26D1\u26E9\u26F0-\u26F5\u26F7\u26F8\u26FA\u2702\u2708\u2709\u270F\u2712\u2714\u2716\u271D\u2721\u2733\u2734\u2744\u2747\u2757\u2763\u27A1\u2934\u2935\u2B05-\u2B07\u2B1B\u2B1C\u2B55\u3030\u303D\u3297\u3299]\uFE0F?|[\u261D\u270C\u270D](?:\uFE0F|\uD83C[\uDFFB-\uDFFF])?|[\u270A\u270B](?:\uD83C[\uDFFB-\uDFFF])?|[\u23E9-\u23EC\u23F0\u23F3\u25FD\u2693\u26A1\u26AB\u26C5\u26CE\u26D4\u26EA\u26FD\u2705\u2728\u274C\u274E\u2753-\u2755\u2795-\u2797\u27B0\u27BF\u2B50]|\u26D3\uFE0F?(?:\u200D\uD83D\uDCA5)?|\u26F9(?:\uFE0F|\uD83C[\uDFFB-\uDFFF])?(?:\u200D[\u2640\u2642]\uFE0F?)?|\u2764\uFE0F?(?:\u200D(?:\uD83D\uDD25|\uD83E\uDE79))?|\uD83C(?:[\uDC04\uDD70\uDD71\uDD7E\uDD7F\uDE02\uDE37\uDF21\uDF24-\uDF2C\uDF36\uDF7D\uDF96\uDF97\uDF99-\uDF9B\uDF9E\uDF9F\uDFCD\uDFCE\uDFD4-\uDFDF\uDFF5\uDFF7]\uFE0F?|[\uDF85\uDFC2\uDFC7](?:\uD83C[\uDFFB-\uDFFF])?|[\uDFC4\uDFCA](?:\uD83C[\uDFFB-\uDFFF])?(?:\u200D[\u2640\u2642]\uFE0F?)?|[\uDFCB\uDFCC](?:\uFE0F|\uD83C[\uDFFB-\uDFFF])?(?:\u200D[\u2640\u2642]\uFE0F?)?|[\uDCCF\uDD8E\uDD91-\uDD9A\uDE01\uDE1A\uDE2F\uDE32-\uDE36\uDE38-\uDE3A\uDE50\uDE51\uDF00-\uDF20\uDF2D-\uDF35\uDF37-\uDF43\uDF45-\uDF4A\uDF4C-\uDF7C\uDF7E-\uDF84\uDF86-\uDF93\uDFA0-\uDFC1\uDFC5\uDFC6\uDFC8\uDFC9\uDFCF-\uDFD3\uDFE0-\uDFF0\uDFF8-\uDFFF]|\uDDE6\uD83C[\uDDE8-\uDDEC\uDDEE\uDDF1\uDDF2\uDDF4\uDDF6-\uDDFA\uDDFC\uDDFD\uDDFF]|\uDDE7\uD83C[\uDDE6\uDDE7\uDDE9-\uDDEF\uDDF1-\uDDF4\uDDF6-\uDDF9\uDDFB\uDDFC\uDDFE\uDDFF]|\uDDE8\uD83C[\uDDE6\uDDE8\uDDE9\uDDEB-\uDDEE\uDDF0-\uDDF5\uDDF7\uDDFA-\uDDFF]|\uDDE9\uD83C[\uDDEA\uDDEC\uDDEF\uDDF0\uDDF2\uDDF4\uDDFF]|\uDDEA\uD83C[\uDDE6\uDDE8\uDDEA\uDDEC\uDDED\uDDF7-\uDDFA]|\uDDEB\uD83C[\uDDEE-\uDDF0\uDDF2\uDDF4\uDDF7]|\uDDEC\uD83C[\uDDE6\uDDE7\uDDE9-\uDDEE\uDDF1-\uDDF3\uDDF5-\uDDFA\uDDFC\uDDFE]|\uDDED\uD83C[\uDDF0\uDDF2\uDDF3\uDDF7\uDDF9\uDDFA]|\uDDEE\uD83C[\uDDE8-\uDDEA\uDDF1-\uDDF4\uDDF6-\uDDF9]|\uDDEF\uD83C[\uDDEA\uDDF2\uDDF4\uDDF5]|\uDDF0\uD83C[\uDDEA\uDDEC-\uDDEE\uDDF2\uDDF3\uDDF5\uDDF7\uDDFC\uDDFE\uDDFF]|\uDDF1\uD83C[\uDDE6-\uDDE8\uDDEE\uDDF0\uDDF7-\uDDFB\uDDFE]|\uDDF2\uD83C[\uDDE6\uDDE8-\uDDED\uDDF0-\uDDFF]|\uDDF3\uD83C[\uDDE6\uDDE8\uDDEA-\uDDEC\uDDEE\uDDF1\uDDF4\uDDF5\uDDF7\uDDFA\uDDFF]|\uDDF4\uD83C\uDDF2|\uDDF5\uD83C[\uDDE6\uDDEA-\uDDED\uDDF0-\uDDF3\uDDF7-\uDDF9\uDDFC\uDDFE]|\uDDF6\uD83C\uDDE6|\uDDF7\uD83C[\uDDEA\uDDF4\uDDF8\uDDFA\uDDFC]|\uDDF8\uD83C[\uDDE6-\uDDEA\uDDEC-\uDDF4\uDDF7-\uDDF9\uDDFB\uDDFD-\uDDFF]|\uDDF9\uD83C[\uDDE6\uDDE8\uDDE9\uDDEB-\uDDED\uDDEF-\uDDF4\uDDF7\uDDF9\uDDFB\uDDFC\uDDFF]|\uDDFA\uD83C[\uDDE6\uDDEC\uDDF2\uDDF3\uDDF8\uDDFE\uDDFF]|\uDDFB\uD83C[\uDDE6\uDDE8\uDDEA\uDDEC\uDDEE\uDDF3\uDDFA]|\uDDFC\uD83C[\uDDEB\uDDF8]|\uDDFD\uD83C\uDDF0|\uDDFE\uD83C[\uDDEA\uDDF9]|\uDDFF\uD83C[\uDDE6\uDDF2\uDDFC]|\uDF44(?:\u200D\uD83D\uDFEB)?|\uDF4B(?:\u200D\uD83D\uDFE9)?|\uDFC3(?:\uD83C[\uDFFB-\uDFFF])?(?:\u200D(?:[\u2640\u2642]\uFE0F?(?:\u200D\u27A1\uFE0F?)?|\u27A1\uFE0F?))?|\uDFF3\uFE0F?(?:\u200D(?:\u26A7\uFE0F?|\uD83C\uDF08))?|\uDFF4(?:\u200D\u2620\uFE0F?|\uDB40\uDC67\uDB40\uDC62\uDB40(?:\uDC65\uDB40\uDC6E\uDB40\uDC67|\uDC73\uDB40\uDC63\uDB40\uDC74|\uDC77\uDB40\uDC6C\uDB40\uDC73)\uDB40\uDC7F)?)|\uD83D(?:[\uDC3F\uDCFD\uDD49\uDD4A\uDD6F\uDD70\uDD73\uDD76-\uDD79\uDD87\uDD8A-\uDD8D\uDDA5\uDDA8\uDDB1\uDDB2\uDDBC\uDDC2-\uDDC4\uDDD1-\uDDD3\uDDDC-\uDDDE\uDDE1\uDDE3\uDDE8\uDDEF\uDDF3\uDDFA\uDECB\uDECD-\uDECF\uDEE0-\uDEE5\uDEE9\uDEF0\uDEF3]\uFE0F?|[\uDC42\uDC43\uDC46-\uDC50\uDC66\uDC67\uDC6B-\uDC6D\uDC72\uDC74-\uDC76\uDC78\uDC7C\uDC83\uDC85\uDC8F\uDC91\uDCAA\uDD7A\uDD95\uDD96\uDE4C\uDE4F\uDEC0\uDECC](?:\uD83C[\uDFFB-\uDFFF])?|[\uDC6E\uDC70\uDC71\uDC73\uDC77\uDC81\uDC82\uDC86\uDC87\uDE45-\uDE47\uDE4B\uDE4D\uDE4E\uDEA3\uDEB4\uDEB5](?:\uD83C[\uDFFB-\uDFFF])?(?:\u200D[\u2640\u2642]\uFE0F?)?|[\uDD74\uDD90](?:\uFE0F|\uD83C[\uDFFB-\uDFFF])?|[\uDC00-\uDC07\uDC09-\uDC14\uDC16-\uDC25\uDC27-\uDC3A\uDC3C-\uDC3E\uDC40\uDC44\uDC45\uDC51-\uDC65\uDC6A\uDC79-\uDC7B\uDC7D-\uDC80\uDC84\uDC88-\uDC8E\uDC90\uDC92-\uDCA9\uDCAB-\uDCFC\uDCFF-\uDD3D\uDD4B-\uDD4E\uDD50-\uDD67\uDDA4\uDDFB-\uDE2D\uDE2F-\uDE34\uDE37-\uDE41\uDE43\uDE44\uDE48-\uDE4A\uDE80-\uDEA2\uDEA4-\uDEB3\uDEB7-\uDEBF\uDEC1-\uDEC5\uDED0-\uDED2\uDED5-\uDED7\uDEDC-\uDEDF\uDEEB\uDEEC\uDEF4-\uDEFC\uDFE0-\uDFEB\uDFF0]|\uDC08(?:\u200D\u2B1B)?|\uDC15(?:\u200D\uD83E\uDDBA)?|\uDC26(?:\u200D(?:\u2B1B|\uD83D\uDD25))?|\uDC3B(?:\u200D\u2744\uFE0F?)?|\uDC41\uFE0F?(?:\u200D\uD83D\uDDE8\uFE0F?)?|\uDC68(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D\uD83D(?:\uDC8B\u200D\uD83D)?\uDC68|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D(?:[\uDC68\uDC69]\u200D\uD83D(?:\uDC66(?:\u200D\uD83D\uDC66)?|\uDC67(?:\u200D\uD83D[\uDC66\uDC67])?)|[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uDC66(?:\u200D\uD83D\uDC66)?|\uDC67(?:\u200D\uD83D[\uDC66\uDC67])?)|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]))|\uD83C(?:\uDFFB(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D\uD83D(?:\uDC8B\u200D\uD83D)?\uDC68\uD83C[\uDFFB-\uDFFF]|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]|\uDD1D\u200D\uD83D\uDC68\uD83C[\uDFFC-\uDFFF])))?|\uDFFC(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D\uD83D(?:\uDC8B\u200D\uD83D)?\uDC68\uD83C[\uDFFB-\uDFFF]|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]|\uDD1D\u200D\uD83D\uDC68\uD83C[\uDFFB\uDFFD-\uDFFF])))?|\uDFFD(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D\uD83D(?:\uDC8B\u200D\uD83D)?\uDC68\uD83C[\uDFFB-\uDFFF]|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]|\uDD1D\u200D\uD83D\uDC68\uD83C[\uDFFB\uDFFC\uDFFE\uDFFF])))?|\uDFFE(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D\uD83D(?:\uDC8B\u200D\uD83D)?\uDC68\uD83C[\uDFFB-\uDFFF]|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]|\uDD1D\u200D\uD83D\uDC68\uD83C[\uDFFB-\uDFFD\uDFFF])))?|\uDFFF(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D\uD83D(?:\uDC8B\u200D\uD83D)?\uDC68\uD83C[\uDFFB-\uDFFF]|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]|\uDD1D\u200D\uD83D\uDC68\uD83C[\uDFFB-\uDFFE])))?))?|\uDC69(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D\uD83D(?:\uDC8B\u200D\uD83D)?[\uDC68\uDC69]|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D(?:[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uDC66(?:\u200D\uD83D\uDC66)?|\uDC67(?:\u200D\uD83D[\uDC66\uDC67])?|\uDC69\u200D\uD83D(?:\uDC66(?:\u200D\uD83D\uDC66)?|\uDC67(?:\u200D\uD83D[\uDC66\uDC67])?))|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]))|\uD83C(?:\uDFFB(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D\uD83D(?:[\uDC68\uDC69]|\uDC8B\u200D\uD83D[\uDC68\uDC69])\uD83C[\uDFFB-\uDFFF]|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]|\uDD1D\u200D\uD83D[\uDC68\uDC69]\uD83C[\uDFFC-\uDFFF])))?|\uDFFC(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D\uD83D(?:[\uDC68\uDC69]|\uDC8B\u200D\uD83D[\uDC68\uDC69])\uD83C[\uDFFB-\uDFFF]|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]|\uDD1D\u200D\uD83D[\uDC68\uDC69]\uD83C[\uDFFB\uDFFD-\uDFFF])))?|\uDFFD(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D\uD83D(?:[\uDC68\uDC69]|\uDC8B\u200D\uD83D[\uDC68\uDC69])\uD83C[\uDFFB-\uDFFF]|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]|\uDD1D\u200D\uD83D[\uDC68\uDC69]\uD83C[\uDFFB\uDFFC\uDFFE\uDFFF])))?|\uDFFE(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D\uD83D(?:[\uDC68\uDC69]|\uDC8B\u200D\uD83D[\uDC68\uDC69])\uD83C[\uDFFB-\uDFFF]|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]|\uDD1D\u200D\uD83D[\uDC68\uDC69]\uD83C[\uDFFB-\uDFFD\uDFFF])))?|\uDFFF(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D\uD83D(?:[\uDC68\uDC69]|\uDC8B\u200D\uD83D[\uDC68\uDC69])\uD83C[\uDFFB-\uDFFF]|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]|\uDD1D\u200D\uD83D[\uDC68\uDC69]\uD83C[\uDFFB-\uDFFE])))?))?|\uDC6F(?:\u200D[\u2640\u2642]\uFE0F?)?|\uDD75(?:\uFE0F|\uD83C[\uDFFB-\uDFFF])?(?:\u200D[\u2640\u2642]\uFE0F?)?|\uDE2E(?:\u200D\uD83D\uDCA8)?|\uDE35(?:\u200D\uD83D\uDCAB)?|\uDE36(?:\u200D\uD83C\uDF2B\uFE0F?)?|\uDE42(?:\u200D[\u2194\u2195]\uFE0F?)?|\uDEB6(?:\uD83C[\uDFFB-\uDFFF])?(?:\u200D(?:[\u2640\u2642]\uFE0F?(?:\u200D\u27A1\uFE0F?)?|\u27A1\uFE0F?))?)|\uD83E(?:[\uDD0C\uDD0F\uDD18-\uDD1F\uDD30-\uDD34\uDD36\uDD77\uDDB5\uDDB6\uDDBB\uDDD2\uDDD3\uDDD5\uDEC3-\uDEC5\uDEF0\uDEF2-\uDEF8](?:\uD83C[\uDFFB-\uDFFF])?|[\uDD26\uDD35\uDD37-\uDD39\uDD3D\uDD3E\uDDB8\uDDB9\uDDCD\uDDCF\uDDD4\uDDD6-\uDDDD](?:\uD83C[\uDFFB-\uDFFF])?(?:\u200D[\u2640\u2642]\uFE0F?)?|[\uDDDE\uDDDF](?:\u200D[\u2640\u2642]\uFE0F?)?|[\uDD0D\uDD0E\uDD10-\uDD17\uDD20-\uDD25\uDD27-\uDD2F\uDD3A\uDD3F-\uDD45\uDD47-\uDD76\uDD78-\uDDB4\uDDB7\uDDBA\uDDBC-\uDDCC\uDDD0\uDDE0-\uDDFF\uDE70-\uDE7C\uDE80-\uDE88\uDE90-\uDEBD\uDEBF-\uDEC2\uDECE-\uDEDB\uDEE0-\uDEE8]|\uDD3C(?:\u200D[\u2640\u2642]\uFE0F?|\uD83C[\uDFFB-\uDFFF])?|\uDDCE(?:\uD83C[\uDFFB-\uDFFF])?(?:\u200D(?:[\u2640\u2642]\uFE0F?(?:\u200D\u27A1\uFE0F?)?|\u27A1\uFE0F?))?|\uDDD1(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]|\uDD1D\u200D\uD83E\uDDD1|\uDDD1\u200D\uD83E\uDDD2(?:\u200D\uD83E\uDDD2)?|\uDDD2(?:\u200D\uD83E\uDDD2)?))|\uD83C(?:\uDFFB(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1\uD83C[\uDFFC-\uDFFF]|\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]|\uDD1D\u200D\uD83E\uDDD1\uD83C[\uDFFB-\uDFFF])))?|\uDFFC(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1\uD83C[\uDFFB\uDFFD-\uDFFF]|\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]|\uDD1D\u200D\uD83E\uDDD1\uD83C[\uDFFB-\uDFFF])))?|\uDFFD(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1\uD83C[\uDFFB\uDFFC\uDFFE\uDFFF]|\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]|\uDD1D\u200D\uD83E\uDDD1\uD83C[\uDFFB-\uDFFF])))?|\uDFFE(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1\uD83C[\uDFFB-\uDFFD\uDFFF]|\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]|\uDD1D\u200D\uD83E\uDDD1\uD83C[\uDFFB-\uDFFF])))?|\uDFFF(?:\u200D(?:[\u2695\u2696\u2708]\uFE0F?|\u2764\uFE0F?\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1\uD83C[\uDFFB-\uDFFE]|\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E(?:[\uDDAF\uDDBC\uDDBD](?:\u200D\u27A1\uFE0F?)?|[\uDDB0-\uDDB3]|\uDD1D\u200D\uD83E\uDDD1\uD83C[\uDFFB-\uDFFF])))?))?|\uDEF1(?:\uD83C(?:\uDFFB(?:\u200D\uD83E\uDEF2\uD83C[\uDFFC-\uDFFF])?|\uDFFC(?:\u200D\uD83E\uDEF2\uD83C[\uDFFB\uDFFD-\uDFFF])?|\uDFFD(?:\u200D\uD83E\uDEF2\uD83C[\uDFFB\uDFFC\uDFFE\uDFFF])?|\uDFFE(?:\u200D\uD83E\uDEF2\uD83C[\uDFFB-\uDFFD\uDFFF])?|\uDFFF(?:\u200D\uD83E\uDEF2\uD83C[\uDFFB-\uDFFE])?))?)/g;var mD=new Intl.Segmenter;function b(D,u={}){if(typeof D!="string"||D.length===0)return 0;let{ambiguousIsNarrow:F=!0,countAnsiEscapeCodes:e=!1}=u;if(e||(D=h(D)),D.length===0)return 0;let r=0,n={ambiguousAsWide:!F};for(let{segment:E}of mD.segment(D)){let t=E.codePointAt(0);if(!(t<=31||t>=127&&t<=159)&&!(t>=768&&t<=879)){if(FD().test(E)){r+=2;continue}r+=uD(t,n);}}return r}var eD=(D=0)=>u=>`\x1B[${u+D}m`,tD=(D=0)=>u=>`\x1B[${38+D};5;${u}m`,rD=(D=0)=>(u,F,e)=>`\x1B[${38+D};2;${u};${F};${e}m`,C={modifier:{reset:[0,0],bold:[1,22],dim:[2,22],italic:[3,23],underline:[4,24],overline:[53,55],inverse:[7,27],hidden:[8,28],strikethrough:[9,29]},color:{black:[30,39],red:[31,39],green:[32,39],yellow:[33,39],blue:[34,39],magenta:[35,39],cyan:[36,39],white:[37,39],blackBright:[90,39],gray:[90,39],grey:[90,39],redBright:[91,39],greenBright:[92,39],yellowBright:[93,39],blueBright:[94,39],magentaBright:[95,39],cyanBright:[96,39],whiteBright:[97,39]},bgColor:{bgBlack:[40,49],bgRed:[41,49],bgGreen:[42,49],bgYellow:[43,49],bgBlue:[44,49],bgMagenta:[45,49],bgCyan:[46,49],bgWhite:[47,49],bgBlackBright:[100,49],bgGray:[100,49],bgGrey:[100,49],bgRedBright:[101,49],bgGreenBright:[102,49],bgYellowBright:[103,49],bgBlueBright:[104,49],bgMagentaBright:[105,49],bgCyanBright:[106,49],bgWhiteBright:[107,49]}};Object.keys(C.modifier);var dD=Object.keys(C.color),hD=Object.keys(C.bgColor);[...dD,...hD];function bD(){let D=new Map;for(let[u,F]of Object.entries(C)){for(let[e,r]of Object.entries(F))C[e]={open:`\x1B[${r[0]}m`,close:`\x1B[${r[1]}m`},F[e]=C[e],D.set(r[0],r[1]);Object.defineProperty(C,u,{value:F,enumerable:!1});}return Object.defineProperty(C,"codes",{value:D,enumerable:!1}),C.color.close="\x1B[39m",C.bgColor.close="\x1B[49m",C.color.ansi=eD(),C.color.ansi256=tD(),C.color.ansi16m=rD(),C.bgColor.ansi=eD(10),C.bgColor.ansi256=tD(10),C.bgColor.ansi16m=rD(10),Object.defineProperties(C,{rgbToAnsi256:{value:(u,F,e)=>u===F&&F===e?u<8?16:u>248?231:Math.round((u-8)/247*24)+232:16+36*Math.round(u/255*5)+6*Math.round(F/255*5)+Math.round(e/255*5),enumerable:!1},hexToRgb:{value:u=>{let F=/[a-f\d]{6}|[a-f\d]{3}/i.exec(u.toString(16));if(!F)return [0,0,0];let[e]=F;e.length===3&&(e=[...e].map(n=>n+n).join(""));let r=Number.parseInt(e,16);return [r>>16&255,r>>8&255,r&255]},enumerable:!1},hexToAnsi256:{value:u=>C.rgbToAnsi256(...C.hexToRgb(u)),enumerable:!1},ansi256ToAnsi:{value:u=>{if(u<8)return 30+u;if(u<16)return 90+(u-8);let F,e,r;if(u>=232)F=((u-232)*10+8)/255,e=F,r=F;else {u-=16;let t=u%36;F=Math.floor(u/36)/5,e=Math.floor(t/6)/5,r=t%6/5;}let n=Math.max(F,e,r)*2;if(n===0)return 30;let E=30+(Math.round(r)<<2|Math.round(e)<<1|Math.round(F));return n===2&&(E+=60),E},enumerable:!1},rgbToAnsi:{value:(u,F,e)=>C.ansi256ToAnsi(C.rgbToAnsi256(u,F,e)),enumerable:!1},hexToAnsi:{value:u=>C.ansi256ToAnsi(C.hexToAnsi256(u)),enumerable:!1}}),C}var yD=bD(),ED=yD;var L=new Set(["\x1B","\x9B"]),xD=39,$="\x07",iD="[",SD="]",sD="m",v=`${SD}8;;`,CD=D=>`${L.values().next().value}${iD}${D}${sD}`,nD=D=>`${L.values().next().value}${v}${D}${$}`,wD=D=>D.split(" ").map(u=>b(u)),j=(D,u,F)=>{let e=[...u],r=!1,n=!1,E=b(h(D.at(-1)));for(let[t,o]of e.entries()){let f=b(o);if(E+f<=F?D[D.length-1]+=o:(D.push(o),E=0),L.has(o)&&(r=!0,n=e.slice(t+1,t+1+v.length).join("")===v),r){n?o===$&&(r=!1,n=!1):o===sD&&(r=!1);continue}E+=f,E===F&&t<e.length-1&&(D.push(""),E=0);}!E&&D.at(-1).length>0&&D.length>1&&(D[D.length-2]+=D.pop());},ND=D=>{let u=D.split(" "),F=u.length;for(;F>0&&!(b(u[F-1])>0);)F--;return F===u.length?D:u.slice(0,F).join(" ")+u.slice(F).join("")},_D=(D,u,F={})=>{if(F.trim!==!1&&D.trim()==="")return "";let e="",r,n,E=wD(D),t=[""];for(let[s,a]of D.split(" ").entries()){F.trim!==!1&&(t[t.length-1]=t.at(-1).trimStart());let B=b(t.at(-1));if(s!==0&&(B>=u&&(F.wordWrap===!1||F.trim===!1)&&(t.push(""),B=0),(B>0||F.trim===!1)&&(t[t.length-1]+=" ",B++)),F.hard&&E[s]>u){let A=u-B,m=1+Math.floor((E[s]-A-1)/u);Math.floor((E[s]-1)/u)<m&&t.push(""),j(t,a,u);continue}if(B+E[s]>u&&B>0&&E[s]>0){if(F.wordWrap===!1&&B<u){j(t,a,u);continue}t.push("");}if(B+E[s]>u&&F.wordWrap===!1){j(t,a,u);continue}t[t.length-1]+=a;}F.trim!==!1&&(t=t.map(s=>ND(s)));let o=t.join(`
10
- `),f=[...o],l=0;for(let[s,a]of f.entries()){if(e+=a,L.has(a)){let{groups:A}=new RegExp(`(?:\\${iD}(?<code>\\d+)m|\\${v}(?<uri>.*)${$})`).exec(o.slice(l))||{groups:{}};if(A.code!==void 0){let m=Number.parseFloat(A.code);r=m===xD?void 0:m;}else A.uri!==void 0&&(n=A.uri.length===0?void 0:A.uri);}let B=ED.codes.get(Number(r));f[s+1]===`
11
- `?(n&&(e+=nD("")),r&&B&&(e+=CD(B))):a===`
12
- `&&(r&&B&&(e+=CD(r)),n&&(e+=nD(n))),l+=a.length;}return e};function T(D,u,F){return String(D).normalize().replaceAll(`\r
13
- `,`
14
- `).split(`
15
- `).map(e=>_D(e,u,F)).join(`
16
- `)}var oD=(D,u)=>(u.__write??u.write).call(u,D);var BD=class extends b$1{#D;#u;#F;#e=!1;constructor(u={}){super({uppercase:{label:!0,...u.uppercase},...u}),this.#D=process.stdout,this.#u=process.stderr;}setStdout(u){this.#D=u;}setStderr(u){this.#u=u;}setInteractiveManager(u){this.#F=u;}setIsInteractive(u){this.#e=u;}log(u){this._log(this._formatMessage(u),u.type.level);}_formatMessage(u){let{columns:F}=W(),e=F;typeof this._styles.messageLength=="number"&&(e=this._styles.messageLength);let{badge:r,context:n,date:E,error:t,file:o,groups:f,label:l,message:s,prefix:a$1,repeated:B,scope:A,suffix:m,traceError:M,type:aD}=u,{color:z}=this._loggerTypes[aD.name],G=z?vD[z]:white,x=f.map(()=>" ").join(""),i=[];if(f.length>0&&i.push(x+grey("["+f.at(-1)+"] ")),E&&i.push(grey(this._styles.dateFormatter(new Date(E)))+" "),r)i.push(G(r));else {let d=a(this._loggerTypes);d.length>0&&i.push(grey(".".repeat(d.length))+" ");}let U=c(this._loggerTypes);l?i.push(G(this._formatLabel(l))+" ",grey(".".repeat(U.length-w(l)))):i.push(grey(".".repeat(U.length+2))),B&&i.push(bgGrey.white("["+B+"x]")+" "),Array.isArray(A)&&A.length>0&&i.push(grey(" ["+A.join(" > ")+"] ")),a$1&&i.push(grey((Array.isArray(A)&&A.length>0?". ":" ")+"["+(this._styles.underline.prefix?underline(a$1):a$1)+"] "));let K=w(i.join(" "));if(o){let d=o.name+(o.line?":"+o.line:""),S=w(d);i.push(grey(".".repeat(e-K-S-2)+" "+d));}else i.push(grey(".".repeat(e-K-1)));if(i.length>0&&i.push(`
17
-
18
- `),s){let d=typeof s=="string"?s:this._stringify(s);i.push(x+T(d??"undefined",e-3,{hard:!0,trim:!0,wordWrap:!0})),n&&i.push(...n.map(S=>typeof S=="object"?" "+this._stringify(S):" "+S));}return t&&i.push(this._formatError(t,e,x)),M&&i.push(this._formatError(M,e,x,!0)),m&&i.push(`
19
- `,x+grey(this._styles.underline.suffix?underline(m):m)),i.join("")+`
20
- `}_log(u,F){let e=["error","trace","warn"].includes(F)?"stderr":"stdout",r=e==="stderr"?this.#u:this.#D;this.#e&&this.#F!==void 0&&r.isTTY?this.#F.update(e,u.split(`
21
- `),0):oD(u+`
22
- `,r);}_formatError(u,F,e,r=!1){let{message:n,name:E,stack:t}=u,o=[];if(o.push(...r?[]:[e+red(E),": "],T(n,F-3,{hard:!0,trim:!0,wordWrap:!0})),t){let f=t.split(`
23
- `).splice(1).map(l=>e+l.trim().replace("file://","")).filter(l=>!l.includes("/pail/dist"));o.push(`
24
- `,f.map(l=>" "+l.replace(/^at +/,s=>grey(s)).replace(/\((.+)\)/,(s,a)=>"("+cyan(a)+")")).join(`
25
- `));}return o.join("")}_formatLabel(u){let F=this._styles.uppercase.label?u.toUpperCase():u;return F=this._styles.underline.label?underline(F):F,this._styles.bold.label&&(F=bold(F)),F}};
26
-
27
- export { W as a, T as b, oD as c, BD as d };
28
- //# sourceMappingURL=out.js.map
29
- //# sourceMappingURL=chunk-JGZNXQSY.js.map