@dxos/debug 0.6.13 → 0.6.14-main.2b6a0f3

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.
@@ -157,8 +157,7 @@ var StackTrace = class {
157
157
  }
158
158
  /**
159
159
  * Get stack formatted as string.
160
- *
161
- * @param skipFrames Number of frames to skip. By default the first frame would be the invocation of the StackTrace constructor.
160
+ * @param skipFrames Number of frames to skip. By default, the first frame would be the invocation of the StackTrace constructor.
162
161
  * @returns
163
162
  */
164
163
  getStack(skipFrames = 0) {
@@ -288,6 +287,9 @@ var importModule = (name) => {
288
287
  }
289
288
  };
290
289
  var EXPOSED_MODULES = {};
290
+
291
+ // packages/common/debug/src/inspect-custom.ts
292
+ var inspectCustom = Symbol.for("nodejs.util.inspect.custom");
291
293
  export {
292
294
  ErrorHandler,
293
295
  ErrorStream,
@@ -301,6 +303,7 @@ export {
301
303
  exposeModule,
302
304
  failUndefined,
303
305
  importModule,
306
+ inspectCustom,
304
307
  inspectObject,
305
308
  isEqual,
306
309
  isEquatable,
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../../../src/assert.ts", "../../../src/error-handler.ts", "../../../src/error-stream.ts", "../../../src/fail.ts", "../../../src/inspect.ts", "../../../src/log-method.ts", "../../../src/raise.ts", "../../../src/snoop.ts", "../../../src/stack-trace.ts", "../../../src/strings.ts", "../../../src/throw.ts", "../../../src/timeout-warning.ts", "../../../src/todo.ts", "../../../src/devtools-formatter.ts", "../../../src/equality.ts", "../../../src/exposed-modules.ts"],
4
- "sourcesContent": ["//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * A simple syntax sugar to write `value as T` as a statement.\n *\n * NOTE: This does not provide any type safety.\n * It's just for convenience so that autocomplete works for value.\n * It's recommended to check the type URL manually beforehand or use `assertAnyType` instead.\n * @param value\n */\nexport const checkType = <T>(value: T): T => value;\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { EventEmitter } from 'node:events';\n\n/**\n * Listens for global errors.\n */\nexport class ErrorHandler extends EventEmitter {\n _listener: any;\n\n constructor() {\n super();\n\n this._listener = (event: any) => {\n const cause = event.error || event.reason || event;\n const message = cause.stack || cause.message || cause.toString();\n this.emit('error', message);\n\n // Default logging.\n // code event.preventDefault();\n };\n\n // https://developer.mozilla.org/en-US/docs/Web/API/Window/error_event\n window.addEventListener('error', this._listener);\n\n // https://developer.mozilla.org/en-US/docs/Web/API/Window/unhandledrejection_event\n window.addEventListener('unhandledrejection', this._listener);\n }\n\n reset() {\n window.removeEventListener('error', this._listener);\n window.removeEventListener('unhandledrejection', this._listener);\n }\n}\n", "//\n// Copyright 2021 DXOS.org\n//\n\nexport type ErrorHandlerCallback = (error: Error) => void;\n\n/**\n * Represents a stream of errors that entities can expose.\n */\nexport class ErrorStream {\n private _handler: ErrorHandlerCallback | undefined;\n\n private _unhandledErrors = 0;\n\n assertNoUnhandledErrors() {\n if (this._unhandledErrors > 0) {\n throw new Error(\n `Assertion failed: expected no unhandled errors to be thrown, but ${this._unhandledErrors} were thrown.`,\n );\n }\n }\n\n raise(error: Error) {\n if (this._handler) {\n this._handler(error);\n } else {\n this._unhandledError(error);\n }\n }\n\n handle(handler: ErrorHandlerCallback) {\n this._handler = handler;\n }\n\n pipeTo(receiver: ErrorStream) {\n this.handle((error) => receiver.raise(error));\n }\n\n private _unhandledError(error: Error) {\n this._unhandledErrors++;\n\n setTimeout(() => {\n throw error;\n });\n }\n}\n", "//\n// Copyright 2021 DXOS.org\n//\n\n/**\n * Should be used in expressions where values are cheked not to be null or undefined.\n *\n * Example:\n *\n * ```\n * const value: string | undefined;\n *\n * callMethod(value ?? failUndefined());\n * ```\n */\n// TODO(burdon): Rename failIfUndefined().\nexport const failUndefined = () => {\n throw new Error('Required value was null or undefined.');\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { inspect } from 'node:util';\n\n/**\n * Utility to automatically log debug info.\n *\n * ```\n * // Called via `console.log`.\n * [inspect.custom] () {\n * return inspectObject(this);\n * }\n *\n * // Called via `JSON.stringify`.\n * toJSON () {\n * return { ... };\n * }\n * ```\n */\nexport const inspectObject = (obj: any) => {\n const name = Object.getPrototypeOf(obj).constructor.name;\n return obj.toJSON ? `${name}(${inspect(obj.toJSON())})` : String(obj);\n};\n", "//\n// Copyright 2021 DXOS.org\n//\n\nexport function logMethod(\n target: any,\n propertyName: string,\n descriptor: TypedPropertyDescriptor<(...args: any) => any>,\n) {\n const method = descriptor.value!;\n descriptor.value = function (this: any, ...args: any) {\n console.log(`Called ${target.constructor.name}.${propertyName} ${args}`);\n try {\n const result = method.apply(this, args);\n if (typeof result.catch === 'function') {\n result.catch((err: any) => {\n console.log(`Rejected ${target.constructor.name}.${propertyName}`, err);\n });\n }\n return result;\n } catch (err: any) {\n console.log(`Thrown ${target.constructor.name}.${propertyName}`, err);\n throw err;\n }\n };\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * Immediatelly throws an error passed as an argument.\n *\n * Usefull for throwing errors from inside expressions.\n * For example:\n * ```\n * const item = model.getById(someId) ?? raise(new Error('Not found'));\n * ```\n * @param error\n */\nexport const raise = (error: Error): never => {\n throw error;\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nexport enum SnoopLevel {\n DEFAULT = 0,\n VERBOSE = 1,\n BOLD = 2,\n}\n\n/**\n * Utils for debug logging of functions.\n */\n// TODO(burdon): Integrate with log/spyglass.\nexport class Snoop {\n static stackFunction(err: Error) {\n const stack = err.stack!.split('\\n');\n const match = stack[2].match(/.+\\((.+)\\).*/);\n if (match) {\n const [file, line] = match[1].split(':');\n return `[${file.substring(file.lastIndexOf('/') + 1)}:${line}]`;\n }\n }\n\n constructor(private readonly _context?: string) {}\n\n get verbose() {\n return SnoopLevel.VERBOSE;\n }\n\n get bold() {\n return SnoopLevel.BOLD;\n }\n\n format(prefix: string, name: string, args: string, level: SnoopLevel) {\n const pre = prefix.repeat(level === SnoopLevel.BOLD ? 8 : 2);\n const label = this._context ? `${this._context}.${name}` : name;\n const line = `${pre} ${label}${args}`;\n return level === SnoopLevel.BOLD ? [pre, line, pre].join('\\n') : line;\n }\n\n in(label: string, level: SnoopLevel, ...args: any[]) {\n return this.format('<', label, level === SnoopLevel.DEFAULT ? '' : `(${String(...args)})`, level);\n }\n\n out(label: string, level: SnoopLevel, result: any) {\n return this.format('>', label, level === SnoopLevel.DEFAULT ? '' : ` = ${String(result)}`, level);\n }\n\n sync(f: any, label?: string, level: SnoopLevel = SnoopLevel.VERBOSE) {\n label = label ?? Snoop.stackFunction(new Error());\n return (...args: any[]) => {\n console.log(this.in(label ?? '', level, ...args));\n const r = f(...args);\n console.log(this.out(label ?? '', level, r));\n return r;\n };\n }\n\n async(f: any, label?: string, level: SnoopLevel = SnoopLevel.VERBOSE) {\n label = label ?? Snoop.stackFunction(new Error());\n return async (...args: any[]) => {\n console.log(this.in(label ?? '', level, ...args));\n const r = await f(...args);\n console.log(this.out(label ?? '', level, r));\n return r;\n };\n }\n}\n\nexport const snoop = new Snoop();\n", "//\n// Copyright 2021 DXOS.org\n//\n\n/**\n * Allows to capture stack-traces.\n *\n * Will capture the stack trace at the point where the class is created.\n * Stack traces are formatted lazily only when `getStack` is called.\n *\n * Formatting is significantly more expensive than capture so only call\n * getStack when you need them.\n */\nexport class StackTrace {\n private _stack: Error;\n\n constructor() {\n this._stack = new Error();\n }\n\n /**\n * Get stack formatted as string.\n *\n * @param skipFrames Number of frames to skip. By default the first frame would be the invocation of the StackTrace constructor.\n * @returns\n */\n getStack(skipFrames = 0) {\n const stack = this._stack.stack!.split('\\n');\n return stack.slice(skipFrames + 2).join('\\n');\n }\n\n getStackArray(skipFrames = 0) {\n const stack = this._stack.stack!.split('\\n');\n return stack.slice(skipFrames + 2);\n }\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\nexport const truncate = (str = '', length = 8, pad: boolean | string = false) => {\n if (str.length >= length - 1) {\n return str.substring(0, length - 1) + '…';\n } else {\n return pad ? str.padEnd(length, typeof pad === 'boolean' ? ' ' : pad[0]) : str;\n }\n};\n\nexport const truncateKey = (key: any, length = 8) => {\n const str = String(key);\n if (str.length <= length) {\n return str;\n }\n\n return str.slice(0, length);\n\n // return start\n // ? `${str.slice(0, length)}...`\n // : `${str.substring(0, length / 2)}...${str.substring(str.length - length / 2)}`;\n};\n", "//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * Wrapper for async tests.\n * @param {Function} test - Async test\n * @param errType\n * @return {Promise<void>}\n */\nexport const expectToThrow = async (test: () => void, errType = Error) => {\n let thrown;\n try {\n await test();\n } catch (err) {\n thrown = err;\n }\n\n if (thrown === undefined || !(thrown instanceof errType)) {\n throw new Error(`Expected function to throw instance of ${errType.prototype.name}`);\n }\n};\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { StackTrace } from './stack-trace';\n\n/**\n * Prints a warning to console if the action takes longer then specified timeout. No errors are thrown.\n *\n * @param timeout Timeout in milliseconds after which warning is printed.\n * @param context Context description that would be included in the printed message.\n * @param body Action which is timed.\n */\nexport const warnAfterTimeout = async <T>(timeout: number, context: string, body: () => Promise<T>): Promise<T> => {\n const stack = new StackTrace();\n const timeoutId = setTimeout(() => {\n console.warn(\n `Action \\`${context}\\` is taking more then ${timeout.toLocaleString()}ms to complete. This might be a bug.\\n${stack.getStack()}`,\n );\n }, timeout);\n try {\n return await body();\n } finally {\n clearTimeout(timeoutId);\n }\n};\n\n/**\n * A decorator that prints a warning to console if method execution time exceeds specified timeout.\n *\n * ```typescript\n * class Foo {\n * @timed(5_000)\n * async doStuff() {\n * // long task\n * }\n * }\n * ```\n *\n * This is useful for debugging code that might deadlock.\n *\n * @param timeout Timeout in milliseconds after which the warning is printed.\n */\nexport function timed(timeout: number) {\n return (target: any, propertyName: string, descriptor: TypedPropertyDescriptor<(...args: any) => any>) => {\n const method = descriptor.value!;\n descriptor.value = function (this: any, ...args: any) {\n return warnAfterTimeout(timeout, `${target.constructor.name}.${propertyName}`, () => method.apply(this, args));\n };\n };\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * Throws an error. Can be used in an expression instead of a value\n */\nexport const todo = (message?: string): never => {\n throw new Error(message ?? 'Not implemented.');\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\n/**\n * Lets types provide custom formatters for the Chrome Devtools.\n *\n * https://www.mattzeunert.com/2016/02/19/custom-chrome-devtools-object-formatters.html\n * NOTE: Must be enabled in chrome devtools preferences.\n *\n * @example\n * ```typescript\n * class MyType {\n * get [devtoolsFormatter] (): DevtoolsFormatter {\n * ...\n * }\n * ```\n */\n\nexport const devtoolsFormatter = Symbol.for('devtoolsFormatter');\n\nexport type JsonML = [string, Record<string, any>?, ...(JsonML | string)[]];\n\nexport interface DevtoolsFormatter {\n /**\n * NOTE: Make sure to do an instance check and return null if the object is not of the correct type.\n */\n header: (config?: any) => JsonML | null;\n hasBody?: (config?: any) => boolean;\n body?: (config?: any) => JsonML | null;\n}\n\n/**\n * Types that implement this interface can provide custom formatters for the Chrome Devtools.\n *\n * https://firefox-source-docs.mozilla.org/devtools-user/custom_formatters/index.html\n */\nexport interface CustomDevtoolsFormattable {\n get [devtoolsFormatter](): DevtoolsFormatter;\n}\n\nconst register = () => {\n if (typeof window !== 'undefined') {\n ((window as any).devtoolsFormatters ??= []).push({\n header: (value: any, config: any) => {\n const formatter = value[devtoolsFormatter];\n if (formatter === undefined) {\n return null;\n }\n if (typeof formatter !== 'object' || formatter === null || typeof formatter.header !== 'function') {\n throw new Error(`Invalid devtools formatter for ${value.constructor.name}`);\n }\n\n return formatter.header(config);\n },\n hasBody: (value: any, config: any) => {\n const formatter = value[devtoolsFormatter];\n if (!formatter || !formatter.hasBody) {\n return false;\n }\n\n return formatter.hasBody(config);\n },\n body: (value: any, config: any) => {\n const formatter = value[devtoolsFormatter];\n if (!formatter || !formatter.body) {\n return null;\n }\n\n return formatter.body(config);\n },\n });\n }\n};\n\nregister();\n", "//\n// Copyright 2023 DXOS.org\n//\n\nexport const equalsSymbol = Symbol.for('dxos.common.equals');\n\nexport interface Equatable {\n [equalsSymbol]: (other: any) => boolean;\n}\n\n// TODO(dmaretskyi): export to @dxos/traits.\n// TODO(dmaretskyi): Hash trait for maps?\n\nexport const isEquatable = (value: any): value is Equatable => {\n return typeof value === 'object' && value !== null && typeof value[equalsSymbol] === 'function';\n};\n\nexport const isEqual = (value: Equatable, other: any) => {\n return value[equalsSymbol](other);\n};\n\n/**\n * Feed this as a third argument to `_.isEqualWith` to compare objects with `Equatable` interface.\n */\nexport const loadashEqualityFn = (value: any, other: any): boolean | undefined => {\n if (!isEquatable(value)) {\n return undefined;\n }\n return isEqual(value, other);\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\n/**\n * Allows to register a module to be used later during debugging.\n *\n * ```ts\n * import * as keys from '@dxos/keys';\n * exposeModule('@dxos/keys', keys);\n *\n * ...\n *\n * const { PublicKey } = importModule('@dxos/keys');\n * ```\n *\n * Overwrites the module if it already exists.\n */\nexport const exposeModule = (name: string, module: any) => {\n EXPOSED_MODULES[name] = module;\n};\n\n/**\n * Imports a previously exposed module by its name.\n * Throws an error if the module is not found.\n *\n * @param {string} name - The name of the module to import.\n * @returns {any} The imported module.\n * @throws {Error} If the module is not exposed.\n */\nexport const importModule = (name: string) => {\n if (EXPOSED_MODULES[name]) {\n return EXPOSED_MODULES[name];\n } else {\n throw new Error(`Module ${name} is not exposed.`);\n }\n};\n\nconst EXPOSED_MODULES: Record<string, any> = {};\n"],
5
- "mappings": "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",
6
- "names": ["checkType", "value", "EventEmitter", "ErrorHandler", "EventEmitter", "constructor", "_listener", "event", "cause", "error", "reason", "message", "stack", "toString", "emit", "window", "addEventListener", "reset", "removeEventListener", "ErrorStream", "_unhandledErrors", "assertNoUnhandledErrors", "Error", "raise", "error", "_handler", "_unhandledError", "handle", "handler", "pipeTo", "receiver", "setTimeout", "failUndefined", "Error", "inspect", "inspectObject", "obj", "name", "Object", "getPrototypeOf", "constructor", "toJSON", "inspect", "String", "logMethod", "target", "propertyName", "descriptor", "method", "value", "args", "console", "log", "constructor", "name", "result", "apply", "catch", "err", "raise", "error", "SnoopLevel", "Snoop", "stackFunction", "err", "stack", "split", "match", "file", "line", "substring", "lastIndexOf", "constructor", "_context", "verbose", "bold", "format", "prefix", "name", "args", "level", "pre", "repeat", "label", "join", "in", "String", "out", "result", "sync", "f", "Error", "console", "log", "r", "async", "snoop", "StackTrace", "constructor", "_stack", "Error", "getStack", "skipFrames", "stack", "split", "slice", "join", "getStackArray", "truncate", "str", "length", "pad", "substring", "padEnd", "truncateKey", "key", "String", "slice", "expectToThrow", "test", "errType", "Error", "thrown", "err", "undefined", "prototype", "name", "warnAfterTimeout", "timeout", "context", "body", "stack", "StackTrace", "timeoutId", "setTimeout", "console", "warn", "toLocaleString", "getStack", "clearTimeout", "timed", "target", "propertyName", "descriptor", "method", "value", "args", "constructor", "name", "apply", "todo", "message", "Error", "devtoolsFormatter", "Symbol", "for", "register", "window", "devtoolsFormatters", "push", "header", "value", "config", "formatter", "undefined", "Error", "constructor", "name", "hasBody", "body", "equalsSymbol", "Symbol", "for", "isEquatable", "value", "isEqual", "other", "loadashEqualityFn", "undefined", "exposeModule", "name", "module", "EXPOSED_MODULES", "importModule", "Error"]
3
+ "sources": ["../../../src/assert.ts", "../../../src/error-handler.ts", "../../../src/error-stream.ts", "../../../src/fail.ts", "../../../src/inspect.ts", "../../../src/log-method.ts", "../../../src/raise.ts", "../../../src/snoop.ts", "../../../src/stack-trace.ts", "../../../src/strings.ts", "../../../src/throw.ts", "../../../src/timeout-warning.ts", "../../../src/todo.ts", "../../../src/devtools-formatter.ts", "../../../src/equality.ts", "../../../src/exposed-modules.ts", "../../../src/inspect-custom.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * A simple syntax sugar to write `value as T` as a statement.\n *\n * NOTE: This does not provide any type safety.\n * It's just for convenience so that autocomplete works for value.\n * It's recommended to check the type URL manually beforehand or use `assertAnyType` instead.\n * @param value\n */\nexport const checkType = <T>(value: T): T => value;\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { EventEmitter } from 'node:events';\n\n/**\n * Listens for global errors.\n */\nexport class ErrorHandler extends EventEmitter {\n _listener: any;\n\n constructor() {\n super();\n\n this._listener = (event: any) => {\n const cause = event.error || event.reason || event;\n const message = cause.stack || cause.message || cause.toString();\n this.emit('error', message);\n\n // Default logging.\n // code event.preventDefault();\n };\n\n // https://developer.mozilla.org/en-US/docs/Web/API/Window/error_event\n window.addEventListener('error', this._listener);\n\n // https://developer.mozilla.org/en-US/docs/Web/API/Window/unhandledrejection_event\n window.addEventListener('unhandledrejection', this._listener);\n }\n\n reset() {\n window.removeEventListener('error', this._listener);\n window.removeEventListener('unhandledrejection', this._listener);\n }\n}\n", "//\n// Copyright 2021 DXOS.org\n//\n\nexport type ErrorHandlerCallback = (error: Error) => void;\n\n/**\n * Represents a stream of errors that entities can expose.\n */\nexport class ErrorStream {\n private _handler: ErrorHandlerCallback | undefined;\n\n private _unhandledErrors = 0;\n\n assertNoUnhandledErrors() {\n if (this._unhandledErrors > 0) {\n throw new Error(\n `Assertion failed: expected no unhandled errors to be thrown, but ${this._unhandledErrors} were thrown.`,\n );\n }\n }\n\n raise(error: Error) {\n if (this._handler) {\n this._handler(error);\n } else {\n this._unhandledError(error);\n }\n }\n\n handle(handler: ErrorHandlerCallback) {\n this._handler = handler;\n }\n\n pipeTo(receiver: ErrorStream) {\n this.handle((error) => receiver.raise(error));\n }\n\n private _unhandledError(error: Error) {\n this._unhandledErrors++;\n\n setTimeout(() => {\n throw error;\n });\n }\n}\n", "//\n// Copyright 2021 DXOS.org\n//\n\n/**\n * Should be used in expressions where values are cheked not to be null or undefined.\n *\n * Example:\n *\n * ```\n * const value: string | undefined;\n *\n * callMethod(value ?? failUndefined());\n * ```\n */\n// TODO(burdon): Rename failIfUndefined().\nexport const failUndefined = () => {\n throw new Error('Required value was null or undefined.');\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { inspect } from 'node:util';\n\n/**\n * Utility to automatically log debug info.\n *\n * ```\n * // Called via `console.log`.\n * [inspect.custom] () {\n * return inspectObject(this);\n * }\n *\n * // Called via `JSON.stringify`.\n * toJSON () {\n * return { ... };\n * }\n * ```\n */\nexport const inspectObject = (obj: any) => {\n const name = Object.getPrototypeOf(obj).constructor.name;\n return obj.toJSON ? `${name}(${inspect(obj.toJSON())})` : String(obj);\n};\n", "//\n// Copyright 2021 DXOS.org\n//\n\nexport function logMethod(\n target: any,\n propertyName: string,\n descriptor: TypedPropertyDescriptor<(...args: any) => any>,\n) {\n const method = descriptor.value!;\n descriptor.value = function (this: any, ...args: any) {\n console.log(`Called ${target.constructor.name}.${propertyName} ${args}`);\n try {\n const result = method.apply(this, args);\n if (typeof result.catch === 'function') {\n result.catch((err: any) => {\n console.log(`Rejected ${target.constructor.name}.${propertyName}`, err);\n });\n }\n return result;\n } catch (err: any) {\n console.log(`Thrown ${target.constructor.name}.${propertyName}`, err);\n throw err;\n }\n };\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * Immediatelly throws an error passed as an argument.\n *\n * Usefull for throwing errors from inside expressions.\n * For example:\n * ```\n * const item = model.getById(someId) ?? raise(new Error('Not found'));\n * ```\n * @param error\n */\nexport const raise = (error: Error): never => {\n throw error;\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nexport enum SnoopLevel {\n DEFAULT = 0,\n VERBOSE = 1,\n BOLD = 2,\n}\n\n/**\n * Utils for debug logging of functions.\n */\n// TODO(burdon): Integrate with log/spyglass.\nexport class Snoop {\n static stackFunction(err: Error) {\n const stack = err.stack!.split('\\n');\n const match = stack[2].match(/.+\\((.+)\\).*/);\n if (match) {\n const [file, line] = match[1].split(':');\n return `[${file.substring(file.lastIndexOf('/') + 1)}:${line}]`;\n }\n }\n\n constructor(private readonly _context?: string) {}\n\n get verbose() {\n return SnoopLevel.VERBOSE;\n }\n\n get bold() {\n return SnoopLevel.BOLD;\n }\n\n format(prefix: string, name: string, args: string, level: SnoopLevel) {\n const pre = prefix.repeat(level === SnoopLevel.BOLD ? 8 : 2);\n const label = this._context ? `${this._context}.${name}` : name;\n const line = `${pre} ${label}${args}`;\n return level === SnoopLevel.BOLD ? [pre, line, pre].join('\\n') : line;\n }\n\n in(label: string, level: SnoopLevel, ...args: any[]) {\n return this.format('<', label, level === SnoopLevel.DEFAULT ? '' : `(${String(...args)})`, level);\n }\n\n out(label: string, level: SnoopLevel, result: any) {\n return this.format('>', label, level === SnoopLevel.DEFAULT ? '' : ` = ${String(result)}`, level);\n }\n\n sync(f: any, label?: string, level: SnoopLevel = SnoopLevel.VERBOSE) {\n label = label ?? Snoop.stackFunction(new Error());\n return (...args: any[]) => {\n console.log(this.in(label ?? '', level, ...args));\n const r = f(...args);\n console.log(this.out(label ?? '', level, r));\n return r;\n };\n }\n\n async(f: any, label?: string, level: SnoopLevel = SnoopLevel.VERBOSE) {\n label = label ?? Snoop.stackFunction(new Error());\n return async (...args: any[]) => {\n console.log(this.in(label ?? '', level, ...args));\n const r = await f(...args);\n console.log(this.out(label ?? '', level, r));\n return r;\n };\n }\n}\n\nexport const snoop = new Snoop();\n", "//\n// Copyright 2021 DXOS.org\n//\n\n/**\n * Will capture the stack trace at the point where the class is created.\n * Stack traces are formatted lazily only when `getStack` is called.\n * Formatting is significantly more expensive than capture so only call getStack when you need them.\n */\nexport class StackTrace {\n private _stack: Error;\n\n constructor() {\n this._stack = new Error();\n }\n\n /**\n * Get stack formatted as string.\n * @param skipFrames Number of frames to skip. By default, the first frame would be the invocation of the StackTrace constructor.\n * @returns\n */\n getStack(skipFrames = 0) {\n const stack = this._stack.stack!.split('\\n');\n return stack.slice(skipFrames + 2).join('\\n');\n }\n\n getStackArray(skipFrames = 0) {\n const stack = this._stack.stack!.split('\\n');\n return stack.slice(skipFrames + 2);\n }\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\nexport const truncate = (str = '', length = 8, pad: boolean | string = false) => {\n if (str.length >= length - 1) {\n return str.substring(0, length - 1) + '…';\n } else {\n return pad ? str.padEnd(length, typeof pad === 'boolean' ? ' ' : pad[0]) : str;\n }\n};\n\nexport const truncateKey = (key: any, length = 8) => {\n const str = String(key);\n if (str.length <= length) {\n return str;\n }\n\n return str.slice(0, length);\n\n // return start\n // ? `${str.slice(0, length)}...`\n // : `${str.substring(0, length / 2)}...${str.substring(str.length - length / 2)}`;\n};\n", "//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * Wrapper for async tests.\n * @param {Function} test - Async test\n * @param errType\n * @return {Promise<void>}\n *\n * @deprecated Use vitests `expect(() => ...).toThrowError();` instead.\n */\nexport const expectToThrow = async (test: () => void, errType = Error) => {\n let thrown;\n try {\n await test();\n } catch (err) {\n thrown = err;\n }\n\n if (thrown === undefined || !(thrown instanceof errType)) {\n throw new Error(`Expected function to throw instance of ${errType.prototype.name}`);\n }\n};\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { StackTrace } from './stack-trace';\n\n/**\n * Prints a warning to console if the action takes longer then specified timeout. No errors are thrown.\n *\n * @param timeout Timeout in milliseconds after which warning is printed.\n * @param context Context description that would be included in the printed message.\n * @param body Action which is timed.\n */\nexport const warnAfterTimeout = async <T>(timeout: number, context: string, body: () => Promise<T>): Promise<T> => {\n const stack = new StackTrace();\n const timeoutId = setTimeout(() => {\n console.warn(\n `Action \\`${context}\\` is taking more then ${timeout.toLocaleString()}ms to complete. This might be a bug.\\n${stack.getStack()}`,\n );\n }, timeout);\n try {\n return await body();\n } finally {\n clearTimeout(timeoutId);\n }\n};\n\n/**\n * A decorator that prints a warning to console if method execution time exceeds specified timeout.\n *\n * ```typescript\n * class Foo {\n * @timed(5_000)\n * async doStuff() {\n * // long task\n * }\n * }\n * ```\n *\n * This is useful for debugging code that might deadlock.\n *\n * @param timeout Timeout in milliseconds after which the warning is printed.\n */\nexport function timed(timeout: number) {\n return (target: any, propertyName: string, descriptor: TypedPropertyDescriptor<(...args: any) => any>) => {\n const method = descriptor.value!;\n descriptor.value = function (this: any, ...args: any) {\n return warnAfterTimeout(timeout, `${target.constructor.name}.${propertyName}`, () => method.apply(this, args));\n };\n };\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * Throws an error. Can be used in an expression instead of a value\n */\nexport const todo = (message?: string): never => {\n throw new Error(message ?? 'Not implemented.');\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\n/**\n * Lets types provide custom formatters for the Chrome Devtools.\n *\n * https://www.mattzeunert.com/2016/02/19/custom-chrome-devtools-object-formatters.html\n * NOTE: Must be enabled in chrome devtools preferences.\n *\n * @example\n * ```typescript\n * class MyType {\n * get [devtoolsFormatter] (): DevtoolsFormatter {\n * ...\n * }\n * ```\n */\n\nexport const devtoolsFormatter = Symbol.for('devtoolsFormatter');\n\nexport type JsonML = [string, Record<string, any>?, ...(JsonML | string)[]];\n\nexport interface DevtoolsFormatter {\n /**\n * NOTE: Make sure to do an instance check and return null if the object is not of the correct type.\n */\n header: (config?: any) => JsonML | null;\n hasBody?: (config?: any) => boolean;\n body?: (config?: any) => JsonML | null;\n}\n\n/**\n * Types that implement this interface can provide custom formatters for the Chrome Devtools.\n *\n * https://firefox-source-docs.mozilla.org/devtools-user/custom_formatters/index.html\n */\nexport interface CustomDevtoolsFormattable {\n get [devtoolsFormatter](): DevtoolsFormatter;\n}\n\nconst register = () => {\n if (typeof window !== 'undefined') {\n ((window as any).devtoolsFormatters ??= []).push({\n header: (value: any, config: any) => {\n const formatter = value[devtoolsFormatter];\n if (formatter === undefined) {\n return null;\n }\n if (typeof formatter !== 'object' || formatter === null || typeof formatter.header !== 'function') {\n throw new Error(`Invalid devtools formatter for ${value.constructor.name}`);\n }\n\n return formatter.header(config);\n },\n hasBody: (value: any, config: any) => {\n const formatter = value[devtoolsFormatter];\n if (!formatter || !formatter.hasBody) {\n return false;\n }\n\n return formatter.hasBody(config);\n },\n body: (value: any, config: any) => {\n const formatter = value[devtoolsFormatter];\n if (!formatter || !formatter.body) {\n return null;\n }\n\n return formatter.body(config);\n },\n });\n }\n};\n\nregister();\n", "//\n// Copyright 2023 DXOS.org\n//\n\nexport const equalsSymbol = Symbol.for('dxos.common.equals');\n\nexport interface Equatable {\n [equalsSymbol]: (other: any) => boolean;\n}\n\n// TODO(dmaretskyi): export to @dxos/traits.\n// TODO(dmaretskyi): Hash trait for maps?\n\nexport const isEquatable = (value: any): value is Equatable => {\n return typeof value === 'object' && value !== null && typeof value[equalsSymbol] === 'function';\n};\n\nexport const isEqual = (value: Equatable, other: any) => {\n return value[equalsSymbol](other);\n};\n\n/**\n * Feed this as a third argument to `_.isEqualWith` to compare objects with `Equatable` interface.\n */\nexport const loadashEqualityFn = (value: any, other: any): boolean | undefined => {\n if (!isEquatable(value)) {\n return undefined;\n }\n return isEqual(value, other);\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\n/**\n * Allows to register a module to be used later during debugging.\n *\n * ```ts\n * import * as keys from '@dxos/keys';\n * exposeModule('@dxos/keys', keys);\n *\n * ...\n *\n * const { PublicKey } = importModule('@dxos/keys');\n * ```\n *\n * Overwrites the module if it already exists.\n */\nexport const exposeModule = (name: string, module: any) => {\n EXPOSED_MODULES[name] = module;\n};\n\n/**\n * Imports a previously exposed module by its name.\n * Throws an error if the module is not found.\n *\n * @param {string} name - The name of the module to import.\n * @returns {any} The imported module.\n * @throws {Error} If the module is not exposed.\n */\nexport const importModule = (name: string) => {\n if (EXPOSED_MODULES[name]) {\n return EXPOSED_MODULES[name];\n } else {\n throw new Error(`Module ${name} is not exposed.`);\n }\n};\n\nconst EXPOSED_MODULES: Record<string, any> = {};\n", "//\n// Copyright 2024 DXOS.org\n//\n\n/**\n * Using this allows code to be written in a portable fashion, so that the custom inspect function is used in an Node.js environment and ignored in the browser.\n */\nexport const inspectCustom = Symbol.for('nodejs.util.inspect.custom');\n"],
5
+ "mappings": "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",
6
+ "names": ["checkType", "value", "EventEmitter", "ErrorHandler", "EventEmitter", "constructor", "_listener", "event", "cause", "error", "reason", "message", "stack", "toString", "emit", "window", "addEventListener", "reset", "removeEventListener", "ErrorStream", "_unhandledErrors", "assertNoUnhandledErrors", "Error", "raise", "error", "_handler", "_unhandledError", "handle", "handler", "pipeTo", "receiver", "setTimeout", "failUndefined", "Error", "inspect", "inspectObject", "obj", "name", "Object", "getPrototypeOf", "constructor", "toJSON", "inspect", "String", "logMethod", "target", "propertyName", "descriptor", "method", "value", "args", "console", "log", "constructor", "name", "result", "apply", "catch", "err", "raise", "error", "SnoopLevel", "Snoop", "stackFunction", "err", "stack", "split", "match", "file", "line", "substring", "lastIndexOf", "constructor", "_context", "verbose", "bold", "format", "prefix", "name", "args", "level", "pre", "repeat", "label", "join", "in", "String", "out", "result", "sync", "f", "Error", "console", "log", "r", "async", "snoop", "StackTrace", "constructor", "_stack", "Error", "getStack", "skipFrames", "stack", "split", "slice", "join", "getStackArray", "truncate", "str", "length", "pad", "substring", "padEnd", "truncateKey", "key", "String", "slice", "expectToThrow", "test", "errType", "Error", "thrown", "err", "undefined", "prototype", "name", "warnAfterTimeout", "timeout", "context", "body", "stack", "StackTrace", "timeoutId", "setTimeout", "console", "warn", "toLocaleString", "getStack", "clearTimeout", "timed", "target", "propertyName", "descriptor", "method", "value", "args", "constructor", "name", "apply", "todo", "message", "Error", "devtoolsFormatter", "Symbol", "for", "register", "window", "devtoolsFormatters", "push", "header", "value", "config", "formatter", "undefined", "Error", "constructor", "name", "hasBody", "body", "equalsSymbol", "Symbol", "for", "isEquatable", "value", "isEqual", "other", "loadashEqualityFn", "undefined", "exposeModule", "name", "module", "EXPOSED_MODULES", "importModule", "Error", "inspectCustom", "Symbol", "for"]
7
7
  }
@@ -1 +1 @@
1
- {"inputs":{"packages/common/debug/src/assert.ts":{"bytes":1334,"imports":[],"format":"esm"},"packages/common/debug/src/error-handler.ts":{"bytes":3608,"imports":[{"path":"@dxos/node-std/events","kind":"import-statement","external":true}],"format":"esm"},"packages/common/debug/src/error-stream.ts":{"bytes":3457,"imports":[],"format":"esm"},"packages/common/debug/src/fail.ts":{"bytes":1405,"imports":[],"format":"esm"},"packages/common/debug/src/inspect.ts":{"bytes":2029,"imports":[{"path":"@dxos/node-std/util","kind":"import-statement","external":true}],"format":"esm"},"packages/common/debug/src/log-method.ts":{"bytes":3084,"imports":[],"format":"esm"},"packages/common/debug/src/raise.ts":{"bytes":1245,"imports":[],"format":"esm"},"packages/common/debug/src/snoop.ts":{"bytes":7985,"imports":[],"format":"esm"},"packages/common/debug/src/stack-trace.ts":{"bytes":3190,"imports":[],"format":"esm"},"packages/common/debug/src/strings.ts":{"bytes":2538,"imports":[],"format":"esm"},"packages/common/debug/src/throw.ts":{"bytes":1949,"imports":[],"format":"esm"},"packages/common/debug/src/timeout-warning.ts":{"bytes":5199,"imports":[{"path":"packages/common/debug/src/stack-trace.ts","kind":"import-statement","original":"./stack-trace"}],"format":"esm"},"packages/common/debug/src/todo.ts":{"bytes":956,"imports":[],"format":"esm"},"packages/common/debug/src/devtools-formatter.ts":{"bytes":6253,"imports":[],"format":"esm"},"packages/common/debug/src/equality.ts":{"bytes":2776,"imports":[],"format":"esm"},"packages/common/debug/src/exposed-modules.ts":{"bytes":3029,"imports":[],"format":"esm"},"packages/common/debug/src/index.ts":{"bytes":1890,"imports":[{"path":"packages/common/debug/src/assert.ts","kind":"import-statement","original":"./assert"},{"path":"packages/common/debug/src/error-handler.ts","kind":"import-statement","original":"./error-handler"},{"path":"packages/common/debug/src/error-stream.ts","kind":"import-statement","original":"./error-stream"},{"path":"packages/common/debug/src/fail.ts","kind":"import-statement","original":"./fail"},{"path":"packages/common/debug/src/inspect.ts","kind":"import-statement","original":"./inspect"},{"path":"packages/common/debug/src/log-method.ts","kind":"import-statement","original":"./log-method"},{"path":"packages/common/debug/src/raise.ts","kind":"import-statement","original":"./raise"},{"path":"packages/common/debug/src/snoop.ts","kind":"import-statement","original":"./snoop"},{"path":"packages/common/debug/src/stack-trace.ts","kind":"import-statement","original":"./stack-trace"},{"path":"packages/common/debug/src/strings.ts","kind":"import-statement","original":"./strings"},{"path":"packages/common/debug/src/throw.ts","kind":"import-statement","original":"./throw"},{"path":"packages/common/debug/src/timeout-warning.ts","kind":"import-statement","original":"./timeout-warning"},{"path":"packages/common/debug/src/todo.ts","kind":"import-statement","original":"./todo"},{"path":"packages/common/debug/src/devtools-formatter.ts","kind":"import-statement","original":"./devtools-formatter"},{"path":"packages/common/debug/src/equality.ts","kind":"import-statement","original":"./equality"},{"path":"packages/common/debug/src/exposed-modules.ts","kind":"import-statement","original":"./exposed-modules"}],"format":"esm"}},"outputs":{"packages/common/debug/dist/lib/browser/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":23136},"packages/common/debug/dist/lib/browser/index.mjs":{"imports":[{"path":"@dxos/node-std/events","kind":"import-statement","external":true},{"path":"@dxos/node-std/util","kind":"import-statement","external":true}],"exports":["ErrorHandler","ErrorStream","Snoop","SnoopLevel","StackTrace","checkType","devtoolsFormatter","equalsSymbol","expectToThrow","exposeModule","failUndefined","importModule","inspectObject","isEqual","isEquatable","loadashEqualityFn","logMethod","raise","snoop","timed","todo","truncate","truncateKey","warnAfterTimeout"],"entryPoint":"packages/common/debug/src/index.ts","inputs":{"packages/common/debug/src/assert.ts":{"bytesInOutput":34},"packages/common/debug/src/index.ts":{"bytesInOutput":0},"packages/common/debug/src/error-handler.ts":{"bytesInOutput":610},"packages/common/debug/src/error-stream.ts":{"bytesInOutput":655},"packages/common/debug/src/fail.ts":{"bytesInOutput":91},"packages/common/debug/src/inspect.ts":{"bytesInOutput":214},"packages/common/debug/src/log-method.ts":{"bytesInOutput":597},"packages/common/debug/src/raise.ts":{"bytesInOutput":43},"packages/common/debug/src/snoop.ts":{"bytesInOutput":1784},"packages/common/debug/src/stack-trace.ts":{"bytesInOutput":534},"packages/common/debug/src/strings.ts":{"bytesInOutput":396},"packages/common/debug/src/throw.ts":{"bytesInOutput":290},"packages/common/debug/src/timeout-warning.ts":{"bytesInOutput":664},"packages/common/debug/src/todo.ts":{"bytesInOutput":79},"packages/common/debug/src/devtools-formatter.ts":{"bytesInOutput":1035},"packages/common/debug/src/equality.ts":{"bytesInOutput":391},"packages/common/debug/src/exposed-modules.ts":{"bytesInOutput":271}},"bytes":8765}}}
1
+ {"inputs":{"packages/common/debug/src/assert.ts":{"bytes":1334,"imports":[],"format":"esm"},"packages/common/debug/src/error-handler.ts":{"bytes":3608,"imports":[{"path":"@dxos/node-std/events","kind":"import-statement","external":true}],"format":"esm"},"packages/common/debug/src/error-stream.ts":{"bytes":3457,"imports":[],"format":"esm"},"packages/common/debug/src/fail.ts":{"bytes":1405,"imports":[],"format":"esm"},"packages/common/debug/src/inspect.ts":{"bytes":2029,"imports":[{"path":"@dxos/node-std/util","kind":"import-statement","external":true}],"format":"esm"},"packages/common/debug/src/log-method.ts":{"bytes":3084,"imports":[],"format":"esm"},"packages/common/debug/src/raise.ts":{"bytes":1245,"imports":[],"format":"esm"},"packages/common/debug/src/snoop.ts":{"bytes":7985,"imports":[],"format":"esm"},"packages/common/debug/src/stack-trace.ts":{"bytes":3058,"imports":[],"format":"esm"},"packages/common/debug/src/strings.ts":{"bytes":2538,"imports":[],"format":"esm"},"packages/common/debug/src/throw.ts":{"bytes":2132,"imports":[],"format":"esm"},"packages/common/debug/src/timeout-warning.ts":{"bytes":5199,"imports":[{"path":"packages/common/debug/src/stack-trace.ts","kind":"import-statement","original":"./stack-trace"}],"format":"esm"},"packages/common/debug/src/todo.ts":{"bytes":956,"imports":[],"format":"esm"},"packages/common/debug/src/devtools-formatter.ts":{"bytes":6253,"imports":[],"format":"esm"},"packages/common/debug/src/equality.ts":{"bytes":2776,"imports":[],"format":"esm"},"packages/common/debug/src/exposed-modules.ts":{"bytes":3029,"imports":[],"format":"esm"},"packages/common/debug/src/inspect-custom.ts":{"bytes":1110,"imports":[],"format":"esm"},"packages/common/debug/src/index.ts":{"bytes":1996,"imports":[{"path":"packages/common/debug/src/assert.ts","kind":"import-statement","original":"./assert"},{"path":"packages/common/debug/src/error-handler.ts","kind":"import-statement","original":"./error-handler"},{"path":"packages/common/debug/src/error-stream.ts","kind":"import-statement","original":"./error-stream"},{"path":"packages/common/debug/src/fail.ts","kind":"import-statement","original":"./fail"},{"path":"packages/common/debug/src/inspect.ts","kind":"import-statement","original":"./inspect"},{"path":"packages/common/debug/src/log-method.ts","kind":"import-statement","original":"./log-method"},{"path":"packages/common/debug/src/raise.ts","kind":"import-statement","original":"./raise"},{"path":"packages/common/debug/src/snoop.ts","kind":"import-statement","original":"./snoop"},{"path":"packages/common/debug/src/stack-trace.ts","kind":"import-statement","original":"./stack-trace"},{"path":"packages/common/debug/src/strings.ts","kind":"import-statement","original":"./strings"},{"path":"packages/common/debug/src/throw.ts","kind":"import-statement","original":"./throw"},{"path":"packages/common/debug/src/timeout-warning.ts","kind":"import-statement","original":"./timeout-warning"},{"path":"packages/common/debug/src/todo.ts","kind":"import-statement","original":"./todo"},{"path":"packages/common/debug/src/devtools-formatter.ts","kind":"import-statement","original":"./devtools-formatter"},{"path":"packages/common/debug/src/equality.ts","kind":"import-statement","original":"./equality"},{"path":"packages/common/debug/src/exposed-modules.ts","kind":"import-statement","original":"./exposed-modules"},{"path":"packages/common/debug/src/inspect-custom.ts","kind":"import-statement","original":"./inspect-custom"}],"format":"esm"}},"outputs":{"packages/common/debug/dist/lib/browser/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":23553},"packages/common/debug/dist/lib/browser/index.mjs":{"imports":[{"path":"@dxos/node-std/events","kind":"import-statement","external":true},{"path":"@dxos/node-std/util","kind":"import-statement","external":true}],"exports":["ErrorHandler","ErrorStream","Snoop","SnoopLevel","StackTrace","checkType","devtoolsFormatter","equalsSymbol","expectToThrow","exposeModule","failUndefined","importModule","inspectCustom","inspectObject","isEqual","isEquatable","loadashEqualityFn","logMethod","raise","snoop","timed","todo","truncate","truncateKey","warnAfterTimeout"],"entryPoint":"packages/common/debug/src/index.ts","inputs":{"packages/common/debug/src/assert.ts":{"bytesInOutput":34},"packages/common/debug/src/index.ts":{"bytesInOutput":0},"packages/common/debug/src/error-handler.ts":{"bytesInOutput":610},"packages/common/debug/src/error-stream.ts":{"bytesInOutput":655},"packages/common/debug/src/fail.ts":{"bytesInOutput":91},"packages/common/debug/src/inspect.ts":{"bytesInOutput":214},"packages/common/debug/src/log-method.ts":{"bytesInOutput":597},"packages/common/debug/src/raise.ts":{"bytesInOutput":43},"packages/common/debug/src/snoop.ts":{"bytesInOutput":1784},"packages/common/debug/src/stack-trace.ts":{"bytesInOutput":531},"packages/common/debug/src/strings.ts":{"bytesInOutput":396},"packages/common/debug/src/throw.ts":{"bytesInOutput":290},"packages/common/debug/src/timeout-warning.ts":{"bytesInOutput":664},"packages/common/debug/src/todo.ts":{"bytesInOutput":79},"packages/common/debug/src/devtools-formatter.ts":{"bytesInOutput":1035},"packages/common/debug/src/equality.ts":{"bytesInOutput":391},"packages/common/debug/src/exposed-modules.ts":{"bytesInOutput":271},"packages/common/debug/src/inspect-custom.ts":{"bytesInOutput":62}},"bytes":8889}}}
@@ -30,6 +30,7 @@ __export(node_exports, {
30
30
  exposeModule: () => exposeModule,
31
31
  failUndefined: () => failUndefined,
32
32
  importModule: () => importModule,
33
+ inspectCustom: () => inspectCustom,
33
34
  inspectObject: () => inspectObject,
34
35
  isEqual: () => isEqual,
35
36
  isEquatable: () => isEquatable,
@@ -186,8 +187,7 @@ var StackTrace = class {
186
187
  }
187
188
  /**
188
189
  * Get stack formatted as string.
189
- *
190
- * @param skipFrames Number of frames to skip. By default the first frame would be the invocation of the StackTrace constructor.
190
+ * @param skipFrames Number of frames to skip. By default, the first frame would be the invocation of the StackTrace constructor.
191
191
  * @returns
192
192
  */
193
193
  getStack(skipFrames = 0) {
@@ -303,6 +303,7 @@ var importModule = (name) => {
303
303
  }
304
304
  };
305
305
  var EXPOSED_MODULES = {};
306
+ var inspectCustom = Symbol.for("nodejs.util.inspect.custom");
306
307
  // Annotate the CommonJS export names for ESM import in node:
307
308
  0 && (module.exports = {
308
309
  ErrorHandler,
@@ -317,6 +318,7 @@ var EXPOSED_MODULES = {};
317
318
  exposeModule,
318
319
  failUndefined,
319
320
  importModule,
321
+ inspectCustom,
320
322
  inspectObject,
321
323
  isEqual,
322
324
  isEquatable,
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../../../src/assert.ts", "../../../src/error-handler.ts", "../../../src/error-stream.ts", "../../../src/fail.ts", "../../../src/inspect.ts", "../../../src/log-method.ts", "../../../src/raise.ts", "../../../src/snoop.ts", "../../../src/stack-trace.ts", "../../../src/strings.ts", "../../../src/throw.ts", "../../../src/timeout-warning.ts", "../../../src/todo.ts", "../../../src/devtools-formatter.ts", "../../../src/equality.ts", "../../../src/exposed-modules.ts"],
4
- "sourcesContent": ["//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * A simple syntax sugar to write `value as T` as a statement.\n *\n * NOTE: This does not provide any type safety.\n * It's just for convenience so that autocomplete works for value.\n * It's recommended to check the type URL manually beforehand or use `assertAnyType` instead.\n * @param value\n */\nexport const checkType = <T>(value: T): T => value;\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { EventEmitter } from 'node:events';\n\n/**\n * Listens for global errors.\n */\nexport class ErrorHandler extends EventEmitter {\n _listener: any;\n\n constructor() {\n super();\n\n this._listener = (event: any) => {\n const cause = event.error || event.reason || event;\n const message = cause.stack || cause.message || cause.toString();\n this.emit('error', message);\n\n // Default logging.\n // code event.preventDefault();\n };\n\n // https://developer.mozilla.org/en-US/docs/Web/API/Window/error_event\n window.addEventListener('error', this._listener);\n\n // https://developer.mozilla.org/en-US/docs/Web/API/Window/unhandledrejection_event\n window.addEventListener('unhandledrejection', this._listener);\n }\n\n reset() {\n window.removeEventListener('error', this._listener);\n window.removeEventListener('unhandledrejection', this._listener);\n }\n}\n", "//\n// Copyright 2021 DXOS.org\n//\n\nexport type ErrorHandlerCallback = (error: Error) => void;\n\n/**\n * Represents a stream of errors that entities can expose.\n */\nexport class ErrorStream {\n private _handler: ErrorHandlerCallback | undefined;\n\n private _unhandledErrors = 0;\n\n assertNoUnhandledErrors() {\n if (this._unhandledErrors > 0) {\n throw new Error(\n `Assertion failed: expected no unhandled errors to be thrown, but ${this._unhandledErrors} were thrown.`,\n );\n }\n }\n\n raise(error: Error) {\n if (this._handler) {\n this._handler(error);\n } else {\n this._unhandledError(error);\n }\n }\n\n handle(handler: ErrorHandlerCallback) {\n this._handler = handler;\n }\n\n pipeTo(receiver: ErrorStream) {\n this.handle((error) => receiver.raise(error));\n }\n\n private _unhandledError(error: Error) {\n this._unhandledErrors++;\n\n setTimeout(() => {\n throw error;\n });\n }\n}\n", "//\n// Copyright 2021 DXOS.org\n//\n\n/**\n * Should be used in expressions where values are cheked not to be null or undefined.\n *\n * Example:\n *\n * ```\n * const value: string | undefined;\n *\n * callMethod(value ?? failUndefined());\n * ```\n */\n// TODO(burdon): Rename failIfUndefined().\nexport const failUndefined = () => {\n throw new Error('Required value was null or undefined.');\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { inspect } from 'node:util';\n\n/**\n * Utility to automatically log debug info.\n *\n * ```\n * // Called via `console.log`.\n * [inspect.custom] () {\n * return inspectObject(this);\n * }\n *\n * // Called via `JSON.stringify`.\n * toJSON () {\n * return { ... };\n * }\n * ```\n */\nexport const inspectObject = (obj: any) => {\n const name = Object.getPrototypeOf(obj).constructor.name;\n return obj.toJSON ? `${name}(${inspect(obj.toJSON())})` : String(obj);\n};\n", "//\n// Copyright 2021 DXOS.org\n//\n\nexport function logMethod(\n target: any,\n propertyName: string,\n descriptor: TypedPropertyDescriptor<(...args: any) => any>,\n) {\n const method = descriptor.value!;\n descriptor.value = function (this: any, ...args: any) {\n console.log(`Called ${target.constructor.name}.${propertyName} ${args}`);\n try {\n const result = method.apply(this, args);\n if (typeof result.catch === 'function') {\n result.catch((err: any) => {\n console.log(`Rejected ${target.constructor.name}.${propertyName}`, err);\n });\n }\n return result;\n } catch (err: any) {\n console.log(`Thrown ${target.constructor.name}.${propertyName}`, err);\n throw err;\n }\n };\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * Immediatelly throws an error passed as an argument.\n *\n * Usefull for throwing errors from inside expressions.\n * For example:\n * ```\n * const item = model.getById(someId) ?? raise(new Error('Not found'));\n * ```\n * @param error\n */\nexport const raise = (error: Error): never => {\n throw error;\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nexport enum SnoopLevel {\n DEFAULT = 0,\n VERBOSE = 1,\n BOLD = 2,\n}\n\n/**\n * Utils for debug logging of functions.\n */\n// TODO(burdon): Integrate with log/spyglass.\nexport class Snoop {\n static stackFunction(err: Error) {\n const stack = err.stack!.split('\\n');\n const match = stack[2].match(/.+\\((.+)\\).*/);\n if (match) {\n const [file, line] = match[1].split(':');\n return `[${file.substring(file.lastIndexOf('/') + 1)}:${line}]`;\n }\n }\n\n constructor(private readonly _context?: string) {}\n\n get verbose() {\n return SnoopLevel.VERBOSE;\n }\n\n get bold() {\n return SnoopLevel.BOLD;\n }\n\n format(prefix: string, name: string, args: string, level: SnoopLevel) {\n const pre = prefix.repeat(level === SnoopLevel.BOLD ? 8 : 2);\n const label = this._context ? `${this._context}.${name}` : name;\n const line = `${pre} ${label}${args}`;\n return level === SnoopLevel.BOLD ? [pre, line, pre].join('\\n') : line;\n }\n\n in(label: string, level: SnoopLevel, ...args: any[]) {\n return this.format('<', label, level === SnoopLevel.DEFAULT ? '' : `(${String(...args)})`, level);\n }\n\n out(label: string, level: SnoopLevel, result: any) {\n return this.format('>', label, level === SnoopLevel.DEFAULT ? '' : ` = ${String(result)}`, level);\n }\n\n sync(f: any, label?: string, level: SnoopLevel = SnoopLevel.VERBOSE) {\n label = label ?? Snoop.stackFunction(new Error());\n return (...args: any[]) => {\n console.log(this.in(label ?? '', level, ...args));\n const r = f(...args);\n console.log(this.out(label ?? '', level, r));\n return r;\n };\n }\n\n async(f: any, label?: string, level: SnoopLevel = SnoopLevel.VERBOSE) {\n label = label ?? Snoop.stackFunction(new Error());\n return async (...args: any[]) => {\n console.log(this.in(label ?? '', level, ...args));\n const r = await f(...args);\n console.log(this.out(label ?? '', level, r));\n return r;\n };\n }\n}\n\nexport const snoop = new Snoop();\n", "//\n// Copyright 2021 DXOS.org\n//\n\n/**\n * Allows to capture stack-traces.\n *\n * Will capture the stack trace at the point where the class is created.\n * Stack traces are formatted lazily only when `getStack` is called.\n *\n * Formatting is significantly more expensive than capture so only call\n * getStack when you need them.\n */\nexport class StackTrace {\n private _stack: Error;\n\n constructor() {\n this._stack = new Error();\n }\n\n /**\n * Get stack formatted as string.\n *\n * @param skipFrames Number of frames to skip. By default the first frame would be the invocation of the StackTrace constructor.\n * @returns\n */\n getStack(skipFrames = 0) {\n const stack = this._stack.stack!.split('\\n');\n return stack.slice(skipFrames + 2).join('\\n');\n }\n\n getStackArray(skipFrames = 0) {\n const stack = this._stack.stack!.split('\\n');\n return stack.slice(skipFrames + 2);\n }\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\nexport const truncate = (str = '', length = 8, pad: boolean | string = false) => {\n if (str.length >= length - 1) {\n return str.substring(0, length - 1) + '…';\n } else {\n return pad ? str.padEnd(length, typeof pad === 'boolean' ? ' ' : pad[0]) : str;\n }\n};\n\nexport const truncateKey = (key: any, length = 8) => {\n const str = String(key);\n if (str.length <= length) {\n return str;\n }\n\n return str.slice(0, length);\n\n // return start\n // ? `${str.slice(0, length)}...`\n // : `${str.substring(0, length / 2)}...${str.substring(str.length - length / 2)}`;\n};\n", "//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * Wrapper for async tests.\n * @param {Function} test - Async test\n * @param errType\n * @return {Promise<void>}\n */\nexport const expectToThrow = async (test: () => void, errType = Error) => {\n let thrown;\n try {\n await test();\n } catch (err) {\n thrown = err;\n }\n\n if (thrown === undefined || !(thrown instanceof errType)) {\n throw new Error(`Expected function to throw instance of ${errType.prototype.name}`);\n }\n};\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { StackTrace } from './stack-trace';\n\n/**\n * Prints a warning to console if the action takes longer then specified timeout. No errors are thrown.\n *\n * @param timeout Timeout in milliseconds after which warning is printed.\n * @param context Context description that would be included in the printed message.\n * @param body Action which is timed.\n */\nexport const warnAfterTimeout = async <T>(timeout: number, context: string, body: () => Promise<T>): Promise<T> => {\n const stack = new StackTrace();\n const timeoutId = setTimeout(() => {\n console.warn(\n `Action \\`${context}\\` is taking more then ${timeout.toLocaleString()}ms to complete. This might be a bug.\\n${stack.getStack()}`,\n );\n }, timeout);\n try {\n return await body();\n } finally {\n clearTimeout(timeoutId);\n }\n};\n\n/**\n * A decorator that prints a warning to console if method execution time exceeds specified timeout.\n *\n * ```typescript\n * class Foo {\n * @timed(5_000)\n * async doStuff() {\n * // long task\n * }\n * }\n * ```\n *\n * This is useful for debugging code that might deadlock.\n *\n * @param timeout Timeout in milliseconds after which the warning is printed.\n */\nexport function timed(timeout: number) {\n return (target: any, propertyName: string, descriptor: TypedPropertyDescriptor<(...args: any) => any>) => {\n const method = descriptor.value!;\n descriptor.value = function (this: any, ...args: any) {\n return warnAfterTimeout(timeout, `${target.constructor.name}.${propertyName}`, () => method.apply(this, args));\n };\n };\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * Throws an error. Can be used in an expression instead of a value\n */\nexport const todo = (message?: string): never => {\n throw new Error(message ?? 'Not implemented.');\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\n/**\n * Lets types provide custom formatters for the Chrome Devtools.\n *\n * https://www.mattzeunert.com/2016/02/19/custom-chrome-devtools-object-formatters.html\n * NOTE: Must be enabled in chrome devtools preferences.\n *\n * @example\n * ```typescript\n * class MyType {\n * get [devtoolsFormatter] (): DevtoolsFormatter {\n * ...\n * }\n * ```\n */\n\nexport const devtoolsFormatter = Symbol.for('devtoolsFormatter');\n\nexport type JsonML = [string, Record<string, any>?, ...(JsonML | string)[]];\n\nexport interface DevtoolsFormatter {\n /**\n * NOTE: Make sure to do an instance check and return null if the object is not of the correct type.\n */\n header: (config?: any) => JsonML | null;\n hasBody?: (config?: any) => boolean;\n body?: (config?: any) => JsonML | null;\n}\n\n/**\n * Types that implement this interface can provide custom formatters for the Chrome Devtools.\n *\n * https://firefox-source-docs.mozilla.org/devtools-user/custom_formatters/index.html\n */\nexport interface CustomDevtoolsFormattable {\n get [devtoolsFormatter](): DevtoolsFormatter;\n}\n\nconst register = () => {\n if (typeof window !== 'undefined') {\n ((window as any).devtoolsFormatters ??= []).push({\n header: (value: any, config: any) => {\n const formatter = value[devtoolsFormatter];\n if (formatter === undefined) {\n return null;\n }\n if (typeof formatter !== 'object' || formatter === null || typeof formatter.header !== 'function') {\n throw new Error(`Invalid devtools formatter for ${value.constructor.name}`);\n }\n\n return formatter.header(config);\n },\n hasBody: (value: any, config: any) => {\n const formatter = value[devtoolsFormatter];\n if (!formatter || !formatter.hasBody) {\n return false;\n }\n\n return formatter.hasBody(config);\n },\n body: (value: any, config: any) => {\n const formatter = value[devtoolsFormatter];\n if (!formatter || !formatter.body) {\n return null;\n }\n\n return formatter.body(config);\n },\n });\n }\n};\n\nregister();\n", "//\n// Copyright 2023 DXOS.org\n//\n\nexport const equalsSymbol = Symbol.for('dxos.common.equals');\n\nexport interface Equatable {\n [equalsSymbol]: (other: any) => boolean;\n}\n\n// TODO(dmaretskyi): export to @dxos/traits.\n// TODO(dmaretskyi): Hash trait for maps?\n\nexport const isEquatable = (value: any): value is Equatable => {\n return typeof value === 'object' && value !== null && typeof value[equalsSymbol] === 'function';\n};\n\nexport const isEqual = (value: Equatable, other: any) => {\n return value[equalsSymbol](other);\n};\n\n/**\n * Feed this as a third argument to `_.isEqualWith` to compare objects with `Equatable` interface.\n */\nexport const loadashEqualityFn = (value: any, other: any): boolean | undefined => {\n if (!isEquatable(value)) {\n return undefined;\n }\n return isEqual(value, other);\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\n/**\n * Allows to register a module to be used later during debugging.\n *\n * ```ts\n * import * as keys from '@dxos/keys';\n * exposeModule('@dxos/keys', keys);\n *\n * ...\n *\n * const { PublicKey } = importModule('@dxos/keys');\n * ```\n *\n * Overwrites the module if it already exists.\n */\nexport const exposeModule = (name: string, module: any) => {\n EXPOSED_MODULES[name] = module;\n};\n\n/**\n * Imports a previously exposed module by its name.\n * Throws an error if the module is not found.\n *\n * @param {string} name - The name of the module to import.\n * @returns {any} The imported module.\n * @throws {Error} If the module is not exposed.\n */\nexport const importModule = (name: string) => {\n if (EXPOSED_MODULES[name]) {\n return EXPOSED_MODULES[name];\n } else {\n throw new Error(`Module ${name} is not exposed.`);\n }\n};\n\nconst EXPOSED_MODULES: Record<string, any> = {};\n"],
5
- "mappings": "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",
6
- "names": ["checkType", "value", "ErrorHandler", "EventEmitter", "constructor", "_listener", "event", "cause", "error", "reason", "message", "stack", "toString", "emit", "window", "addEventListener", "reset", "removeEventListener", "ErrorStream", "_unhandledErrors", "assertNoUnhandledErrors", "Error", "raise", "_handler", "_unhandledError", "handle", "handler", "pipeTo", "receiver", "setTimeout", "failUndefined", "inspectObject", "obj", "name", "Object", "getPrototypeOf", "toJSON", "inspect", "String", "logMethod", "target", "propertyName", "descriptor", "method", "args", "console", "log", "result", "apply", "catch", "err", "SnoopLevel", "Snoop", "stackFunction", "split", "match", "file", "line", "substring", "lastIndexOf", "_context", "verbose", "bold", "format", "prefix", "level", "pre", "repeat", "label", "join", "in", "out", "sync", "f", "r", "async", "snoop", "StackTrace", "_stack", "getStack", "skipFrames", "slice", "getStackArray", "truncate", "str", "length", "pad", "padEnd", "truncateKey", "key", "expectToThrow", "test", "errType", "thrown", "undefined", "prototype", "warnAfterTimeout", "timeout", "context", "body", "timeoutId", "warn", "toLocaleString", "clearTimeout", "timed", "todo", "devtoolsFormatter", "Symbol", "for", "register", "devtoolsFormatters", "push", "header", "config", "formatter", "hasBody", "equalsSymbol", "isEquatable", "isEqual", "other", "loadashEqualityFn", "exposeModule", "module", "EXPOSED_MODULES", "importModule"]
3
+ "sources": ["../../../src/assert.ts", "../../../src/error-handler.ts", "../../../src/error-stream.ts", "../../../src/fail.ts", "../../../src/inspect.ts", "../../../src/log-method.ts", "../../../src/raise.ts", "../../../src/snoop.ts", "../../../src/stack-trace.ts", "../../../src/strings.ts", "../../../src/throw.ts", "../../../src/timeout-warning.ts", "../../../src/todo.ts", "../../../src/devtools-formatter.ts", "../../../src/equality.ts", "../../../src/exposed-modules.ts", "../../../src/inspect-custom.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * A simple syntax sugar to write `value as T` as a statement.\n *\n * NOTE: This does not provide any type safety.\n * It's just for convenience so that autocomplete works for value.\n * It's recommended to check the type URL manually beforehand or use `assertAnyType` instead.\n * @param value\n */\nexport const checkType = <T>(value: T): T => value;\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { EventEmitter } from 'node:events';\n\n/**\n * Listens for global errors.\n */\nexport class ErrorHandler extends EventEmitter {\n _listener: any;\n\n constructor() {\n super();\n\n this._listener = (event: any) => {\n const cause = event.error || event.reason || event;\n const message = cause.stack || cause.message || cause.toString();\n this.emit('error', message);\n\n // Default logging.\n // code event.preventDefault();\n };\n\n // https://developer.mozilla.org/en-US/docs/Web/API/Window/error_event\n window.addEventListener('error', this._listener);\n\n // https://developer.mozilla.org/en-US/docs/Web/API/Window/unhandledrejection_event\n window.addEventListener('unhandledrejection', this._listener);\n }\n\n reset() {\n window.removeEventListener('error', this._listener);\n window.removeEventListener('unhandledrejection', this._listener);\n }\n}\n", "//\n// Copyright 2021 DXOS.org\n//\n\nexport type ErrorHandlerCallback = (error: Error) => void;\n\n/**\n * Represents a stream of errors that entities can expose.\n */\nexport class ErrorStream {\n private _handler: ErrorHandlerCallback | undefined;\n\n private _unhandledErrors = 0;\n\n assertNoUnhandledErrors() {\n if (this._unhandledErrors > 0) {\n throw new Error(\n `Assertion failed: expected no unhandled errors to be thrown, but ${this._unhandledErrors} were thrown.`,\n );\n }\n }\n\n raise(error: Error) {\n if (this._handler) {\n this._handler(error);\n } else {\n this._unhandledError(error);\n }\n }\n\n handle(handler: ErrorHandlerCallback) {\n this._handler = handler;\n }\n\n pipeTo(receiver: ErrorStream) {\n this.handle((error) => receiver.raise(error));\n }\n\n private _unhandledError(error: Error) {\n this._unhandledErrors++;\n\n setTimeout(() => {\n throw error;\n });\n }\n}\n", "//\n// Copyright 2021 DXOS.org\n//\n\n/**\n * Should be used in expressions where values are cheked not to be null or undefined.\n *\n * Example:\n *\n * ```\n * const value: string | undefined;\n *\n * callMethod(value ?? failUndefined());\n * ```\n */\n// TODO(burdon): Rename failIfUndefined().\nexport const failUndefined = () => {\n throw new Error('Required value was null or undefined.');\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { inspect } from 'node:util';\n\n/**\n * Utility to automatically log debug info.\n *\n * ```\n * // Called via `console.log`.\n * [inspect.custom] () {\n * return inspectObject(this);\n * }\n *\n * // Called via `JSON.stringify`.\n * toJSON () {\n * return { ... };\n * }\n * ```\n */\nexport const inspectObject = (obj: any) => {\n const name = Object.getPrototypeOf(obj).constructor.name;\n return obj.toJSON ? `${name}(${inspect(obj.toJSON())})` : String(obj);\n};\n", "//\n// Copyright 2021 DXOS.org\n//\n\nexport function logMethod(\n target: any,\n propertyName: string,\n descriptor: TypedPropertyDescriptor<(...args: any) => any>,\n) {\n const method = descriptor.value!;\n descriptor.value = function (this: any, ...args: any) {\n console.log(`Called ${target.constructor.name}.${propertyName} ${args}`);\n try {\n const result = method.apply(this, args);\n if (typeof result.catch === 'function') {\n result.catch((err: any) => {\n console.log(`Rejected ${target.constructor.name}.${propertyName}`, err);\n });\n }\n return result;\n } catch (err: any) {\n console.log(`Thrown ${target.constructor.name}.${propertyName}`, err);\n throw err;\n }\n };\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * Immediatelly throws an error passed as an argument.\n *\n * Usefull for throwing errors from inside expressions.\n * For example:\n * ```\n * const item = model.getById(someId) ?? raise(new Error('Not found'));\n * ```\n * @param error\n */\nexport const raise = (error: Error): never => {\n throw error;\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nexport enum SnoopLevel {\n DEFAULT = 0,\n VERBOSE = 1,\n BOLD = 2,\n}\n\n/**\n * Utils for debug logging of functions.\n */\n// TODO(burdon): Integrate with log/spyglass.\nexport class Snoop {\n static stackFunction(err: Error) {\n const stack = err.stack!.split('\\n');\n const match = stack[2].match(/.+\\((.+)\\).*/);\n if (match) {\n const [file, line] = match[1].split(':');\n return `[${file.substring(file.lastIndexOf('/') + 1)}:${line}]`;\n }\n }\n\n constructor(private readonly _context?: string) {}\n\n get verbose() {\n return SnoopLevel.VERBOSE;\n }\n\n get bold() {\n return SnoopLevel.BOLD;\n }\n\n format(prefix: string, name: string, args: string, level: SnoopLevel) {\n const pre = prefix.repeat(level === SnoopLevel.BOLD ? 8 : 2);\n const label = this._context ? `${this._context}.${name}` : name;\n const line = `${pre} ${label}${args}`;\n return level === SnoopLevel.BOLD ? [pre, line, pre].join('\\n') : line;\n }\n\n in(label: string, level: SnoopLevel, ...args: any[]) {\n return this.format('<', label, level === SnoopLevel.DEFAULT ? '' : `(${String(...args)})`, level);\n }\n\n out(label: string, level: SnoopLevel, result: any) {\n return this.format('>', label, level === SnoopLevel.DEFAULT ? '' : ` = ${String(result)}`, level);\n }\n\n sync(f: any, label?: string, level: SnoopLevel = SnoopLevel.VERBOSE) {\n label = label ?? Snoop.stackFunction(new Error());\n return (...args: any[]) => {\n console.log(this.in(label ?? '', level, ...args));\n const r = f(...args);\n console.log(this.out(label ?? '', level, r));\n return r;\n };\n }\n\n async(f: any, label?: string, level: SnoopLevel = SnoopLevel.VERBOSE) {\n label = label ?? Snoop.stackFunction(new Error());\n return async (...args: any[]) => {\n console.log(this.in(label ?? '', level, ...args));\n const r = await f(...args);\n console.log(this.out(label ?? '', level, r));\n return r;\n };\n }\n}\n\nexport const snoop = new Snoop();\n", "//\n// Copyright 2021 DXOS.org\n//\n\n/**\n * Will capture the stack trace at the point where the class is created.\n * Stack traces are formatted lazily only when `getStack` is called.\n * Formatting is significantly more expensive than capture so only call getStack when you need them.\n */\nexport class StackTrace {\n private _stack: Error;\n\n constructor() {\n this._stack = new Error();\n }\n\n /**\n * Get stack formatted as string.\n * @param skipFrames Number of frames to skip. By default, the first frame would be the invocation of the StackTrace constructor.\n * @returns\n */\n getStack(skipFrames = 0) {\n const stack = this._stack.stack!.split('\\n');\n return stack.slice(skipFrames + 2).join('\\n');\n }\n\n getStackArray(skipFrames = 0) {\n const stack = this._stack.stack!.split('\\n');\n return stack.slice(skipFrames + 2);\n }\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\nexport const truncate = (str = '', length = 8, pad: boolean | string = false) => {\n if (str.length >= length - 1) {\n return str.substring(0, length - 1) + '…';\n } else {\n return pad ? str.padEnd(length, typeof pad === 'boolean' ? ' ' : pad[0]) : str;\n }\n};\n\nexport const truncateKey = (key: any, length = 8) => {\n const str = String(key);\n if (str.length <= length) {\n return str;\n }\n\n return str.slice(0, length);\n\n // return start\n // ? `${str.slice(0, length)}...`\n // : `${str.substring(0, length / 2)}...${str.substring(str.length - length / 2)}`;\n};\n", "//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * Wrapper for async tests.\n * @param {Function} test - Async test\n * @param errType\n * @return {Promise<void>}\n *\n * @deprecated Use vitests `expect(() => ...).toThrowError();` instead.\n */\nexport const expectToThrow = async (test: () => void, errType = Error) => {\n let thrown;\n try {\n await test();\n } catch (err) {\n thrown = err;\n }\n\n if (thrown === undefined || !(thrown instanceof errType)) {\n throw new Error(`Expected function to throw instance of ${errType.prototype.name}`);\n }\n};\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { StackTrace } from './stack-trace';\n\n/**\n * Prints a warning to console if the action takes longer then specified timeout. No errors are thrown.\n *\n * @param timeout Timeout in milliseconds after which warning is printed.\n * @param context Context description that would be included in the printed message.\n * @param body Action which is timed.\n */\nexport const warnAfterTimeout = async <T>(timeout: number, context: string, body: () => Promise<T>): Promise<T> => {\n const stack = new StackTrace();\n const timeoutId = setTimeout(() => {\n console.warn(\n `Action \\`${context}\\` is taking more then ${timeout.toLocaleString()}ms to complete. This might be a bug.\\n${stack.getStack()}`,\n );\n }, timeout);\n try {\n return await body();\n } finally {\n clearTimeout(timeoutId);\n }\n};\n\n/**\n * A decorator that prints a warning to console if method execution time exceeds specified timeout.\n *\n * ```typescript\n * class Foo {\n * @timed(5_000)\n * async doStuff() {\n * // long task\n * }\n * }\n * ```\n *\n * This is useful for debugging code that might deadlock.\n *\n * @param timeout Timeout in milliseconds after which the warning is printed.\n */\nexport function timed(timeout: number) {\n return (target: any, propertyName: string, descriptor: TypedPropertyDescriptor<(...args: any) => any>) => {\n const method = descriptor.value!;\n descriptor.value = function (this: any, ...args: any) {\n return warnAfterTimeout(timeout, `${target.constructor.name}.${propertyName}`, () => method.apply(this, args));\n };\n };\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * Throws an error. Can be used in an expression instead of a value\n */\nexport const todo = (message?: string): never => {\n throw new Error(message ?? 'Not implemented.');\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\n/**\n * Lets types provide custom formatters for the Chrome Devtools.\n *\n * https://www.mattzeunert.com/2016/02/19/custom-chrome-devtools-object-formatters.html\n * NOTE: Must be enabled in chrome devtools preferences.\n *\n * @example\n * ```typescript\n * class MyType {\n * get [devtoolsFormatter] (): DevtoolsFormatter {\n * ...\n * }\n * ```\n */\n\nexport const devtoolsFormatter = Symbol.for('devtoolsFormatter');\n\nexport type JsonML = [string, Record<string, any>?, ...(JsonML | string)[]];\n\nexport interface DevtoolsFormatter {\n /**\n * NOTE: Make sure to do an instance check and return null if the object is not of the correct type.\n */\n header: (config?: any) => JsonML | null;\n hasBody?: (config?: any) => boolean;\n body?: (config?: any) => JsonML | null;\n}\n\n/**\n * Types that implement this interface can provide custom formatters for the Chrome Devtools.\n *\n * https://firefox-source-docs.mozilla.org/devtools-user/custom_formatters/index.html\n */\nexport interface CustomDevtoolsFormattable {\n get [devtoolsFormatter](): DevtoolsFormatter;\n}\n\nconst register = () => {\n if (typeof window !== 'undefined') {\n ((window as any).devtoolsFormatters ??= []).push({\n header: (value: any, config: any) => {\n const formatter = value[devtoolsFormatter];\n if (formatter === undefined) {\n return null;\n }\n if (typeof formatter !== 'object' || formatter === null || typeof formatter.header !== 'function') {\n throw new Error(`Invalid devtools formatter for ${value.constructor.name}`);\n }\n\n return formatter.header(config);\n },\n hasBody: (value: any, config: any) => {\n const formatter = value[devtoolsFormatter];\n if (!formatter || !formatter.hasBody) {\n return false;\n }\n\n return formatter.hasBody(config);\n },\n body: (value: any, config: any) => {\n const formatter = value[devtoolsFormatter];\n if (!formatter || !formatter.body) {\n return null;\n }\n\n return formatter.body(config);\n },\n });\n }\n};\n\nregister();\n", "//\n// Copyright 2023 DXOS.org\n//\n\nexport const equalsSymbol = Symbol.for('dxos.common.equals');\n\nexport interface Equatable {\n [equalsSymbol]: (other: any) => boolean;\n}\n\n// TODO(dmaretskyi): export to @dxos/traits.\n// TODO(dmaretskyi): Hash trait for maps?\n\nexport const isEquatable = (value: any): value is Equatable => {\n return typeof value === 'object' && value !== null && typeof value[equalsSymbol] === 'function';\n};\n\nexport const isEqual = (value: Equatable, other: any) => {\n return value[equalsSymbol](other);\n};\n\n/**\n * Feed this as a third argument to `_.isEqualWith` to compare objects with `Equatable` interface.\n */\nexport const loadashEqualityFn = (value: any, other: any): boolean | undefined => {\n if (!isEquatable(value)) {\n return undefined;\n }\n return isEqual(value, other);\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\n/**\n * Allows to register a module to be used later during debugging.\n *\n * ```ts\n * import * as keys from '@dxos/keys';\n * exposeModule('@dxos/keys', keys);\n *\n * ...\n *\n * const { PublicKey } = importModule('@dxos/keys');\n * ```\n *\n * Overwrites the module if it already exists.\n */\nexport const exposeModule = (name: string, module: any) => {\n EXPOSED_MODULES[name] = module;\n};\n\n/**\n * Imports a previously exposed module by its name.\n * Throws an error if the module is not found.\n *\n * @param {string} name - The name of the module to import.\n * @returns {any} The imported module.\n * @throws {Error} If the module is not exposed.\n */\nexport const importModule = (name: string) => {\n if (EXPOSED_MODULES[name]) {\n return EXPOSED_MODULES[name];\n } else {\n throw new Error(`Module ${name} is not exposed.`);\n }\n};\n\nconst EXPOSED_MODULES: Record<string, any> = {};\n", "//\n// Copyright 2024 DXOS.org\n//\n\n/**\n * Using this allows code to be written in a portable fashion, so that the custom inspect function is used in an Node.js environment and ignored in the browser.\n */\nexport const inspectCustom = Symbol.for('nodejs.util.inspect.custom');\n"],
5
+ "mappings": "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",
6
+ "names": ["checkType", "value", "ErrorHandler", "EventEmitter", "constructor", "_listener", "event", "cause", "error", "reason", "message", "stack", "toString", "emit", "window", "addEventListener", "reset", "removeEventListener", "ErrorStream", "_unhandledErrors", "assertNoUnhandledErrors", "Error", "raise", "_handler", "_unhandledError", "handle", "handler", "pipeTo", "receiver", "setTimeout", "failUndefined", "inspectObject", "obj", "name", "Object", "getPrototypeOf", "toJSON", "inspect", "String", "logMethod", "target", "propertyName", "descriptor", "method", "args", "console", "log", "result", "apply", "catch", "err", "SnoopLevel", "Snoop", "stackFunction", "split", "match", "file", "line", "substring", "lastIndexOf", "_context", "verbose", "bold", "format", "prefix", "level", "pre", "repeat", "label", "join", "in", "out", "sync", "f", "r", "async", "snoop", "StackTrace", "_stack", "getStack", "skipFrames", "slice", "getStackArray", "truncate", "str", "length", "pad", "padEnd", "truncateKey", "key", "expectToThrow", "test", "errType", "thrown", "undefined", "prototype", "warnAfterTimeout", "timeout", "context", "body", "timeoutId", "warn", "toLocaleString", "clearTimeout", "timed", "todo", "devtoolsFormatter", "Symbol", "for", "register", "devtoolsFormatters", "push", "header", "config", "formatter", "hasBody", "equalsSymbol", "isEquatable", "isEqual", "other", "loadashEqualityFn", "exposeModule", "module", "EXPOSED_MODULES", "importModule", "inspectCustom"]
7
7
  }
@@ -1 +1 @@
1
- {"inputs":{"packages/common/debug/src/assert.ts":{"bytes":1334,"imports":[],"format":"esm"},"packages/common/debug/src/error-handler.ts":{"bytes":3608,"imports":[{"path":"node:events","kind":"import-statement","external":true}],"format":"esm"},"packages/common/debug/src/error-stream.ts":{"bytes":3457,"imports":[],"format":"esm"},"packages/common/debug/src/fail.ts":{"bytes":1405,"imports":[],"format":"esm"},"packages/common/debug/src/inspect.ts":{"bytes":2029,"imports":[{"path":"node:util","kind":"import-statement","external":true}],"format":"esm"},"packages/common/debug/src/log-method.ts":{"bytes":3084,"imports":[],"format":"esm"},"packages/common/debug/src/raise.ts":{"bytes":1245,"imports":[],"format":"esm"},"packages/common/debug/src/snoop.ts":{"bytes":7985,"imports":[],"format":"esm"},"packages/common/debug/src/stack-trace.ts":{"bytes":3190,"imports":[],"format":"esm"},"packages/common/debug/src/strings.ts":{"bytes":2538,"imports":[],"format":"esm"},"packages/common/debug/src/throw.ts":{"bytes":1949,"imports":[],"format":"esm"},"packages/common/debug/src/timeout-warning.ts":{"bytes":5199,"imports":[{"path":"packages/common/debug/src/stack-trace.ts","kind":"import-statement","original":"./stack-trace"}],"format":"esm"},"packages/common/debug/src/todo.ts":{"bytes":956,"imports":[],"format":"esm"},"packages/common/debug/src/devtools-formatter.ts":{"bytes":6253,"imports":[],"format":"esm"},"packages/common/debug/src/equality.ts":{"bytes":2776,"imports":[],"format":"esm"},"packages/common/debug/src/exposed-modules.ts":{"bytes":3029,"imports":[],"format":"esm"},"packages/common/debug/src/index.ts":{"bytes":1890,"imports":[{"path":"packages/common/debug/src/assert.ts","kind":"import-statement","original":"./assert"},{"path":"packages/common/debug/src/error-handler.ts","kind":"import-statement","original":"./error-handler"},{"path":"packages/common/debug/src/error-stream.ts","kind":"import-statement","original":"./error-stream"},{"path":"packages/common/debug/src/fail.ts","kind":"import-statement","original":"./fail"},{"path":"packages/common/debug/src/inspect.ts","kind":"import-statement","original":"./inspect"},{"path":"packages/common/debug/src/log-method.ts","kind":"import-statement","original":"./log-method"},{"path":"packages/common/debug/src/raise.ts","kind":"import-statement","original":"./raise"},{"path":"packages/common/debug/src/snoop.ts","kind":"import-statement","original":"./snoop"},{"path":"packages/common/debug/src/stack-trace.ts","kind":"import-statement","original":"./stack-trace"},{"path":"packages/common/debug/src/strings.ts","kind":"import-statement","original":"./strings"},{"path":"packages/common/debug/src/throw.ts","kind":"import-statement","original":"./throw"},{"path":"packages/common/debug/src/timeout-warning.ts","kind":"import-statement","original":"./timeout-warning"},{"path":"packages/common/debug/src/todo.ts","kind":"import-statement","original":"./todo"},{"path":"packages/common/debug/src/devtools-formatter.ts","kind":"import-statement","original":"./devtools-formatter"},{"path":"packages/common/debug/src/equality.ts","kind":"import-statement","original":"./equality"},{"path":"packages/common/debug/src/exposed-modules.ts","kind":"import-statement","original":"./exposed-modules"}],"format":"esm"}},"outputs":{"packages/common/debug/dist/lib/node/index.cjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":23136},"packages/common/debug/dist/lib/node/index.cjs":{"imports":[{"path":"node:events","kind":"import-statement","external":true},{"path":"node:util","kind":"import-statement","external":true}],"exports":["ErrorHandler","ErrorStream","Snoop","SnoopLevel","StackTrace","checkType","devtoolsFormatter","equalsSymbol","expectToThrow","exposeModule","failUndefined","importModule","inspectObject","isEqual","isEquatable","loadashEqualityFn","logMethod","raise","snoop","timed","todo","truncate","truncateKey","warnAfterTimeout"],"entryPoint":"packages/common/debug/src/index.ts","inputs":{"packages/common/debug/src/assert.ts":{"bytesInOutput":34},"packages/common/debug/src/index.ts":{"bytesInOutput":0},"packages/common/debug/src/error-handler.ts":{"bytesInOutput":600},"packages/common/debug/src/error-stream.ts":{"bytesInOutput":655},"packages/common/debug/src/fail.ts":{"bytesInOutput":91},"packages/common/debug/src/inspect.ts":{"bytesInOutput":204},"packages/common/debug/src/log-method.ts":{"bytesInOutput":597},"packages/common/debug/src/raise.ts":{"bytesInOutput":43},"packages/common/debug/src/snoop.ts":{"bytesInOutput":1784},"packages/common/debug/src/stack-trace.ts":{"bytesInOutput":534},"packages/common/debug/src/strings.ts":{"bytesInOutput":396},"packages/common/debug/src/throw.ts":{"bytesInOutput":290},"packages/common/debug/src/timeout-warning.ts":{"bytesInOutput":664},"packages/common/debug/src/todo.ts":{"bytesInOutput":79},"packages/common/debug/src/devtools-formatter.ts":{"bytesInOutput":1035},"packages/common/debug/src/equality.ts":{"bytesInOutput":391},"packages/common/debug/src/exposed-modules.ts":{"bytesInOutput":271}},"bytes":8745}}}
1
+ {"inputs":{"packages/common/debug/src/assert.ts":{"bytes":1334,"imports":[],"format":"esm"},"packages/common/debug/src/error-handler.ts":{"bytes":3608,"imports":[{"path":"node:events","kind":"import-statement","external":true}],"format":"esm"},"packages/common/debug/src/error-stream.ts":{"bytes":3457,"imports":[],"format":"esm"},"packages/common/debug/src/fail.ts":{"bytes":1405,"imports":[],"format":"esm"},"packages/common/debug/src/inspect.ts":{"bytes":2029,"imports":[{"path":"node:util","kind":"import-statement","external":true}],"format":"esm"},"packages/common/debug/src/log-method.ts":{"bytes":3084,"imports":[],"format":"esm"},"packages/common/debug/src/raise.ts":{"bytes":1245,"imports":[],"format":"esm"},"packages/common/debug/src/snoop.ts":{"bytes":7985,"imports":[],"format":"esm"},"packages/common/debug/src/stack-trace.ts":{"bytes":3058,"imports":[],"format":"esm"},"packages/common/debug/src/strings.ts":{"bytes":2538,"imports":[],"format":"esm"},"packages/common/debug/src/throw.ts":{"bytes":2132,"imports":[],"format":"esm"},"packages/common/debug/src/timeout-warning.ts":{"bytes":5199,"imports":[{"path":"packages/common/debug/src/stack-trace.ts","kind":"import-statement","original":"./stack-trace"}],"format":"esm"},"packages/common/debug/src/todo.ts":{"bytes":956,"imports":[],"format":"esm"},"packages/common/debug/src/devtools-formatter.ts":{"bytes":6253,"imports":[],"format":"esm"},"packages/common/debug/src/equality.ts":{"bytes":2776,"imports":[],"format":"esm"},"packages/common/debug/src/exposed-modules.ts":{"bytes":3029,"imports":[],"format":"esm"},"packages/common/debug/src/inspect-custom.ts":{"bytes":1110,"imports":[],"format":"esm"},"packages/common/debug/src/index.ts":{"bytes":1996,"imports":[{"path":"packages/common/debug/src/assert.ts","kind":"import-statement","original":"./assert"},{"path":"packages/common/debug/src/error-handler.ts","kind":"import-statement","original":"./error-handler"},{"path":"packages/common/debug/src/error-stream.ts","kind":"import-statement","original":"./error-stream"},{"path":"packages/common/debug/src/fail.ts","kind":"import-statement","original":"./fail"},{"path":"packages/common/debug/src/inspect.ts","kind":"import-statement","original":"./inspect"},{"path":"packages/common/debug/src/log-method.ts","kind":"import-statement","original":"./log-method"},{"path":"packages/common/debug/src/raise.ts","kind":"import-statement","original":"./raise"},{"path":"packages/common/debug/src/snoop.ts","kind":"import-statement","original":"./snoop"},{"path":"packages/common/debug/src/stack-trace.ts","kind":"import-statement","original":"./stack-trace"},{"path":"packages/common/debug/src/strings.ts","kind":"import-statement","original":"./strings"},{"path":"packages/common/debug/src/throw.ts","kind":"import-statement","original":"./throw"},{"path":"packages/common/debug/src/timeout-warning.ts","kind":"import-statement","original":"./timeout-warning"},{"path":"packages/common/debug/src/todo.ts","kind":"import-statement","original":"./todo"},{"path":"packages/common/debug/src/devtools-formatter.ts","kind":"import-statement","original":"./devtools-formatter"},{"path":"packages/common/debug/src/equality.ts","kind":"import-statement","original":"./equality"},{"path":"packages/common/debug/src/exposed-modules.ts","kind":"import-statement","original":"./exposed-modules"},{"path":"packages/common/debug/src/inspect-custom.ts","kind":"import-statement","original":"./inspect-custom"}],"format":"esm"}},"outputs":{"packages/common/debug/dist/lib/node/index.cjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":23553},"packages/common/debug/dist/lib/node/index.cjs":{"imports":[{"path":"node:events","kind":"import-statement","external":true},{"path":"node:util","kind":"import-statement","external":true}],"exports":["ErrorHandler","ErrorStream","Snoop","SnoopLevel","StackTrace","checkType","devtoolsFormatter","equalsSymbol","expectToThrow","exposeModule","failUndefined","importModule","inspectCustom","inspectObject","isEqual","isEquatable","loadashEqualityFn","logMethod","raise","snoop","timed","todo","truncate","truncateKey","warnAfterTimeout"],"entryPoint":"packages/common/debug/src/index.ts","inputs":{"packages/common/debug/src/assert.ts":{"bytesInOutput":34},"packages/common/debug/src/index.ts":{"bytesInOutput":0},"packages/common/debug/src/error-handler.ts":{"bytesInOutput":600},"packages/common/debug/src/error-stream.ts":{"bytesInOutput":655},"packages/common/debug/src/fail.ts":{"bytesInOutput":91},"packages/common/debug/src/inspect.ts":{"bytesInOutput":204},"packages/common/debug/src/log-method.ts":{"bytesInOutput":597},"packages/common/debug/src/raise.ts":{"bytesInOutput":43},"packages/common/debug/src/snoop.ts":{"bytesInOutput":1784},"packages/common/debug/src/stack-trace.ts":{"bytesInOutput":531},"packages/common/debug/src/strings.ts":{"bytesInOutput":396},"packages/common/debug/src/throw.ts":{"bytesInOutput":290},"packages/common/debug/src/timeout-warning.ts":{"bytesInOutput":664},"packages/common/debug/src/todo.ts":{"bytesInOutput":79},"packages/common/debug/src/devtools-formatter.ts":{"bytesInOutput":1035},"packages/common/debug/src/equality.ts":{"bytesInOutput":391},"packages/common/debug/src/exposed-modules.ts":{"bytesInOutput":271},"packages/common/debug/src/inspect-custom.ts":{"bytesInOutput":62}},"bytes":8869}}}
@@ -0,0 +1,322 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+
3
+ // packages/common/debug/src/assert.ts
4
+ var checkType = (value) => value;
5
+
6
+ // packages/common/debug/src/error-handler.ts
7
+ import { EventEmitter } from "node:events";
8
+ var ErrorHandler = class extends EventEmitter {
9
+ constructor() {
10
+ super();
11
+ this._listener = (event) => {
12
+ const cause = event.error || event.reason || event;
13
+ const message = cause.stack || cause.message || cause.toString();
14
+ this.emit("error", message);
15
+ };
16
+ window.addEventListener("error", this._listener);
17
+ window.addEventListener("unhandledrejection", this._listener);
18
+ }
19
+ reset() {
20
+ window.removeEventListener("error", this._listener);
21
+ window.removeEventListener("unhandledrejection", this._listener);
22
+ }
23
+ };
24
+
25
+ // packages/common/debug/src/error-stream.ts
26
+ var ErrorStream = class {
27
+ constructor() {
28
+ this._unhandledErrors = 0;
29
+ }
30
+ assertNoUnhandledErrors() {
31
+ if (this._unhandledErrors > 0) {
32
+ throw new Error(`Assertion failed: expected no unhandled errors to be thrown, but ${this._unhandledErrors} were thrown.`);
33
+ }
34
+ }
35
+ raise(error) {
36
+ if (this._handler) {
37
+ this._handler(error);
38
+ } else {
39
+ this._unhandledError(error);
40
+ }
41
+ }
42
+ handle(handler) {
43
+ this._handler = handler;
44
+ }
45
+ pipeTo(receiver) {
46
+ this.handle((error) => receiver.raise(error));
47
+ }
48
+ _unhandledError(error) {
49
+ this._unhandledErrors++;
50
+ setTimeout(() => {
51
+ throw error;
52
+ });
53
+ }
54
+ };
55
+
56
+ // packages/common/debug/src/fail.ts
57
+ var failUndefined = () => {
58
+ throw new Error("Required value was null or undefined.");
59
+ };
60
+
61
+ // packages/common/debug/src/inspect.ts
62
+ import { inspect } from "node:util";
63
+ var inspectObject = (obj) => {
64
+ const name = Object.getPrototypeOf(obj).constructor.name;
65
+ return obj.toJSON ? `${name}(${inspect(obj.toJSON())})` : String(obj);
66
+ };
67
+
68
+ // packages/common/debug/src/log-method.ts
69
+ function logMethod(target, propertyName, descriptor) {
70
+ const method = descriptor.value;
71
+ descriptor.value = function(...args) {
72
+ console.log(`Called ${target.constructor.name}.${propertyName} ${args}`);
73
+ try {
74
+ const result = method.apply(this, args);
75
+ if (typeof result.catch === "function") {
76
+ result.catch((err) => {
77
+ console.log(`Rejected ${target.constructor.name}.${propertyName}`, err);
78
+ });
79
+ }
80
+ return result;
81
+ } catch (err) {
82
+ console.log(`Thrown ${target.constructor.name}.${propertyName}`, err);
83
+ throw err;
84
+ }
85
+ };
86
+ }
87
+
88
+ // packages/common/debug/src/raise.ts
89
+ var raise = (error) => {
90
+ throw error;
91
+ };
92
+
93
+ // packages/common/debug/src/snoop.ts
94
+ var SnoopLevel;
95
+ (function(SnoopLevel2) {
96
+ SnoopLevel2[SnoopLevel2["DEFAULT"] = 0] = "DEFAULT";
97
+ SnoopLevel2[SnoopLevel2["VERBOSE"] = 1] = "VERBOSE";
98
+ SnoopLevel2[SnoopLevel2["BOLD"] = 2] = "BOLD";
99
+ })(SnoopLevel || (SnoopLevel = {}));
100
+ var Snoop = class _Snoop {
101
+ static stackFunction(err) {
102
+ const stack = err.stack.split("\n");
103
+ const match = stack[2].match(/.+\((.+)\).*/);
104
+ if (match) {
105
+ const [file, line] = match[1].split(":");
106
+ return `[${file.substring(file.lastIndexOf("/") + 1)}:${line}]`;
107
+ }
108
+ }
109
+ constructor(_context) {
110
+ this._context = _context;
111
+ }
112
+ get verbose() {
113
+ return 1;
114
+ }
115
+ get bold() {
116
+ return 2;
117
+ }
118
+ format(prefix, name, args, level) {
119
+ const pre = prefix.repeat(level === 2 ? 8 : 2);
120
+ const label = this._context ? `${this._context}.${name}` : name;
121
+ const line = `${pre} ${label}${args}`;
122
+ return level === 2 ? [
123
+ pre,
124
+ line,
125
+ pre
126
+ ].join("\n") : line;
127
+ }
128
+ in(label, level, ...args) {
129
+ return this.format("<", label, level === 0 ? "" : `(${String(...args)})`, level);
130
+ }
131
+ out(label, level, result) {
132
+ return this.format(">", label, level === 0 ? "" : ` = ${String(result)}`, level);
133
+ }
134
+ sync(f, label, level = 1) {
135
+ label = label ?? _Snoop.stackFunction(new Error());
136
+ return (...args) => {
137
+ console.log(this.in(label ?? "", level, ...args));
138
+ const r = f(...args);
139
+ console.log(this.out(label ?? "", level, r));
140
+ return r;
141
+ };
142
+ }
143
+ async(f, label, level = 1) {
144
+ label = label ?? _Snoop.stackFunction(new Error());
145
+ return async (...args) => {
146
+ console.log(this.in(label ?? "", level, ...args));
147
+ const r = await f(...args);
148
+ console.log(this.out(label ?? "", level, r));
149
+ return r;
150
+ };
151
+ }
152
+ };
153
+ var snoop = new Snoop();
154
+
155
+ // packages/common/debug/src/stack-trace.ts
156
+ var StackTrace = class {
157
+ constructor() {
158
+ this._stack = new Error();
159
+ }
160
+ /**
161
+ * Get stack formatted as string.
162
+ * @param skipFrames Number of frames to skip. By default, the first frame would be the invocation of the StackTrace constructor.
163
+ * @returns
164
+ */
165
+ getStack(skipFrames = 0) {
166
+ const stack = this._stack.stack.split("\n");
167
+ return stack.slice(skipFrames + 2).join("\n");
168
+ }
169
+ getStackArray(skipFrames = 0) {
170
+ const stack = this._stack.stack.split("\n");
171
+ return stack.slice(skipFrames + 2);
172
+ }
173
+ };
174
+
175
+ // packages/common/debug/src/strings.ts
176
+ var truncate = (str = "", length = 8, pad = false) => {
177
+ if (str.length >= length - 1) {
178
+ return str.substring(0, length - 1) + "\u2026";
179
+ } else {
180
+ return pad ? str.padEnd(length, typeof pad === "boolean" ? " " : pad[0]) : str;
181
+ }
182
+ };
183
+ var truncateKey = (key, length = 8) => {
184
+ const str = String(key);
185
+ if (str.length <= length) {
186
+ return str;
187
+ }
188
+ return str.slice(0, length);
189
+ };
190
+
191
+ // packages/common/debug/src/throw.ts
192
+ var expectToThrow = async (test, errType = Error) => {
193
+ let thrown;
194
+ try {
195
+ await test();
196
+ } catch (err) {
197
+ thrown = err;
198
+ }
199
+ if (thrown === void 0 || !(thrown instanceof errType)) {
200
+ throw new Error(`Expected function to throw instance of ${errType.prototype.name}`);
201
+ }
202
+ };
203
+
204
+ // packages/common/debug/src/timeout-warning.ts
205
+ var warnAfterTimeout = async (timeout, context, body) => {
206
+ const stack = new StackTrace();
207
+ const timeoutId = setTimeout(() => {
208
+ console.warn(`Action \`${context}\` is taking more then ${timeout.toLocaleString()}ms to complete. This might be a bug.
209
+ ${stack.getStack()}`);
210
+ }, timeout);
211
+ try {
212
+ return await body();
213
+ } finally {
214
+ clearTimeout(timeoutId);
215
+ }
216
+ };
217
+ function timed(timeout) {
218
+ return (target, propertyName, descriptor) => {
219
+ const method = descriptor.value;
220
+ descriptor.value = function(...args) {
221
+ return warnAfterTimeout(timeout, `${target.constructor.name}.${propertyName}`, () => method.apply(this, args));
222
+ };
223
+ };
224
+ }
225
+
226
+ // packages/common/debug/src/todo.ts
227
+ var todo = (message) => {
228
+ throw new Error(message ?? "Not implemented.");
229
+ };
230
+
231
+ // packages/common/debug/src/devtools-formatter.ts
232
+ var devtoolsFormatter = Symbol.for("devtoolsFormatter");
233
+ var register = () => {
234
+ if (typeof window !== "undefined") {
235
+ (window.devtoolsFormatters ??= []).push({
236
+ header: (value, config) => {
237
+ const formatter = value[devtoolsFormatter];
238
+ if (formatter === void 0) {
239
+ return null;
240
+ }
241
+ if (typeof formatter !== "object" || formatter === null || typeof formatter.header !== "function") {
242
+ throw new Error(`Invalid devtools formatter for ${value.constructor.name}`);
243
+ }
244
+ return formatter.header(config);
245
+ },
246
+ hasBody: (value, config) => {
247
+ const formatter = value[devtoolsFormatter];
248
+ if (!formatter || !formatter.hasBody) {
249
+ return false;
250
+ }
251
+ return formatter.hasBody(config);
252
+ },
253
+ body: (value, config) => {
254
+ const formatter = value[devtoolsFormatter];
255
+ if (!formatter || !formatter.body) {
256
+ return null;
257
+ }
258
+ return formatter.body(config);
259
+ }
260
+ });
261
+ }
262
+ };
263
+ register();
264
+
265
+ // packages/common/debug/src/equality.ts
266
+ var equalsSymbol = Symbol.for("dxos.common.equals");
267
+ var isEquatable = (value) => {
268
+ return typeof value === "object" && value !== null && typeof value[equalsSymbol] === "function";
269
+ };
270
+ var isEqual = (value, other) => {
271
+ return value[equalsSymbol](other);
272
+ };
273
+ var loadashEqualityFn = (value, other) => {
274
+ if (!isEquatable(value)) {
275
+ return void 0;
276
+ }
277
+ return isEqual(value, other);
278
+ };
279
+
280
+ // packages/common/debug/src/exposed-modules.ts
281
+ var exposeModule = (name, module) => {
282
+ EXPOSED_MODULES[name] = module;
283
+ };
284
+ var importModule = (name) => {
285
+ if (EXPOSED_MODULES[name]) {
286
+ return EXPOSED_MODULES[name];
287
+ } else {
288
+ throw new Error(`Module ${name} is not exposed.`);
289
+ }
290
+ };
291
+ var EXPOSED_MODULES = {};
292
+
293
+ // packages/common/debug/src/inspect-custom.ts
294
+ var inspectCustom = Symbol.for("nodejs.util.inspect.custom");
295
+ export {
296
+ ErrorHandler,
297
+ ErrorStream,
298
+ Snoop,
299
+ SnoopLevel,
300
+ StackTrace,
301
+ checkType,
302
+ devtoolsFormatter,
303
+ equalsSymbol,
304
+ expectToThrow,
305
+ exposeModule,
306
+ failUndefined,
307
+ importModule,
308
+ inspectCustom,
309
+ inspectObject,
310
+ isEqual,
311
+ isEquatable,
312
+ loadashEqualityFn,
313
+ logMethod,
314
+ raise,
315
+ snoop,
316
+ timed,
317
+ todo,
318
+ truncate,
319
+ truncateKey,
320
+ warnAfterTimeout
321
+ };
322
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/assert.ts", "../../../src/error-handler.ts", "../../../src/error-stream.ts", "../../../src/fail.ts", "../../../src/inspect.ts", "../../../src/log-method.ts", "../../../src/raise.ts", "../../../src/snoop.ts", "../../../src/stack-trace.ts", "../../../src/strings.ts", "../../../src/throw.ts", "../../../src/timeout-warning.ts", "../../../src/todo.ts", "../../../src/devtools-formatter.ts", "../../../src/equality.ts", "../../../src/exposed-modules.ts", "../../../src/inspect-custom.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * A simple syntax sugar to write `value as T` as a statement.\n *\n * NOTE: This does not provide any type safety.\n * It's just for convenience so that autocomplete works for value.\n * It's recommended to check the type URL manually beforehand or use `assertAnyType` instead.\n * @param value\n */\nexport const checkType = <T>(value: T): T => value;\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { EventEmitter } from 'node:events';\n\n/**\n * Listens for global errors.\n */\nexport class ErrorHandler extends EventEmitter {\n _listener: any;\n\n constructor() {\n super();\n\n this._listener = (event: any) => {\n const cause = event.error || event.reason || event;\n const message = cause.stack || cause.message || cause.toString();\n this.emit('error', message);\n\n // Default logging.\n // code event.preventDefault();\n };\n\n // https://developer.mozilla.org/en-US/docs/Web/API/Window/error_event\n window.addEventListener('error', this._listener);\n\n // https://developer.mozilla.org/en-US/docs/Web/API/Window/unhandledrejection_event\n window.addEventListener('unhandledrejection', this._listener);\n }\n\n reset() {\n window.removeEventListener('error', this._listener);\n window.removeEventListener('unhandledrejection', this._listener);\n }\n}\n", "//\n// Copyright 2021 DXOS.org\n//\n\nexport type ErrorHandlerCallback = (error: Error) => void;\n\n/**\n * Represents a stream of errors that entities can expose.\n */\nexport class ErrorStream {\n private _handler: ErrorHandlerCallback | undefined;\n\n private _unhandledErrors = 0;\n\n assertNoUnhandledErrors() {\n if (this._unhandledErrors > 0) {\n throw new Error(\n `Assertion failed: expected no unhandled errors to be thrown, but ${this._unhandledErrors} were thrown.`,\n );\n }\n }\n\n raise(error: Error) {\n if (this._handler) {\n this._handler(error);\n } else {\n this._unhandledError(error);\n }\n }\n\n handle(handler: ErrorHandlerCallback) {\n this._handler = handler;\n }\n\n pipeTo(receiver: ErrorStream) {\n this.handle((error) => receiver.raise(error));\n }\n\n private _unhandledError(error: Error) {\n this._unhandledErrors++;\n\n setTimeout(() => {\n throw error;\n });\n }\n}\n", "//\n// Copyright 2021 DXOS.org\n//\n\n/**\n * Should be used in expressions where values are cheked not to be null or undefined.\n *\n * Example:\n *\n * ```\n * const value: string | undefined;\n *\n * callMethod(value ?? failUndefined());\n * ```\n */\n// TODO(burdon): Rename failIfUndefined().\nexport const failUndefined = () => {\n throw new Error('Required value was null or undefined.');\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { inspect } from 'node:util';\n\n/**\n * Utility to automatically log debug info.\n *\n * ```\n * // Called via `console.log`.\n * [inspect.custom] () {\n * return inspectObject(this);\n * }\n *\n * // Called via `JSON.stringify`.\n * toJSON () {\n * return { ... };\n * }\n * ```\n */\nexport const inspectObject = (obj: any) => {\n const name = Object.getPrototypeOf(obj).constructor.name;\n return obj.toJSON ? `${name}(${inspect(obj.toJSON())})` : String(obj);\n};\n", "//\n// Copyright 2021 DXOS.org\n//\n\nexport function logMethod(\n target: any,\n propertyName: string,\n descriptor: TypedPropertyDescriptor<(...args: any) => any>,\n) {\n const method = descriptor.value!;\n descriptor.value = function (this: any, ...args: any) {\n console.log(`Called ${target.constructor.name}.${propertyName} ${args}`);\n try {\n const result = method.apply(this, args);\n if (typeof result.catch === 'function') {\n result.catch((err: any) => {\n console.log(`Rejected ${target.constructor.name}.${propertyName}`, err);\n });\n }\n return result;\n } catch (err: any) {\n console.log(`Thrown ${target.constructor.name}.${propertyName}`, err);\n throw err;\n }\n };\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * Immediatelly throws an error passed as an argument.\n *\n * Usefull for throwing errors from inside expressions.\n * For example:\n * ```\n * const item = model.getById(someId) ?? raise(new Error('Not found'));\n * ```\n * @param error\n */\nexport const raise = (error: Error): never => {\n throw error;\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nexport enum SnoopLevel {\n DEFAULT = 0,\n VERBOSE = 1,\n BOLD = 2,\n}\n\n/**\n * Utils for debug logging of functions.\n */\n// TODO(burdon): Integrate with log/spyglass.\nexport class Snoop {\n static stackFunction(err: Error) {\n const stack = err.stack!.split('\\n');\n const match = stack[2].match(/.+\\((.+)\\).*/);\n if (match) {\n const [file, line] = match[1].split(':');\n return `[${file.substring(file.lastIndexOf('/') + 1)}:${line}]`;\n }\n }\n\n constructor(private readonly _context?: string) {}\n\n get verbose() {\n return SnoopLevel.VERBOSE;\n }\n\n get bold() {\n return SnoopLevel.BOLD;\n }\n\n format(prefix: string, name: string, args: string, level: SnoopLevel) {\n const pre = prefix.repeat(level === SnoopLevel.BOLD ? 8 : 2);\n const label = this._context ? `${this._context}.${name}` : name;\n const line = `${pre} ${label}${args}`;\n return level === SnoopLevel.BOLD ? [pre, line, pre].join('\\n') : line;\n }\n\n in(label: string, level: SnoopLevel, ...args: any[]) {\n return this.format('<', label, level === SnoopLevel.DEFAULT ? '' : `(${String(...args)})`, level);\n }\n\n out(label: string, level: SnoopLevel, result: any) {\n return this.format('>', label, level === SnoopLevel.DEFAULT ? '' : ` = ${String(result)}`, level);\n }\n\n sync(f: any, label?: string, level: SnoopLevel = SnoopLevel.VERBOSE) {\n label = label ?? Snoop.stackFunction(new Error());\n return (...args: any[]) => {\n console.log(this.in(label ?? '', level, ...args));\n const r = f(...args);\n console.log(this.out(label ?? '', level, r));\n return r;\n };\n }\n\n async(f: any, label?: string, level: SnoopLevel = SnoopLevel.VERBOSE) {\n label = label ?? Snoop.stackFunction(new Error());\n return async (...args: any[]) => {\n console.log(this.in(label ?? '', level, ...args));\n const r = await f(...args);\n console.log(this.out(label ?? '', level, r));\n return r;\n };\n }\n}\n\nexport const snoop = new Snoop();\n", "//\n// Copyright 2021 DXOS.org\n//\n\n/**\n * Will capture the stack trace at the point where the class is created.\n * Stack traces are formatted lazily only when `getStack` is called.\n * Formatting is significantly more expensive than capture so only call getStack when you need them.\n */\nexport class StackTrace {\n private _stack: Error;\n\n constructor() {\n this._stack = new Error();\n }\n\n /**\n * Get stack formatted as string.\n * @param skipFrames Number of frames to skip. By default, the first frame would be the invocation of the StackTrace constructor.\n * @returns\n */\n getStack(skipFrames = 0) {\n const stack = this._stack.stack!.split('\\n');\n return stack.slice(skipFrames + 2).join('\\n');\n }\n\n getStackArray(skipFrames = 0) {\n const stack = this._stack.stack!.split('\\n');\n return stack.slice(skipFrames + 2);\n }\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\nexport const truncate = (str = '', length = 8, pad: boolean | string = false) => {\n if (str.length >= length - 1) {\n return str.substring(0, length - 1) + '…';\n } else {\n return pad ? str.padEnd(length, typeof pad === 'boolean' ? ' ' : pad[0]) : str;\n }\n};\n\nexport const truncateKey = (key: any, length = 8) => {\n const str = String(key);\n if (str.length <= length) {\n return str;\n }\n\n return str.slice(0, length);\n\n // return start\n // ? `${str.slice(0, length)}...`\n // : `${str.substring(0, length / 2)}...${str.substring(str.length - length / 2)}`;\n};\n", "//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * Wrapper for async tests.\n * @param {Function} test - Async test\n * @param errType\n * @return {Promise<void>}\n *\n * @deprecated Use vitests `expect(() => ...).toThrowError();` instead.\n */\nexport const expectToThrow = async (test: () => void, errType = Error) => {\n let thrown;\n try {\n await test();\n } catch (err) {\n thrown = err;\n }\n\n if (thrown === undefined || !(thrown instanceof errType)) {\n throw new Error(`Expected function to throw instance of ${errType.prototype.name}`);\n }\n};\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { StackTrace } from './stack-trace';\n\n/**\n * Prints a warning to console if the action takes longer then specified timeout. No errors are thrown.\n *\n * @param timeout Timeout in milliseconds after which warning is printed.\n * @param context Context description that would be included in the printed message.\n * @param body Action which is timed.\n */\nexport const warnAfterTimeout = async <T>(timeout: number, context: string, body: () => Promise<T>): Promise<T> => {\n const stack = new StackTrace();\n const timeoutId = setTimeout(() => {\n console.warn(\n `Action \\`${context}\\` is taking more then ${timeout.toLocaleString()}ms to complete. This might be a bug.\\n${stack.getStack()}`,\n );\n }, timeout);\n try {\n return await body();\n } finally {\n clearTimeout(timeoutId);\n }\n};\n\n/**\n * A decorator that prints a warning to console if method execution time exceeds specified timeout.\n *\n * ```typescript\n * class Foo {\n * @timed(5_000)\n * async doStuff() {\n * // long task\n * }\n * }\n * ```\n *\n * This is useful for debugging code that might deadlock.\n *\n * @param timeout Timeout in milliseconds after which the warning is printed.\n */\nexport function timed(timeout: number) {\n return (target: any, propertyName: string, descriptor: TypedPropertyDescriptor<(...args: any) => any>) => {\n const method = descriptor.value!;\n descriptor.value = function (this: any, ...args: any) {\n return warnAfterTimeout(timeout, `${target.constructor.name}.${propertyName}`, () => method.apply(this, args));\n };\n };\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\n/**\n * Throws an error. Can be used in an expression instead of a value\n */\nexport const todo = (message?: string): never => {\n throw new Error(message ?? 'Not implemented.');\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\n/**\n * Lets types provide custom formatters for the Chrome Devtools.\n *\n * https://www.mattzeunert.com/2016/02/19/custom-chrome-devtools-object-formatters.html\n * NOTE: Must be enabled in chrome devtools preferences.\n *\n * @example\n * ```typescript\n * class MyType {\n * get [devtoolsFormatter] (): DevtoolsFormatter {\n * ...\n * }\n * ```\n */\n\nexport const devtoolsFormatter = Symbol.for('devtoolsFormatter');\n\nexport type JsonML = [string, Record<string, any>?, ...(JsonML | string)[]];\n\nexport interface DevtoolsFormatter {\n /**\n * NOTE: Make sure to do an instance check and return null if the object is not of the correct type.\n */\n header: (config?: any) => JsonML | null;\n hasBody?: (config?: any) => boolean;\n body?: (config?: any) => JsonML | null;\n}\n\n/**\n * Types that implement this interface can provide custom formatters for the Chrome Devtools.\n *\n * https://firefox-source-docs.mozilla.org/devtools-user/custom_formatters/index.html\n */\nexport interface CustomDevtoolsFormattable {\n get [devtoolsFormatter](): DevtoolsFormatter;\n}\n\nconst register = () => {\n if (typeof window !== 'undefined') {\n ((window as any).devtoolsFormatters ??= []).push({\n header: (value: any, config: any) => {\n const formatter = value[devtoolsFormatter];\n if (formatter === undefined) {\n return null;\n }\n if (typeof formatter !== 'object' || formatter === null || typeof formatter.header !== 'function') {\n throw new Error(`Invalid devtools formatter for ${value.constructor.name}`);\n }\n\n return formatter.header(config);\n },\n hasBody: (value: any, config: any) => {\n const formatter = value[devtoolsFormatter];\n if (!formatter || !formatter.hasBody) {\n return false;\n }\n\n return formatter.hasBody(config);\n },\n body: (value: any, config: any) => {\n const formatter = value[devtoolsFormatter];\n if (!formatter || !formatter.body) {\n return null;\n }\n\n return formatter.body(config);\n },\n });\n }\n};\n\nregister();\n", "//\n// Copyright 2023 DXOS.org\n//\n\nexport const equalsSymbol = Symbol.for('dxos.common.equals');\n\nexport interface Equatable {\n [equalsSymbol]: (other: any) => boolean;\n}\n\n// TODO(dmaretskyi): export to @dxos/traits.\n// TODO(dmaretskyi): Hash trait for maps?\n\nexport const isEquatable = (value: any): value is Equatable => {\n return typeof value === 'object' && value !== null && typeof value[equalsSymbol] === 'function';\n};\n\nexport const isEqual = (value: Equatable, other: any) => {\n return value[equalsSymbol](other);\n};\n\n/**\n * Feed this as a third argument to `_.isEqualWith` to compare objects with `Equatable` interface.\n */\nexport const loadashEqualityFn = (value: any, other: any): boolean | undefined => {\n if (!isEquatable(value)) {\n return undefined;\n }\n return isEqual(value, other);\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\n/**\n * Allows to register a module to be used later during debugging.\n *\n * ```ts\n * import * as keys from '@dxos/keys';\n * exposeModule('@dxos/keys', keys);\n *\n * ...\n *\n * const { PublicKey } = importModule('@dxos/keys');\n * ```\n *\n * Overwrites the module if it already exists.\n */\nexport const exposeModule = (name: string, module: any) => {\n EXPOSED_MODULES[name] = module;\n};\n\n/**\n * Imports a previously exposed module by its name.\n * Throws an error if the module is not found.\n *\n * @param {string} name - The name of the module to import.\n * @returns {any} The imported module.\n * @throws {Error} If the module is not exposed.\n */\nexport const importModule = (name: string) => {\n if (EXPOSED_MODULES[name]) {\n return EXPOSED_MODULES[name];\n } else {\n throw new Error(`Module ${name} is not exposed.`);\n }\n};\n\nconst EXPOSED_MODULES: Record<string, any> = {};\n", "//\n// Copyright 2024 DXOS.org\n//\n\n/**\n * Using this allows code to be written in a portable fashion, so that the custom inspect function is used in an Node.js environment and ignored in the browser.\n */\nexport const inspectCustom = Symbol.for('nodejs.util.inspect.custom');\n"],
5
+ "mappings": "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",
6
+ "names": ["checkType", "value", "EventEmitter", "ErrorHandler", "EventEmitter", "constructor", "_listener", "event", "cause", "error", "reason", "message", "stack", "toString", "emit", "window", "addEventListener", "reset", "removeEventListener", "ErrorStream", "_unhandledErrors", "assertNoUnhandledErrors", "Error", "raise", "error", "_handler", "_unhandledError", "handle", "handler", "pipeTo", "receiver", "setTimeout", "failUndefined", "Error", "inspect", "inspectObject", "obj", "name", "Object", "getPrototypeOf", "constructor", "toJSON", "inspect", "String", "logMethod", "target", "propertyName", "descriptor", "method", "value", "args", "console", "log", "constructor", "name", "result", "apply", "catch", "err", "raise", "error", "SnoopLevel", "Snoop", "stackFunction", "err", "stack", "split", "match", "file", "line", "substring", "lastIndexOf", "constructor", "_context", "verbose", "bold", "format", "prefix", "name", "args", "level", "pre", "repeat", "label", "join", "in", "String", "out", "result", "sync", "f", "Error", "console", "log", "r", "async", "snoop", "StackTrace", "constructor", "_stack", "Error", "getStack", "skipFrames", "stack", "split", "slice", "join", "getStackArray", "truncate", "str", "length", "pad", "substring", "padEnd", "truncateKey", "key", "String", "slice", "expectToThrow", "test", "errType", "Error", "thrown", "err", "undefined", "prototype", "name", "warnAfterTimeout", "timeout", "context", "body", "stack", "StackTrace", "timeoutId", "setTimeout", "console", "warn", "toLocaleString", "getStack", "clearTimeout", "timed", "target", "propertyName", "descriptor", "method", "value", "args", "constructor", "name", "apply", "todo", "message", "Error", "devtoolsFormatter", "Symbol", "for", "register", "window", "devtoolsFormatters", "push", "header", "value", "config", "formatter", "undefined", "Error", "constructor", "name", "hasBody", "body", "equalsSymbol", "Symbol", "for", "isEquatable", "value", "isEqual", "other", "loadashEqualityFn", "undefined", "exposeModule", "name", "module", "EXPOSED_MODULES", "importModule", "Error", "inspectCustom", "Symbol", "for"]
7
+ }
@@ -0,0 +1 @@
1
+ {"inputs":{"packages/common/debug/src/assert.ts":{"bytes":1334,"imports":[],"format":"esm"},"packages/common/debug/src/error-handler.ts":{"bytes":3608,"imports":[{"path":"node:events","kind":"import-statement","external":true}],"format":"esm"},"packages/common/debug/src/error-stream.ts":{"bytes":3457,"imports":[],"format":"esm"},"packages/common/debug/src/fail.ts":{"bytes":1405,"imports":[],"format":"esm"},"packages/common/debug/src/inspect.ts":{"bytes":2029,"imports":[{"path":"node:util","kind":"import-statement","external":true}],"format":"esm"},"packages/common/debug/src/log-method.ts":{"bytes":3084,"imports":[],"format":"esm"},"packages/common/debug/src/raise.ts":{"bytes":1245,"imports":[],"format":"esm"},"packages/common/debug/src/snoop.ts":{"bytes":7985,"imports":[],"format":"esm"},"packages/common/debug/src/stack-trace.ts":{"bytes":3058,"imports":[],"format":"esm"},"packages/common/debug/src/strings.ts":{"bytes":2538,"imports":[],"format":"esm"},"packages/common/debug/src/throw.ts":{"bytes":2132,"imports":[],"format":"esm"},"packages/common/debug/src/timeout-warning.ts":{"bytes":5199,"imports":[{"path":"packages/common/debug/src/stack-trace.ts","kind":"import-statement","original":"./stack-trace"}],"format":"esm"},"packages/common/debug/src/todo.ts":{"bytes":956,"imports":[],"format":"esm"},"packages/common/debug/src/devtools-formatter.ts":{"bytes":6253,"imports":[],"format":"esm"},"packages/common/debug/src/equality.ts":{"bytes":2776,"imports":[],"format":"esm"},"packages/common/debug/src/exposed-modules.ts":{"bytes":3029,"imports":[],"format":"esm"},"packages/common/debug/src/inspect-custom.ts":{"bytes":1110,"imports":[],"format":"esm"},"packages/common/debug/src/index.ts":{"bytes":1996,"imports":[{"path":"packages/common/debug/src/assert.ts","kind":"import-statement","original":"./assert"},{"path":"packages/common/debug/src/error-handler.ts","kind":"import-statement","original":"./error-handler"},{"path":"packages/common/debug/src/error-stream.ts","kind":"import-statement","original":"./error-stream"},{"path":"packages/common/debug/src/fail.ts","kind":"import-statement","original":"./fail"},{"path":"packages/common/debug/src/inspect.ts","kind":"import-statement","original":"./inspect"},{"path":"packages/common/debug/src/log-method.ts","kind":"import-statement","original":"./log-method"},{"path":"packages/common/debug/src/raise.ts","kind":"import-statement","original":"./raise"},{"path":"packages/common/debug/src/snoop.ts","kind":"import-statement","original":"./snoop"},{"path":"packages/common/debug/src/stack-trace.ts","kind":"import-statement","original":"./stack-trace"},{"path":"packages/common/debug/src/strings.ts","kind":"import-statement","original":"./strings"},{"path":"packages/common/debug/src/throw.ts","kind":"import-statement","original":"./throw"},{"path":"packages/common/debug/src/timeout-warning.ts","kind":"import-statement","original":"./timeout-warning"},{"path":"packages/common/debug/src/todo.ts","kind":"import-statement","original":"./todo"},{"path":"packages/common/debug/src/devtools-formatter.ts","kind":"import-statement","original":"./devtools-formatter"},{"path":"packages/common/debug/src/equality.ts","kind":"import-statement","original":"./equality"},{"path":"packages/common/debug/src/exposed-modules.ts","kind":"import-statement","original":"./exposed-modules"},{"path":"packages/common/debug/src/inspect-custom.ts","kind":"import-statement","original":"./inspect-custom"}],"format":"esm"}},"outputs":{"packages/common/debug/dist/lib/node-esm/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":23555},"packages/common/debug/dist/lib/node-esm/index.mjs":{"imports":[{"path":"node:events","kind":"import-statement","external":true},{"path":"node:util","kind":"import-statement","external":true}],"exports":["ErrorHandler","ErrorStream","Snoop","SnoopLevel","StackTrace","checkType","devtoolsFormatter","equalsSymbol","expectToThrow","exposeModule","failUndefined","importModule","inspectCustom","inspectObject","isEqual","isEquatable","loadashEqualityFn","logMethod","raise","snoop","timed","todo","truncate","truncateKey","warnAfterTimeout"],"entryPoint":"packages/common/debug/src/index.ts","inputs":{"packages/common/debug/src/assert.ts":{"bytesInOutput":34},"packages/common/debug/src/index.ts":{"bytesInOutput":0},"packages/common/debug/src/error-handler.ts":{"bytesInOutput":600},"packages/common/debug/src/error-stream.ts":{"bytesInOutput":655},"packages/common/debug/src/fail.ts":{"bytesInOutput":91},"packages/common/debug/src/inspect.ts":{"bytesInOutput":204},"packages/common/debug/src/log-method.ts":{"bytesInOutput":597},"packages/common/debug/src/raise.ts":{"bytesInOutput":43},"packages/common/debug/src/snoop.ts":{"bytesInOutput":1784},"packages/common/debug/src/stack-trace.ts":{"bytesInOutput":531},"packages/common/debug/src/strings.ts":{"bytesInOutput":396},"packages/common/debug/src/throw.ts":{"bytesInOutput":290},"packages/common/debug/src/timeout-warning.ts":{"bytesInOutput":664},"packages/common/debug/src/todo.ts":{"bytesInOutput":79},"packages/common/debug/src/devtools-formatter.ts":{"bytesInOutput":1035},"packages/common/debug/src/equality.ts":{"bytesInOutput":391},"packages/common/debug/src/exposed-modules.ts":{"bytesInOutput":271},"packages/common/debug/src/inspect-custom.ts":{"bytesInOutput":62}},"bytes":8962}}}
@@ -14,4 +14,5 @@ export * from './todo';
14
14
  export * from './devtools-formatter';
15
15
  export * from './equality';
16
16
  export * from './exposed-modules';
17
+ export * from './inspect-custom';
17
18
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/index.ts"],"names":[],"mappings":"AAIA,cAAc,UAAU,CAAC;AACzB,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC;AAC1B,cAAc,cAAc,CAAC;AAC7B,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC;AACxB,cAAc,eAAe,CAAC;AAC9B,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC;AACxB,cAAc,mBAAmB,CAAC;AAClC,cAAc,QAAQ,CAAC;AACvB,cAAc,sBAAsB,CAAC;AACrC,cAAc,YAAY,CAAC;AAC3B,cAAc,mBAAmB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/index.ts"],"names":[],"mappings":"AAIA,cAAc,UAAU,CAAC;AACzB,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC;AAC1B,cAAc,cAAc,CAAC;AAC7B,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC;AACxB,cAAc,eAAe,CAAC;AAC9B,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC;AACxB,cAAc,mBAAmB,CAAC;AAClC,cAAc,QAAQ,CAAC;AACvB,cAAc,sBAAsB,CAAC;AACrC,cAAc,YAAY,CAAC;AAC3B,cAAc,mBAAmB,CAAC;AAClC,cAAc,kBAAkB,CAAC"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Using this allows code to be written in a portable fashion, so that the custom inspect function is used in an Node.js environment and ignored in the browser.
3
+ */
4
+ export declare const inspectCustom: unique symbol;
5
+ //# sourceMappingURL=inspect-custom.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"inspect-custom.d.ts","sourceRoot":"","sources":["../../../src/inspect-custom.ts"],"names":[],"mappings":"AAIA;;GAEG;AACH,eAAO,MAAM,aAAa,eAA2C,CAAC"}
@@ -1,19 +1,14 @@
1
1
  /**
2
- * Allows to capture stack-traces.
3
- *
4
2
  * Will capture the stack trace at the point where the class is created.
5
3
  * Stack traces are formatted lazily only when `getStack` is called.
6
- *
7
- * Formatting is significantly more expensive than capture so only call
8
- * getStack when you need them.
4
+ * Formatting is significantly more expensive than capture so only call getStack when you need them.
9
5
  */
10
6
  export declare class StackTrace {
11
7
  private _stack;
12
8
  constructor();
13
9
  /**
14
10
  * Get stack formatted as string.
15
- *
16
- * @param skipFrames Number of frames to skip. By default the first frame would be the invocation of the StackTrace constructor.
11
+ * @param skipFrames Number of frames to skip. By default, the first frame would be the invocation of the StackTrace constructor.
17
12
  * @returns
18
13
  */
19
14
  getStack(skipFrames?: number): string;
@@ -1 +1 @@
1
- {"version":3,"file":"stack-trace.d.ts","sourceRoot":"","sources":["../../../src/stack-trace.ts"],"names":[],"mappings":"AAIA;;;;;;;;GAQG;AACH,qBAAa,UAAU;IACrB,OAAO,CAAC,MAAM,CAAQ;;IAMtB;;;;;OAKG;IACH,QAAQ,CAAC,UAAU,SAAI;IAKvB,aAAa,CAAC,UAAU,SAAI;CAI7B"}
1
+ {"version":3,"file":"stack-trace.d.ts","sourceRoot":"","sources":["../../../src/stack-trace.ts"],"names":[],"mappings":"AAIA;;;;GAIG;AACH,qBAAa,UAAU;IACrB,OAAO,CAAC,MAAM,CAAQ;;IAMtB;;;;OAIG;IACH,QAAQ,CAAC,UAAU,SAAI;IAKvB,aAAa,CAAC,UAAU,SAAI;CAI7B"}
@@ -3,6 +3,8 @@
3
3
  * @param {Function} test - Async test
4
4
  * @param errType
5
5
  * @return {Promise<void>}
6
+ *
7
+ * @deprecated Use vitests `expect(() => ...).toThrowError();` instead.
6
8
  */
7
9
  export declare const expectToThrow: (test: () => void, errType?: ErrorConstructor) => Promise<void>;
8
10
  //# sourceMappingURL=throw.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"throw.d.ts","sourceRoot":"","sources":["../../../src/throw.ts"],"names":[],"mappings":"AAIA;;;;;GAKG;AACH,eAAO,MAAM,aAAa,SAAgB,MAAM,IAAI,8CAWnD,CAAC"}
1
+ {"version":3,"file":"throw.d.ts","sourceRoot":"","sources":["../../../src/throw.ts"],"names":[],"mappings":"AAIA;;;;;;;GAOG;AACH,eAAO,MAAM,aAAa,SAAgB,MAAM,IAAI,8CAWnD,CAAC"}
package/package.json CHANGED
@@ -1,16 +1,18 @@
1
1
  {
2
2
  "name": "@dxos/debug",
3
- "version": "0.6.13",
3
+ "version": "0.6.14-main.2b6a0f3",
4
4
  "description": "Debug utilities",
5
5
  "homepage": "https://dxos.org",
6
6
  "bugs": "https://github.com/dxos/dxos/issues",
7
7
  "license": "MIT",
8
8
  "author": "DXOS.org",
9
+ "sideEffects": false,
9
10
  "exports": {
10
11
  ".": {
11
12
  "browser": "./dist/lib/browser/index.mjs",
12
13
  "node": {
13
- "default": "./dist/lib/node/index.cjs"
14
+ "require": "./dist/lib/node/index.cjs",
15
+ "default": "./dist/lib/node-esm/index.mjs"
14
16
  },
15
17
  "types": "./dist/types/src/index.d.ts"
16
18
  }
@@ -24,8 +26,9 @@
24
26
  "src"
25
27
  ],
26
28
  "dependencies": {
27
- "@dxos/node-std": "0.6.13"
29
+ "@dxos/node-std": "0.6.14-main.2b6a0f3"
28
30
  },
31
+ "devDependencies": {},
29
32
  "publishConfig": {
30
33
  "access": "public"
31
34
  }
package/src/index.ts CHANGED
@@ -18,3 +18,4 @@ export * from './todo';
18
18
  export * from './devtools-formatter';
19
19
  export * from './equality';
20
20
  export * from './exposed-modules';
21
+ export * from './inspect-custom';
@@ -0,0 +1,8 @@
1
+ //
2
+ // Copyright 2024 DXOS.org
3
+ //
4
+
5
+ /**
6
+ * Using this allows code to be written in a portable fashion, so that the custom inspect function is used in an Node.js environment and ignored in the browser.
7
+ */
8
+ export const inspectCustom = Symbol.for('nodejs.util.inspect.custom');
@@ -3,13 +3,9 @@
3
3
  //
4
4
 
5
5
  /**
6
- * Allows to capture stack-traces.
7
- *
8
6
  * Will capture the stack trace at the point where the class is created.
9
7
  * Stack traces are formatted lazily only when `getStack` is called.
10
- *
11
- * Formatting is significantly more expensive than capture so only call
12
- * getStack when you need them.
8
+ * Formatting is significantly more expensive than capture so only call getStack when you need them.
13
9
  */
14
10
  export class StackTrace {
15
11
  private _stack: Error;
@@ -20,8 +16,7 @@ export class StackTrace {
20
16
 
21
17
  /**
22
18
  * Get stack formatted as string.
23
- *
24
- * @param skipFrames Number of frames to skip. By default the first frame would be the invocation of the StackTrace constructor.
19
+ * @param skipFrames Number of frames to skip. By default, the first frame would be the invocation of the StackTrace constructor.
25
20
  * @returns
26
21
  */
27
22
  getStack(skipFrames = 0) {
package/src/throw.test.ts CHANGED
@@ -2,7 +2,7 @@
2
2
  // Copyright 2020 DXOS.org
3
3
  //
4
4
 
5
- import { test } from '@dxos/test';
5
+ import { test } from 'vitest';
6
6
 
7
7
  import { expectToThrow } from './throw';
8
8
 
package/src/throw.ts CHANGED
@@ -7,6 +7,8 @@
7
7
  * @param {Function} test - Async test
8
8
  * @param errType
9
9
  * @return {Promise<void>}
10
+ *
11
+ * @deprecated Use vitests `expect(() => ...).toThrowError();` instead.
10
12
  */
11
13
  export const expectToThrow = async (test: () => void, errType = Error) => {
12
14
  let thrown;