obsidian-dev-utils 13.9.0 → 13.10.1
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.
- package/CHANGELOG.md +9 -0
- package/README.md +24 -0
- package/dist/lib/Async.cjs +6 -5
- package/dist/lib/Debug.cjs +15 -7
- package/dist/lib/Debug.d.ts +12 -2
- package/dist/lib/DebugController.cjs +26 -0
- package/dist/lib/DebugController.d.ts +85 -0
- package/dist/lib/index.cjs +4 -1
- package/dist/lib/index.d.ts +1 -0
- package/dist/lib/obsidian/Logger.cjs +8 -8
- package/dist/lib/obsidian/Loop.cjs +2 -2
- package/dist/lib/obsidian/MetadataCache.cjs +7 -7
- package/dist/lib/obsidian/Plugin/PluginBase.cjs +20 -26
- package/dist/lib/obsidian/Plugin/PluginBase.d.ts +13 -11
- package/dist/lib/obsidian/RenameDeleteHandler.cjs +4 -4
- package/dist/lib/scripts/version.cjs +3 -3
- package/package.json +2 -2
package/CHANGELOG.md
CHANGED
package/README.md
CHANGED
@@ -151,6 +151,30 @@ import * as obsidianDevUtils from "obsidian-dev-utils";
|
|
151
151
|
await obsidianDevUtils.obsidian.Modal.Prompt.prompt({ app, title: 'Enter your name' });
|
152
152
|
```
|
153
153
|
|
154
|
+
## Debugging
|
155
|
+
|
156
|
+
By default, console debug messages are not shown. To enable them you have to enable `Verbose` mode in the console settings.
|
157
|
+
|
158
|
+

|
159
|
+
|
160
|
+
When you enable `Verbose` mode, you will see debug messages in the console sent via `console.debug()` calls.
|
161
|
+
|
162
|
+
`obsidian-dev-utils` library uses [debug](https://github.com/debug-js/debug) library to enable conditional logging.
|
163
|
+
|
164
|
+
By default, none of the debug messages are shown. You have to enable the debug namespace explicitly.
|
165
|
+
|
166
|
+
To see debug messages for your plugin `foo`, you have to enable them:
|
167
|
+
|
168
|
+
```javascript
|
169
|
+
window.DEBUG.enable('foo'); // show all debug messages from the `foo` plugin
|
170
|
+
window.DEBUG.enable('foo:obsidian-dev-utils:*'); // show all debug messages from the `obsidian-dev-utils` library within the `foo` plugin
|
171
|
+
window.DEBUG.enable('foo:*'); // show all debug messages from the `foo` plugin and its submodules
|
172
|
+
window.DEBUG.enable('*:obsidian-dev-utils:*'); // show all debug messages for the `obsidian-dev-utils` library within any plugin
|
173
|
+
window.DEBUG.enable('*'); // show all debug messages
|
174
|
+
```
|
175
|
+
|
176
|
+
See full documentation of [`window.DEBUG`](https://github.com/mnaoumov/obsidian-dev-utils/blob/main/src/DebugController.ts).
|
177
|
+
|
154
178
|
## Support
|
155
179
|
|
156
180
|
<a href="https://www.buymeacoffee.com/mnaoumov" target="_blank"><img src="https://cdn.buymeacoffee.com/buttons/v2/default-yellow.png" alt="Buy Me A Coffee" style="height: 60px !important;width: 217px !important;"></a>
|
package/dist/lib/Async.cjs
CHANGED
@@ -44,7 +44,6 @@ __export(Async_exports, {
|
|
44
44
|
module.exports = __toCommonJS(Async_exports);
|
45
45
|
var import_Debug = require('./Debug.cjs');
|
46
46
|
var import_Error = require('./Error.cjs');
|
47
|
-
const retryWithTimeoutDebugger = (0, import_Debug.getDebugger)("obsidian-dev-utils:Async:retryWithTimeout");
|
48
47
|
async function addErrorHandler(asyncFn) {
|
49
48
|
try {
|
50
49
|
await asyncFn();
|
@@ -77,6 +76,7 @@ function marksAsTerminateRetry(error) {
|
|
77
76
|
return Object.assign(error, { __terminateRetry: true });
|
78
77
|
}
|
79
78
|
async function retryWithTimeout(fn, retryOptions = {}, stackTrace) {
|
79
|
+
const retryWithTimeoutDebugger = (0, import_Debug.getLibDebugger)("Async:retryWithTimeout");
|
80
80
|
stackTrace ??= (0, import_Error.getStackTrace)(1);
|
81
81
|
const DEFAULT_RETRY_OPTIONS = {
|
82
82
|
retryDelayInMilliseconds: 100,
|
@@ -127,7 +127,7 @@ async function runWithTimeout(timeoutInMilliseconds, fn) {
|
|
127
127
|
result = await fn();
|
128
128
|
isTimedOut = false;
|
129
129
|
const duration = performance.now() - startTime;
|
130
|
-
(0, import_Debug.
|
130
|
+
(0, import_Debug.getLibDebugger)("Async:runWithTimeout")(`Execution time: ${duration.toString()} milliseconds`, { fn });
|
131
131
|
}
|
132
132
|
async function timeout2() {
|
133
133
|
if (!isTimedOut) {
|
@@ -139,8 +139,9 @@ async function runWithTimeout(timeoutInMilliseconds, fn) {
|
|
139
139
|
}
|
140
140
|
const duration = performance.now() - startTime;
|
141
141
|
console.warn(`Timed out in ${duration.toString()} milliseconds`, { fn });
|
142
|
-
|
143
|
-
|
142
|
+
const _debugger = (0, import_Debug.getLibDebugger)("Async:runWithTimeout:timeout");
|
143
|
+
if (_debugger.enabled) {
|
144
|
+
_debugger.log(`The execution is not terminated because debugger ${_debugger.namespace} is enabled. See https://github.com/mnaoumov/obsidian-dev-utils/?tab=readme-ov-file#debugging for more information`);
|
144
145
|
await timeout2();
|
145
146
|
}
|
146
147
|
}
|
@@ -175,4 +176,4 @@ async function toArray(iter) {
|
|
175
176
|
timeout,
|
176
177
|
toArray
|
177
178
|
});
|
178
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/Async.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation Async\n * Contains utility functions for asynchronous operations.\n */\n\nimport { getDebugger } from './Debug.ts';\nimport {\n  emitAsyncErrorEvent,\n  getStackTrace,\n  printError\n} from './Error.ts';\n\n/**\n * A type representing a value that can either be a direct value or a Promise resolving to that value.\n * @typeParam T - The type of the value.\n */\nexport type MaybePromise<T> = Promise<T> | T;\n\n/**\n * Options for configuring the retry behavior.\n */\nexport interface RetryOptions {\n  /**\n   * The abort signal to cancel the retry operation.\n   */\n  abortSignal?: AbortSignal;\n\n  /**\n   * The delay in milliseconds between retry attempts.\n   */\n  retryDelayInMilliseconds?: number;\n\n  /**\n   * Whether to retry the function on error.\n   */\n  shouldRetryOnError?: boolean;\n\n  /**\n   * The maximum time in milliseconds to wait before giving up on retrying.\n   */\n  timeoutInMilliseconds?: number;\n}\n\n/**\n * A marker interface to indicate that an error should terminate retry logic.\n */\nexport interface TerminateRetry {\n  /**\n   * A marker property to indicate that an error should terminate retry logic.\n   */\n  __terminateRetry: true;\n}\n\nconst retryWithTimeoutDebugger = getDebugger('obsidian-dev-utils:Async:retryWithTimeout');\n\n/**\n * Adds an error handler to a Promise that catches any errors and emits an async error event.\n *\n * @param asyncFn - The asynchronous function to add an error handler to.\n * @returns A Promise that resolves when the asynchronous function completes or emits async error event.\n */\nexport async function addErrorHandler(asyncFn: () => Promise<unknown>): Promise<void> {\n  try {\n    await asyncFn();\n  } catch (asyncError) {\n    emitAsyncErrorEvent(asyncError);\n  }\n}\n\n/**\n * Filters an array asynchronously, keeping only the elements that satisfy the provided predicate function.\n *\n * @typeParam T - The type of elements in the input array.\n * @param arr - The array to filter.\n * @param predicate - The predicate function to test each element.\n * @returns A Promise that resolves with an array of elements that satisfy the predicate function.\n */\nexport async function asyncFilter<T>(arr: T[], predicate: (value: T, index: number, array: T[]) => MaybePromise<boolean>): Promise<T[]> {\n  const predicateResults = await asyncMap(arr, predicate);\n  return arr.filter((_, index) => predicateResults[index] ?? false);\n}\n\n/**\n * Maps over an array asynchronously, applying the provided callback function to each element, and then flattens the results into a single array.\n *\n * @typeParam T - The type of elements in the input array.\n * @typeParam U - The type of elements in the output array.\n * @param arr - The array to map over and flatten.\n * @param callback - The callback function to apply to each element.\n * @returns A Promise that resolves with a flattened array of the results of the callback function.\n */\nexport async function asyncFlatMap<T, U>(arr: T[], callback: (value: T, index: number, array: T[]) => MaybePromise<U[]>): Promise<U[]> {\n  return (await asyncMap(arr, callback)).flat();\n}\n\n/**\n * Maps over an array asynchronously, applying the provided callback function to each element.\n *\n * @typeParam T - The type of elements in the input array.\n * @typeParam U - The type of elements in the output array.\n * @param arr - The array to map over.\n * @param callback - The callback function to apply to each element.\n * @returns A Promise that resolves with an array of the results of the callback function.\n */\nexport async function asyncMap<T, U>(arr: T[], callback: (value: T, index: number, array: T[]) => MaybePromise<U>): Promise<U[]> {\n  return await Promise.all(arr.map(callback));\n}\n\n/**\n * Converts an asynchronous function to a synchronous one by automatically handling the Promise rejection.\n *\n * @typeParam Args - The types of the arguments the function accepts.\n * @param asyncFunc - The asynchronous function to convert.\n * @returns A function that wraps the asynchronous function in a synchronous interface.\n */\nexport function convertAsyncToSync<Args extends unknown[]>(asyncFunc: (...args: Args) => Promise<unknown>): (...args: Args) => void {\n  return (...args: Args): void => {\n    invokeAsyncSafely(() => asyncFunc(...args));\n  };\n}\n\n/**\n * Converts a synchronous function to an asynchronous one by wrapping it in a Promise.\n *\n * @typeParam Args - The types of the arguments the function accepts.\n * @typeParam Result - The type of the function's return value.\n * @param syncFn - The synchronous function to convert.\n * @returns A function that wraps the synchronous function in an asynchronous interface.\n */\nexport function convertSyncToAsync<Args extends unknown[], Result>(syncFn: (...args: Args) => Result): (...args: Args) => Promise<Result> {\n  return (...args: Args): Promise<Result> => Promise.resolve().then(() => syncFn(...args));\n}\n\n/**\n * Invokes a Promise and safely handles any errors by catching them and emitting an async error event.\n *\n * @param asyncFn - The asynchronous function to invoke safely.\n */\nexport function invokeAsyncSafely(asyncFn: () => Promise<unknown>): void {\n  void addErrorHandler(asyncFn);\n}\n\n/**\n * Marks an error to terminate retry logic.\n *\n * @param error - The error to mark to terminate retry logic.\n * @returns An error that should terminate retry logic.\n */\nexport function marksAsTerminateRetry<TError extends Error>(error: TError): TerminateRetry & TError {\n  return Object.assign(error, { __terminateRetry: true }) as TerminateRetry & TError;\n}\n\n/**\n * Retries the provided function until it returns true or the timeout is reached.\n *\n * @param fn - The function to retry.\n * @param retryOptions - Optional parameters to configure the retry behavior.\n * @param stackTrace - Optional stack trace.\n * @returns A Promise that resolves when the function returns true or rejects when the timeout is reached.\n */\nexport async function retryWithTimeout(fn: () => MaybePromise<boolean>, retryOptions: RetryOptions = {}, stackTrace?: string): Promise<void> {\n  stackTrace ??= getStackTrace(1);\n  const DEFAULT_RETRY_OPTIONS = {\n    retryDelayInMilliseconds: 100,\n    shouldRetryOnError: false,\n    timeoutInMilliseconds: 5000\n  };\n  const fullOptions = { ...DEFAULT_RETRY_OPTIONS, ...retryOptions };\n  await runWithTimeout(fullOptions.timeoutInMilliseconds, async () => {\n    let attempt = 0;\n    for (; ;) {\n      fullOptions.abortSignal?.throwIfAborted();\n      attempt++;\n      let isSuccess: boolean;\n      try {\n        isSuccess = await fn();\n      } catch (error) {\n        if (!fullOptions.shouldRetryOnError || (error as Partial<TerminateRetry>).__terminateRetry) {\n          throw error;\n        }\n        printError(error);\n        isSuccess = false;\n      }\n      if (isSuccess) {\n        if (attempt > 1) {\n          retryWithTimeoutDebugger(`Retry completed successfully after ${attempt.toString()} attempts`);\n          retryWithTimeoutDebugger.printStackTrace(stackTrace);\n        }\n        return;\n      }\n\n      retryWithTimeoutDebugger(`Retry attempt ${attempt.toString()} completed unsuccessfully. Trying again in ${fullOptions.retryDelayInMilliseconds.toString()} milliseconds`, {\n        fn\n      });\n      retryWithTimeoutDebugger.printStackTrace(stackTrace);\n      await sleep(fullOptions.retryDelayInMilliseconds);\n    }\n  });\n}\n\n/**\n * Executes a function with a timeout. If the function does not complete within the specified time, it is considered to have timed out.\n *\n * If `DEBUG=obsidian-dev-utils:Async:runWithTimeout` is set, the execution is not terminated after the timeout and the function is allowed to run indefinitely.\n *\n * @typeParam R - The type of the result from the asynchronous function.\n * @param timeoutInMilliseconds - The maximum time to wait in milliseconds.\n * @param fn - The function to execute.\n * @returns A Promise that resolves with the result of the asynchronous function or rejects if it times out.\n */\nexport async function runWithTimeout<R>(timeoutInMilliseconds: number, fn: () => MaybePromise<R>): Promise<R> {\n  let isTimedOut = true;\n  let result: R = null as R;\n  const startTime = performance.now();\n  await Promise.race([run(), timeout()]);\n  // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n  if (isTimedOut) {\n    throw new Error('Timed out');\n  }\n  return result;\n\n  async function run(): Promise<void> {\n    result = await fn();\n    isTimedOut = false;\n    const duration = performance.now() - startTime;\n    getDebugger('obsidian-dev-utils:Async:runWithTimeout')(`Execution time: ${duration.toString()} milliseconds`, { fn });\n  }\n\n  async function timeout(): Promise<void> {\n    if (!isTimedOut) {\n      return;\n    }\n    await sleep(timeoutInMilliseconds);\n    // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n    if (!isTimedOut) {\n      return;\n    }\n    const duration = performance.now() - startTime;\n    console.warn(`Timed out in ${duration.toString()} milliseconds`, { fn });\n    if (getDebugger('obsidian-dev-utils:Async:timeout').enabled) {\n      console.warn('The execution is not terminated because debugger obsidian-dev-utils:Async:timeout is enabled. See window.DEBUG.enable(\\'obsidian-dev-utils:Async:timeout\\') and https://github.com/debug-js/debug?tab=readme-ov-file for more information');\n      await timeout();\n    }\n  }\n}\n\n/**\n * Delays execution for a specified number of milliseconds.\n *\n * @param milliseconds - The time to wait in milliseconds.\n * @returns A Promise that resolves after the specified delay.\n */\nexport async function sleep(milliseconds: number): Promise<void> {\n  await new Promise((resolve) => setTimeout(resolve, milliseconds));\n}\n\n/**\n * Returns a Promise that rejects after the specified timeout period.\n *\n * @param timeoutInMilliseconds - The timeout period in milliseconds.\n * @returns A Promise that always rejects with a timeout error.\n */\nexport async function timeout(timeoutInMilliseconds: number): Promise<never> {\n  await sleep(timeoutInMilliseconds);\n  throw new Error(`Timed out in ${timeoutInMilliseconds.toString()} milliseconds`);\n}\n\n/**\n * Converts an AsyncIterableIterator to an array by consuming all its elements.\n *\n * @typeParam T - The type of elements produced by the AsyncIterableIterator.\n * @param iter - The AsyncIterableIterator to convert.\n * @returns A Promise that resolves with an array of all the elements in the AsyncIterableIterator.\n */\nexport async function toArray<T>(iter: AsyncIterableIterator<T>): Promise<T[]> {\n  const arr: T[] = [];\n  for await (const item of iter) {\n    arr.push(item);\n  }\n  return arr;\n}\n"],
  "mappings": "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",
  "names": ["timeout"]
}

|
179
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/Async.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation Async\n * Contains utility functions for asynchronous operations.\n */\n\nimport { getLibDebugger } from './Debug.ts';\nimport {\n  emitAsyncErrorEvent,\n  getStackTrace,\n  printError\n} from './Error.ts';\n\n/**\n * A type representing a value that can either be a direct value or a Promise resolving to that value.\n * @typeParam T - The type of the value.\n */\nexport type MaybePromise<T> = Promise<T> | T;\n\n/**\n * Options for configuring the retry behavior.\n */\nexport interface RetryOptions {\n  /**\n   * The abort signal to cancel the retry operation.\n   */\n  abortSignal?: AbortSignal;\n\n  /**\n   * The delay in milliseconds between retry attempts.\n   */\n  retryDelayInMilliseconds?: number;\n\n  /**\n   * Whether to retry the function on error.\n   */\n  shouldRetryOnError?: boolean;\n\n  /**\n   * The maximum time in milliseconds to wait before giving up on retrying.\n   */\n  timeoutInMilliseconds?: number;\n}\n\n/**\n * A marker interface to indicate that an error should terminate retry logic.\n */\nexport interface TerminateRetry {\n  /**\n   * A marker property to indicate that an error should terminate retry logic.\n   */\n  __terminateRetry: true;\n}\n\n/**\n * Adds an error handler to a Promise that catches any errors and emits an async error event.\n *\n * @param asyncFn - The asynchronous function to add an error handler to.\n * @returns A Promise that resolves when the asynchronous function completes or emits async error event.\n */\nexport async function addErrorHandler(asyncFn: () => Promise<unknown>): Promise<void> {\n  try {\n    await asyncFn();\n  } catch (asyncError) {\n    emitAsyncErrorEvent(asyncError);\n  }\n}\n\n/**\n * Filters an array asynchronously, keeping only the elements that satisfy the provided predicate function.\n *\n * @typeParam T - The type of elements in the input array.\n * @param arr - The array to filter.\n * @param predicate - The predicate function to test each element.\n * @returns A Promise that resolves with an array of elements that satisfy the predicate function.\n */\nexport async function asyncFilter<T>(arr: T[], predicate: (value: T, index: number, array: T[]) => MaybePromise<boolean>): Promise<T[]> {\n  const predicateResults = await asyncMap(arr, predicate);\n  return arr.filter((_, index) => predicateResults[index] ?? false);\n}\n\n/**\n * Maps over an array asynchronously, applying the provided callback function to each element, and then flattens the results into a single array.\n *\n * @typeParam T - The type of elements in the input array.\n * @typeParam U - The type of elements in the output array.\n * @param arr - The array to map over and flatten.\n * @param callback - The callback function to apply to each element.\n * @returns A Promise that resolves with a flattened array of the results of the callback function.\n */\nexport async function asyncFlatMap<T, U>(arr: T[], callback: (value: T, index: number, array: T[]) => MaybePromise<U[]>): Promise<U[]> {\n  return (await asyncMap(arr, callback)).flat();\n}\n\n/**\n * Maps over an array asynchronously, applying the provided callback function to each element.\n *\n * @typeParam T - The type of elements in the input array.\n * @typeParam U - The type of elements in the output array.\n * @param arr - The array to map over.\n * @param callback - The callback function to apply to each element.\n * @returns A Promise that resolves with an array of the results of the callback function.\n */\nexport async function asyncMap<T, U>(arr: T[], callback: (value: T, index: number, array: T[]) => MaybePromise<U>): Promise<U[]> {\n  return await Promise.all(arr.map(callback));\n}\n\n/**\n * Converts an asynchronous function to a synchronous one by automatically handling the Promise rejection.\n *\n * @typeParam Args - The types of the arguments the function accepts.\n * @param asyncFunc - The asynchronous function to convert.\n * @returns A function that wraps the asynchronous function in a synchronous interface.\n */\nexport function convertAsyncToSync<Args extends unknown[]>(asyncFunc: (...args: Args) => Promise<unknown>): (...args: Args) => void {\n  return (...args: Args): void => {\n    invokeAsyncSafely(() => asyncFunc(...args));\n  };\n}\n\n/**\n * Converts a synchronous function to an asynchronous one by wrapping it in a Promise.\n *\n * @typeParam Args - The types of the arguments the function accepts.\n * @typeParam Result - The type of the function's return value.\n * @param syncFn - The synchronous function to convert.\n * @returns A function that wraps the synchronous function in an asynchronous interface.\n */\nexport function convertSyncToAsync<Args extends unknown[], Result>(syncFn: (...args: Args) => Result): (...args: Args) => Promise<Result> {\n  return (...args: Args): Promise<Result> => Promise.resolve().then(() => syncFn(...args));\n}\n\n/**\n * Invokes a Promise and safely handles any errors by catching them and emitting an async error event.\n *\n * @param asyncFn - The asynchronous function to invoke safely.\n */\nexport function invokeAsyncSafely(asyncFn: () => Promise<unknown>): void {\n  void addErrorHandler(asyncFn);\n}\n\n/**\n * Marks an error to terminate retry logic.\n *\n * @param error - The error to mark to terminate retry logic.\n * @returns An error that should terminate retry logic.\n */\nexport function marksAsTerminateRetry<TError extends Error>(error: TError): TerminateRetry & TError {\n  return Object.assign(error, { __terminateRetry: true }) as TerminateRetry & TError;\n}\n\n/**\n * Retries the provided function until it returns true or the timeout is reached.\n *\n * @param fn - The function to retry.\n * @param retryOptions - Optional parameters to configure the retry behavior.\n * @param stackTrace - Optional stack trace.\n * @returns A Promise that resolves when the function returns true or rejects when the timeout is reached.\n */\nexport async function retryWithTimeout(fn: () => MaybePromise<boolean>, retryOptions: RetryOptions = {}, stackTrace?: string): Promise<void> {\n  const retryWithTimeoutDebugger = getLibDebugger('Async:retryWithTimeout');\n  stackTrace ??= getStackTrace(1);\n  const DEFAULT_RETRY_OPTIONS = {\n    retryDelayInMilliseconds: 100,\n    shouldRetryOnError: false,\n    timeoutInMilliseconds: 5000\n  };\n  const fullOptions = { ...DEFAULT_RETRY_OPTIONS, ...retryOptions };\n  await runWithTimeout(fullOptions.timeoutInMilliseconds, async () => {\n    let attempt = 0;\n    for (; ;) {\n      fullOptions.abortSignal?.throwIfAborted();\n      attempt++;\n      let isSuccess: boolean;\n      try {\n        isSuccess = await fn();\n      } catch (error) {\n        if (!fullOptions.shouldRetryOnError || (error as Partial<TerminateRetry>).__terminateRetry) {\n          throw error;\n        }\n        printError(error);\n        isSuccess = false;\n      }\n      if (isSuccess) {\n        if (attempt > 1) {\n          retryWithTimeoutDebugger(`Retry completed successfully after ${attempt.toString()} attempts`);\n          retryWithTimeoutDebugger.printStackTrace(stackTrace);\n        }\n        return;\n      }\n\n      retryWithTimeoutDebugger(`Retry attempt ${attempt.toString()} completed unsuccessfully. Trying again in ${fullOptions.retryDelayInMilliseconds.toString()} milliseconds`, {\n        fn\n      });\n      retryWithTimeoutDebugger.printStackTrace(stackTrace);\n      await sleep(fullOptions.retryDelayInMilliseconds);\n    }\n  });\n}\n\n/**\n * Executes a function with a timeout. If the function does not complete within the specified time, it is considered to have timed out.\n *\n * If `DEBUG=obsidian-dev-utils:Async:runWithTimeout` is set, the execution is not terminated after the timeout and the function is allowed to run indefinitely.\n *\n * @typeParam R - The type of the result from the asynchronous function.\n * @param timeoutInMilliseconds - The maximum time to wait in milliseconds.\n * @param fn - The function to execute.\n * @returns A Promise that resolves with the result of the asynchronous function or rejects if it times out.\n */\nexport async function runWithTimeout<R>(timeoutInMilliseconds: number, fn: () => MaybePromise<R>): Promise<R> {\n  let isTimedOut = true;\n  let result: R = null as R;\n  const startTime = performance.now();\n  await Promise.race([run(), timeout()]);\n  // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n  if (isTimedOut) {\n    throw new Error('Timed out');\n  }\n  return result;\n\n  async function run(): Promise<void> {\n    result = await fn();\n    isTimedOut = false;\n    const duration = performance.now() - startTime;\n    getLibDebugger('Async:runWithTimeout')(`Execution time: ${duration.toString()} milliseconds`, { fn });\n  }\n\n  async function timeout(): Promise<void> {\n    if (!isTimedOut) {\n      return;\n    }\n    await sleep(timeoutInMilliseconds);\n    // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n    if (!isTimedOut) {\n      return;\n    }\n    const duration = performance.now() - startTime;\n    console.warn(`Timed out in ${duration.toString()} milliseconds`, { fn });\n    const _debugger = getLibDebugger('Async:runWithTimeout:timeout');\n    if (_debugger.enabled) {\n      _debugger.log(`The execution is not terminated because debugger ${_debugger.namespace} is enabled. See https://github.com/mnaoumov/obsidian-dev-utils/?tab=readme-ov-file#debugging for more information`);\n      await timeout();\n    }\n  }\n}\n\n/**\n * Delays execution for a specified number of milliseconds.\n *\n * @param milliseconds - The time to wait in milliseconds.\n * @returns A Promise that resolves after the specified delay.\n */\nexport async function sleep(milliseconds: number): Promise<void> {\n  await new Promise((resolve) => setTimeout(resolve, milliseconds));\n}\n\n/**\n * Returns a Promise that rejects after the specified timeout period.\n *\n * @param timeoutInMilliseconds - The timeout period in milliseconds.\n * @returns A Promise that always rejects with a timeout error.\n */\nexport async function timeout(timeoutInMilliseconds: number): Promise<never> {\n  await sleep(timeoutInMilliseconds);\n  throw new Error(`Timed out in ${timeoutInMilliseconds.toString()} milliseconds`);\n}\n\n/**\n * Converts an AsyncIterableIterator to an array by consuming all its elements.\n *\n * @typeParam T - The type of elements produced by the AsyncIterableIterator.\n * @param iter - The AsyncIterableIterator to convert.\n * @returns A Promise that resolves with an array of all the elements in the AsyncIterableIterator.\n */\nexport async function toArray<T>(iter: AsyncIterableIterator<T>): Promise<T[]> {\n  const arr: T[] = [];\n  for await (const item of iter) {\n    arr.push(item);\n  }\n  return arr;\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAKA,mBAA+B;AAC/B,mBAIO;AAiDP,eAAsB,gBAAgB,SAAgD;AACpF,MAAI;AACF,UAAM,QAAQ;AAAA,EAChB,SAAS,YAAY;AACnB,0CAAoB,UAAU;AAAA,EAChC;AACF;AAUA,eAAsB,YAAe,KAAU,WAAyF;AACtI,QAAM,mBAAmB,MAAM,SAAS,KAAK,SAAS;AACtD,SAAO,IAAI,OAAO,CAAC,GAAG,UAAU,iBAAiB,KAAK,KAAK,KAAK;AAClE;AAWA,eAAsB,aAAmB,KAAU,UAAoF;AACrI,UAAQ,MAAM,SAAS,KAAK,QAAQ,GAAG,KAAK;AAC9C;AAWA,eAAsB,SAAe,KAAU,UAAkF;AAC/H,SAAO,MAAM,QAAQ,IAAI,IAAI,IAAI,QAAQ,CAAC;AAC5C;AASO,SAAS,mBAA2C,WAAyE;AAClI,SAAO,IAAI,SAAqB;AAC9B,sBAAkB,MAAM,UAAU,GAAG,IAAI,CAAC;AAAA,EAC5C;AACF;AAUO,SAAS,mBAAmD,QAAuE;AACxI,SAAO,IAAI,SAAgC,QAAQ,QAAQ,EAAE,KAAK,MAAM,OAAO,GAAG,IAAI,CAAC;AACzF;AAOO,SAAS,kBAAkB,SAAuC;AACvE,OAAK,gBAAgB,OAAO;AAC9B;AAQO,SAAS,sBAA4C,OAAwC;AAClG,SAAO,OAAO,OAAO,OAAO,EAAE,kBAAkB,KAAK,CAAC;AACxD;AAUA,eAAsB,iBAAiB,IAAiC,eAA6B,CAAC,GAAG,YAAoC;AAC3I,QAAM,+BAA2B,6BAAe,wBAAwB;AACxE,qBAAe,4BAAc,CAAC;AAC9B,QAAM,wBAAwB;AAAA,IAC5B,0BAA0B;AAAA,IAC1B,oBAAoB;AAAA,IACpB,uBAAuB;AAAA,EACzB;AACA,QAAM,cAAc,EAAE,GAAG,uBAAuB,GAAG,aAAa;AAChE,QAAM,eAAe,YAAY,uBAAuB,YAAY;AAClE,QAAI,UAAU;AACd,eAAU;AACR,kBAAY,aAAa,eAAe;AACxC;AACA,UAAI;AACJ,UAAI;AACF,oBAAY,MAAM,GAAG;AAAA,MACvB,SAAS,OAAO;AACd,YAAI,CAAC,YAAY,sBAAuB,MAAkC,kBAAkB;AAC1F,gBAAM;AAAA,QACR;AACA,qCAAW,KAAK;AAChB,oBAAY;AAAA,MACd;AACA,UAAI,WAAW;AACb,YAAI,UAAU,GAAG;AACf,mCAAyB,sCAAsC,QAAQ,SAAS,CAAC,WAAW;AAC5F,mCAAyB,gBAAgB,UAAU;AAAA,QACrD;AACA;AAAA,MACF;AAEA,+BAAyB,iBAAiB,QAAQ,SAAS,CAAC,8CAA8C,YAAY,yBAAyB,SAAS,CAAC,iBAAiB;AAAA,QACxK;AAAA,MACF,CAAC;AACD,+BAAyB,gBAAgB,UAAU;AACnD,YAAM,MAAM,YAAY,wBAAwB;AAAA,IAClD;AAAA,EACF,CAAC;AACH;AAYA,eAAsB,eAAkB,uBAA+B,IAAuC;AAC5G,MAAI,aAAa;AACjB,MAAI,SAAY;AAChB,QAAM,YAAY,YAAY,IAAI;AAClC,QAAM,QAAQ,KAAK,CAAC,IAAI,GAAGA,SAAQ,CAAC,CAAC;AAErC,MAAI,YAAY;AACd,UAAM,IAAI,MAAM,WAAW;AAAA,EAC7B;AACA,SAAO;AAEP,iBAAe,MAAqB;AAClC,aAAS,MAAM,GAAG;AAClB,iBAAa;AACb,UAAM,WAAW,YAAY,IAAI,IAAI;AACrC,qCAAe,sBAAsB,EAAE,mBAAmB,SAAS,SAAS,CAAC,iBAAiB,EAAE,GAAG,CAAC;AAAA,EACtG;AAEA,iBAAeA,WAAyB;AACtC,QAAI,CAAC,YAAY;AACf;AAAA,IACF;AACA,UAAM,MAAM,qBAAqB;AAEjC,QAAI,CAAC,YAAY;AACf;AAAA,IACF;AACA,UAAM,WAAW,YAAY,IAAI,IAAI;AACrC,YAAQ,KAAK,gBAAgB,SAAS,SAAS,CAAC,iBAAiB,EAAE,GAAG,CAAC;AACvE,UAAM,gBAAY,6BAAe,8BAA8B;AAC/D,QAAI,UAAU,SAAS;AACrB,gBAAU,IAAI,oDAAoD,UAAU,SAAS,oHAAoH;AACzM,YAAMA,SAAQ;AAAA,IAChB;AAAA,EACF;AACF;AAQA,eAAsB,MAAM,cAAqC;AAC/D,QAAM,IAAI,QAAQ,CAAC,YAAY,WAAW,SAAS,YAAY,CAAC;AAClE;AAQA,eAAsB,QAAQ,uBAA+C;AAC3E,QAAM,MAAM,qBAAqB;AACjC,QAAM,IAAI,MAAM,gBAAgB,sBAAsB,SAAS,CAAC,eAAe;AACjF;AASA,eAAsB,QAAW,MAA8C;AAC7E,QAAM,MAAW,CAAC;AAClB,mBAAiB,QAAQ,MAAM;AAC7B,QAAI,KAAK,IAAI;AAAA,EACf;AACA,SAAO;AACT;",
  "names": ["timeout"]
}

|
package/dist/lib/Debug.cjs
CHANGED
@@ -38,23 +38,30 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
|
|
38
38
|
var Debug_exports = {};
|
39
39
|
__export(Debug_exports, {
|
40
40
|
getDebugger: () => getDebugger,
|
41
|
+
getLibDebugger: () => getLibDebugger,
|
41
42
|
initDebugHelpers: () => initDebugHelpers
|
42
43
|
});
|
43
44
|
module.exports = __toCommonJS(Debug_exports);
|
44
45
|
var import_debug = __toESM(__extractDefault(require('debug')), 1);
|
46
|
+
let currentPluginId = "";
|
45
47
|
const NAMESPACE_SEPARATOR = ",";
|
46
48
|
const NEGATED_NAMESPACE_PREFIX = "-";
|
47
|
-
function getDebugger(namespace) {
|
48
|
-
const debugInstance = import_debug.default
|
49
|
+
function getDebugger(namespace, framesToSkip = 0) {
|
50
|
+
const debugInstance = (0, import_debug.default)(namespace);
|
49
51
|
debugInstance.log = (message, ...args) => {
|
50
|
-
logWithCaller(namespace, message, ...args);
|
52
|
+
logWithCaller(namespace, framesToSkip, message, ...args);
|
51
53
|
};
|
52
54
|
debugInstance.printStackTrace = (stackTrace, title) => {
|
53
55
|
printStackTrace(namespace, stackTrace, title);
|
54
56
|
};
|
55
57
|
return debugInstance;
|
56
58
|
}
|
57
|
-
function
|
59
|
+
function getLibDebugger(namespace) {
|
60
|
+
const prefix = currentPluginId ? `${currentPluginId}:` : "";
|
61
|
+
return getDebugger(`${prefix}obsidian-dev-utils:${namespace}`);
|
62
|
+
}
|
63
|
+
function initDebugHelpers(pluginId) {
|
64
|
+
currentPluginId = pluginId;
|
58
65
|
window.DEBUG = {
|
59
66
|
disable: disableNamespaces,
|
60
67
|
enable: enableNamespaces,
|
@@ -92,13 +99,13 @@ function enableNamespaces(namespaces) {
|
|
92
99
|
function getNamespaces() {
|
93
100
|
return toArray(import_debug.default.load() ?? "");
|
94
101
|
}
|
95
|
-
function logWithCaller(namespace, message, ...args) {
|
102
|
+
function logWithCaller(namespace, framesToSkip, message, ...args) {
|
96
103
|
if (!import_debug.default.enabled(namespace)) {
|
97
104
|
return;
|
98
105
|
}
|
99
106
|
const CALLER_LINE_INDEX = 4;
|
100
107
|
const stackLines = new Error().stack?.split("\n") ?? [];
|
101
|
-
const callerLine = stackLines[CALLER_LINE_INDEX] ?? "";
|
108
|
+
const callerLine = stackLines[CALLER_LINE_INDEX + framesToSkip] ?? "";
|
102
109
|
console.debug(message, ...args);
|
103
110
|
printStackTrace(namespace, callerLine, "Original debug message caller");
|
104
111
|
}
|
@@ -124,6 +131,7 @@ function toArray(namespaces) {
|
|
124
131
|
// Annotate the CommonJS export names for ESM import in node:
|
125
132
|
0 && (module.exports = {
|
126
133
|
getDebugger,
|
134
|
+
getLibDebugger,
|
127
135
|
initDebugHelpers
|
128
136
|
});
|
129
|
-
//# sourceMappingURL=data:application/json;base64,
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/Debug.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation Debug\n * Contains utility functions for debugging.\n */\n\nimport type { Debugger } from 'debug';\n\nimport debug from 'debug';\n\nimport type { DebugController } from './DebugController.ts';\n\ninterface DebuggerEx extends Debugger {\n  printStackTrace(stackTrace: string, title?: string): void;\n}\n\ninterface DebugWrapper {\n  DEBUG: DebugController;\n}\n\nlet currentPluginId = '';\nconst NAMESPACE_SEPARATOR = ',';\nconst NEGATED_NAMESPACE_PREFIX = '-';\n\n/**\n * Returns a debugger instance with a log function that includes the caller's file name and line number.\n *\n * @param namespace - The namespace for the debugger instance.\n * @param framesToSkip - The number of frames to skip in the stack trace.\n * @returns A debugger instance with a log function that includes the caller's file name and line number.\n */\nexport function getDebugger(namespace: string, framesToSkip = 0): DebuggerEx {\n  const debugInstance = debug(namespace) as DebuggerEx;\n  debugInstance.log = (message: string, ...args: unknown[]): void => {\n    logWithCaller(namespace, framesToSkip, message, ...args);\n  };\n  debugInstance.printStackTrace = (stackTrace, title): void => {\n    printStackTrace(namespace, stackTrace, title);\n  };\n  return debugInstance;\n}\n\n/**\n * Returns a debugger instance for the `obsidian-dev-utils` library.\n *\n * @param namespace - The namespace for the debugger instance.\n * @returns A debugger instance for the `obsidian-dev-utils` library.\n */\nexport function getLibDebugger(namespace: string): DebuggerEx {\n  const prefix = currentPluginId ? `${currentPluginId}:` : '';\n  return getDebugger(`${prefix}obsidian-dev-utils:${namespace}`);\n}\n\n/**\n * Adds the DEBUG variable to the window object.\n *\n * @param pluginId - The plugin ID.\n */\nexport function initDebugHelpers(pluginId: string): void {\n  currentPluginId = pluginId;\n  (window as Partial<DebugWrapper>).DEBUG = {\n    disable: disableNamespaces,\n    enable: enableNamespaces,\n    get: getNamespaces,\n    set: setNamespaces\n  };\n}\n\nfunction disableNamespaces(namespaces: string | string[]): void {\n  const set = new Set(getNamespaces());\n  for (const namespace of toArray(namespaces)) {\n    if (namespace.startsWith(NEGATED_NAMESPACE_PREFIX)) {\n      continue;\n    }\n    const negatedNamespace = NEGATED_NAMESPACE_PREFIX + namespace;\n    if (set.has(namespace)) {\n      set.delete(namespace);\n    }\n    set.add(negatedNamespace);\n  }\n  setNamespaces(Array.from(set));\n}\n\nfunction enableNamespaces(namespaces: string | string[]): void {\n  const set = new Set(getNamespaces());\n  for (const namespace of toArray(namespaces)) {\n    if (!namespace.startsWith(NEGATED_NAMESPACE_PREFIX)) {\n      const negatedNamespace = NEGATED_NAMESPACE_PREFIX + namespace;\n      if (set.has(negatedNamespace)) {\n        set.delete(negatedNamespace);\n      }\n    }\n    set.add(namespace);\n  }\n  setNamespaces(Array.from(set));\n}\n\nfunction getNamespaces(): string[] {\n  return toArray(debug.load() ?? '');\n}\n\nfunction logWithCaller(namespace: string, framesToSkip: number, message: string, ...args: unknown[]): void {\n  if (!debug.enabled(namespace)) {\n    return;\n  }\n\n  /**\n   * The caller line index is 4 because the call stack is as follows:\n   *\n   * 0: Error\n   * 1:     at logWithCaller (?:?:?)\n   * 2:     at debugInstance.log (?:?:?)\n   * 3:     at debug (?:?:?)\n   * 4:     at functionName (path/to/caller.js:?:?)\n   */\n  const CALLER_LINE_INDEX = 4;\n\n  const stackLines = new Error().stack?.split('\\n') ?? [];\n  const callerLine = stackLines[CALLER_LINE_INDEX + framesToSkip] ?? '';\n  console.debug(message, ...args);\n  printStackTrace(namespace, callerLine, 'Original debug message caller');\n}\n\nfunction printStackTrace(namespace: string, stackTrace: string, title?: string): void {\n  if (!debug.enabled(namespace)) {\n    return;\n  }\n\n  if (!stackTrace) {\n    stackTrace = '(unavailable)';\n  }\n  if (!title) {\n    title = 'Caller stack trace';\n  }\n  console.debug(`NotError:${namespace}:${title}\\n${stackTrace}`);\n}\n\nfunction setNamespaces(namespaces: string | string[]): void {\n  debug.enable(toArray(namespaces).join(NAMESPACE_SEPARATOR));\n}\n\nfunction toArray(namespaces: string | string[]): string[] {\n  return typeof namespaces === 'string' ? namespaces.split(NAMESPACE_SEPARATOR).filter(Boolean) : namespaces.flatMap(toArray);\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAOA,mBAAkB;AAYlB,IAAI,kBAAkB;AACtB,MAAM,sBAAsB;AAC5B,MAAM,2BAA2B;AAS1B,SAAS,YAAY,WAAmB,eAAe,GAAe;AAC3E,QAAM,oBAAgB,aAAAA,SAAM,SAAS;AACrC,gBAAc,MAAM,CAAC,YAAoB,SAA0B;AACjE,kBAAc,WAAW,cAAc,SAAS,GAAG,IAAI;AAAA,EACzD;AACA,gBAAc,kBAAkB,CAAC,YAAY,UAAgB;AAC3D,oBAAgB,WAAW,YAAY,KAAK;AAAA,EAC9C;AACA,SAAO;AACT;AAQO,SAAS,eAAe,WAA+B;AAC5D,QAAM,SAAS,kBAAkB,GAAG,eAAe,MAAM;AACzD,SAAO,YAAY,GAAG,MAAM,sBAAsB,SAAS,EAAE;AAC/D;AAOO,SAAS,iBAAiB,UAAwB;AACvD,oBAAkB;AAClB,EAAC,OAAiC,QAAQ;AAAA,IACxC,SAAS;AAAA,IACT,QAAQ;AAAA,IACR,KAAK;AAAA,IACL,KAAK;AAAA,EACP;AACF;AAEA,SAAS,kBAAkB,YAAqC;AAC9D,QAAM,MAAM,IAAI,IAAI,cAAc,CAAC;AACnC,aAAW,aAAa,QAAQ,UAAU,GAAG;AAC3C,QAAI,UAAU,WAAW,wBAAwB,GAAG;AAClD;AAAA,IACF;AACA,UAAM,mBAAmB,2BAA2B;AACpD,QAAI,IAAI,IAAI,SAAS,GAAG;AACtB,UAAI,OAAO,SAAS;AAAA,IACtB;AACA,QAAI,IAAI,gBAAgB;AAAA,EAC1B;AACA,gBAAc,MAAM,KAAK,GAAG,CAAC;AAC/B;AAEA,SAAS,iBAAiB,YAAqC;AAC7D,QAAM,MAAM,IAAI,IAAI,cAAc,CAAC;AACnC,aAAW,aAAa,QAAQ,UAAU,GAAG;AAC3C,QAAI,CAAC,UAAU,WAAW,wBAAwB,GAAG;AACnD,YAAM,mBAAmB,2BAA2B;AACpD,UAAI,IAAI,IAAI,gBAAgB,GAAG;AAC7B,YAAI,OAAO,gBAAgB;AAAA,MAC7B;AAAA,IACF;AACA,QAAI,IAAI,SAAS;AAAA,EACnB;AACA,gBAAc,MAAM,KAAK,GAAG,CAAC;AAC/B;AAEA,SAAS,gBAA0B;AACjC,SAAO,QAAQ,aAAAA,QAAM,KAAK,KAAK,EAAE;AACnC;AAEA,SAAS,cAAc,WAAmB,cAAsB,YAAoB,MAAuB;AACzG,MAAI,CAAC,aAAAA,QAAM,QAAQ,SAAS,GAAG;AAC7B;AAAA,EACF;AAWA,QAAM,oBAAoB;AAE1B,QAAM,aAAa,IAAI,MAAM,EAAE,OAAO,MAAM,IAAI,KAAK,CAAC;AACtD,QAAM,aAAa,WAAW,oBAAoB,YAAY,KAAK;AACnE,UAAQ,MAAM,SAAS,GAAG,IAAI;AAC9B,kBAAgB,WAAW,YAAY,+BAA+B;AACxE;AAEA,SAAS,gBAAgB,WAAmB,YAAoB,OAAsB;AACpF,MAAI,CAAC,aAAAA,QAAM,QAAQ,SAAS,GAAG;AAC7B;AAAA,EACF;AAEA,MAAI,CAAC,YAAY;AACf,iBAAa;AAAA,EACf;AACA,MAAI,CAAC,OAAO;AACV,YAAQ;AAAA,EACV;AACA,UAAQ,MAAM,YAAY,SAAS,IAAI,KAAK;AAAA,EAAK,UAAU,EAAE;AAC/D;AAEA,SAAS,cAAc,YAAqC;AAC1D,eAAAA,QAAM,OAAO,QAAQ,UAAU,EAAE,KAAK,mBAAmB,CAAC;AAC5D;AAEA,SAAS,QAAQ,YAAyC;AACxD,SAAO,OAAO,eAAe,WAAW,WAAW,MAAM,mBAAmB,EAAE,OAAO,OAAO,IAAI,WAAW,QAAQ,OAAO;AAC5H;",
  "names": ["debug"]
}

|
package/dist/lib/Debug.d.ts
CHANGED
@@ -10,11 +10,21 @@ interface DebuggerEx extends Debugger {
|
|
10
10
|
* Returns a debugger instance with a log function that includes the caller's file name and line number.
|
11
11
|
*
|
12
12
|
* @param namespace - The namespace for the debugger instance.
|
13
|
+
* @param framesToSkip - The number of frames to skip in the stack trace.
|
13
14
|
* @returns A debugger instance with a log function that includes the caller's file name and line number.
|
14
15
|
*/
|
15
|
-
export declare function getDebugger(namespace: string): DebuggerEx;
|
16
|
+
export declare function getDebugger(namespace: string, framesToSkip?: number): DebuggerEx;
|
17
|
+
/**
|
18
|
+
* Returns a debugger instance for the `obsidian-dev-utils` library.
|
19
|
+
*
|
20
|
+
* @param namespace - The namespace for the debugger instance.
|
21
|
+
* @returns A debugger instance for the `obsidian-dev-utils` library.
|
22
|
+
*/
|
23
|
+
export declare function getLibDebugger(namespace: string): DebuggerEx;
|
16
24
|
/**
|
17
25
|
* Adds the DEBUG variable to the window object.
|
26
|
+
*
|
27
|
+
* @param pluginId - The plugin ID.
|
18
28
|
*/
|
19
|
-
export declare function initDebugHelpers(): void;
|
29
|
+
export declare function initDebugHelpers(pluginId: string): void;
|
20
30
|
export {};
|
@@ -0,0 +1,26 @@
|
|
1
|
+
/*
|
2
|
+
THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
|
3
|
+
if you want to view the source, please visit the github repository of this plugin
|
4
|
+
*/
|
5
|
+
|
6
|
+
function __extractDefault(module){return module&&module.__esModule&&module.default?module.default:module}
|
7
|
+
|
8
|
+
(function patchRequireEsmDefault(){const __require=require;require=Object.assign(id=>{const module=__require(id)??{};return __extractDefault(module)},__require)})()
|
9
|
+
|
10
|
+
"use strict";
|
11
|
+
var __defProp = Object.defineProperty;
|
12
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
13
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
14
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
15
|
+
var __copyProps = (to, from, except, desc) => {
|
16
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
17
|
+
for (let key of __getOwnPropNames(from))
|
18
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
19
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
20
|
+
}
|
21
|
+
return to;
|
22
|
+
};
|
23
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
24
|
+
var DebugController_exports = {};
|
25
|
+
module.exports = __toCommonJS(DebugController_exports);
|
26
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL0RlYnVnQ29udHJvbGxlci50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqIFByb3ZpZGVzIHRoZSBpbnRlcmZhY2UgZm9yIGNvbnRyb2xsaW5nIGRlYnVnIG91dHB1dCB0aHJvdWdoIG5hbWVzcGFjZSBtYW5hZ2VtZW50LlxuICpcbiAqIERlYnVnIG5hbWVzcGFjZXMgZm9sbG93IHRoZSBwYXR0ZXJuICdmb28nLCBgZm9vOmJhcmAsIGBmb286YmFyOmJhemAsIGV0YywgYW5kIGNhbiB1c2Ugd2lsZGNhcmRzIChgKmApLlxuICpcbiAqIEBleGFtcGxlXG4gKiAtIGBmb286KmAgbWF0Y2hlcyBhbGwgc3VibW9kdWxlcyBvZiAnZm9vJ1xuICogLSBgKjpiYXJgIG1hdGNoZXMgYWxsIHBsdWdpbnMnIGBiYXJgIHN1Ym1vZHVsZXNcbiAqIC0gYCpgIG1hdGNoZXMgZXZlcnl0aGluZ1xuICpcbiAqIFNwZWNpYWwgc3ludGF4OlxuICogLSBOYW1lc3BhY2VzIHByZWZpeGVkIHdpdGggJy0nIGFyZSBleHBsaWNpdGx5IGRpc2FibGVkXG4gKiAtIE11bHRpcGxlIG5hbWVzcGFjZXMgY2FuIGJlIGNvbWJpbmVkIHdpdGggY29tbWFzOiBgZm9vLC1mb286YmFyLGJhejoqYFxuICpcbiAqIEBzZWUge0BsaW5rIGh0dHBzOi8vZ2l0aHViLmNvbS9tbmFvdW1vdi9vYnNpZGlhbi1kZXYtdXRpbHMvP3RhYj1yZWFkbWUtb3YtZmlsZSNkZWJ1Z2dpbmd9XG4gKi9cblxuLyoqXG4gKiBDb250cm9scyBkZWJ1ZyBvdXRwdXQgYnkgbWFuYWdpbmcgZGVidWcgbmFtZXNwYWNlcy5cbiAqIEV4cG9zZWQgZ2xvYmFsbHkgYXMgYHdpbmRvdy5ERUJVR2AuXG4gKlxuICogQHJlbWFya3NcbiAqIERlYnVnIHNldHRpbmdzIHBlcnNpc3QgYWNyb3NzIHBsdWdpbiByZWxvYWRzIGluIGxvY2FsU3RvcmFnZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBEZWJ1Z0NvbnRyb2xsZXIge1xuICAvKipcbiAgICogRGlzYWJsZSBzcGVjaWZpYyBkZWJ1ZyBuYW1lc3BhY2VzLiBEaXNhYmxlZCBuYW1lc3BhY2VzIHRha2UgcHJlY2VkZW5jZVxuICAgKiBvdmVyIGVuYWJsZWQgb25lcyB3aGVuIHRoZXJlJ3MgYSBjb25mbGljdC5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogYGBgdHlwZXNjcmlwdFxuICAgKiB3aW5kb3cuREVCVUcuZGlzYWJsZSgnZm9vJyk7IC8vIGhpZGUgYWxsIGRlYnVnIG1lc3NhZ2VzIGZyb20gdGhlIGBmb29gIHBsdWdpblxuICAgKiB3aW5kb3cuREVCVUcuZGlzYWJsZSgnZm9vOionKTsgLy8gaGlkZSBhbGwgZGVidWcgbWVzc2FnZXMgZnJvbSB0aGUgYGZvb2AgcGx1Z2luIHN1Ym1vZHVsZXNcbiAgICogd2luZG93LkRFQlVHLmRpc2FibGUoWydmb28nLCAnYmFyJ10pOyAvLyBkaXNhYmxlIG11bHRpcGxlIG5hbWVzcGFjZXNcbiAgICogd2luZG93LkRFQlVHLmRpc2FibGUoJ2ZvbyxiYXInKTsgLy8gZGlzYWJsZSBtdWx0aXBsZSBuYW1lc3BhY2VzIHVzaW5nIGNvbW1hLXNlcGFyYXRlZCBzdHJpbmdcbiAgICogd2luZG93LkRFQlVHLmRpc2FibGUoJyonKTsgLy8gZGlzYWJsZSBhbGwgZGVidWcgbWVzc2FnZXNcbiAgICogYGBgXG4gICAqXG4gICAqIEBwYXJhbSBuYW1lc3BhY2VzIC0gU2luZ2xlIG5hbWVzcGFjZSBzdHJpbmcgb3IgYXJyYXkgb2YgbmFtZXNwYWNlIHN0cmluZ3MgdG8gZGlzYWJsZVxuICAgKi9cbiAgZGlzYWJsZShuYW1lc3BhY2VzOiBzdHJpbmcgfCBzdHJpbmdbXSk6IHZvaWQ7XG5cbiAgLyoqXG4gICAqIEVuYWJsZSBzcGVjaWZpYyBkZWJ1ZyBuYW1lc3BhY2VzLiBOb3RlIHRoYXQgZXhwbGljaXRseSBkaXNhYmxlZFxuICAgKiBuYW1lc3BhY2VzIChwcmVmaXhlZCB3aXRoICctJykgd2lsbCByZW1haW4gZGlzYWJsZWQuXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGBgYHR5cGVzY3JpcHRcbiAgICogd2luZG93LkRFQlVHLmVuYWJsZSgnZm9vJyk7IC8vIHNob3cgYWxsIGRlYnVnIG1lc3NhZ2VzIGZyb20gdGhlIGBmb29gIHBsdWdpblxuICAgKiB3aW5kb3cuREVCVUcuZW5hYmxlKCdmb286b2JzaWRpYW4tZGV2LXV0aWxzOionKTsgLy8gc2hvdyBhbGwgZGVidWcgbWVzc2FnZXMgZnJvbSB0aGUgYG9ic2lkaWFuLWRldi11dGlsc2AgbGlicmFyeSB3aXRoaW4gdGhlIGBmb29gIHBsdWdpblxuICAgKiB3aW5kb3cuREVCVUcuZW5hYmxlKCdmb286KicpOyAvLyBzaG93IGFsbCBkZWJ1ZyBtZXNzYWdlcyBmcm9tIHRoZSBgZm9vYCBwbHVnaW4gYW5kIGl0cyBzdWJtb2R1bGVzXG4gICAqIHdpbmRvdy5ERUJVRy5lbmFibGUoJyo6b2JzaWRpYW4tZGV2LXV0aWxzOionKTsgLy8gc2hvdyBhbGwgZGVidWcgbWVzc2FnZXMgZm9yIHRoZSBgb2JzaWRpYW4tZGV2LXV0aWxzYCBsaWJyYXJ5IHdpdGhpbiBhbnkgcGx1Z2luXG4gICAqIHdpbmRvdy5ERUJVRy5lbmFibGUoWydmb28nLCAnYmFyJ10pOyAvLyBlbmFibGUgbXVsdGlwbGUgbmFtZXNwYWNlc1xuICAgKiB3aW5kb3cuREVCVUcuZW5hYmxlKCdmb28sYmFyJyk7IC8vIGVuYWJsZSBtdWx0aXBsZSBuYW1lc3BhY2VzIHVzaW5nIGNvbW1hLXNlcGFyYXRlZCBzdHJpbmdcbiAgICogd2luZG93LkRFQlVHLmVuYWJsZSgnKicpOyAvLyBzaG93IGFsbCBkZWJ1ZyBtZXNzYWdlc1xuICAgKiBgYGBcbiAgICpcbiAgICogQHBhcmFtIG5hbWVzcGFjZXMgLSBTaW5nbGUgbmFtZXNwYWNlIHN0cmluZyBvciBhcnJheSBvZiBuYW1lc3BhY2Ugc3RyaW5ncyB0byBlbmFibGVcbiAgICovXG4gIGVuYWJsZShuYW1lc3BhY2VzOiBzdHJpbmcgfCBzdHJpbmdbXSk6IHZvaWQ7XG5cbiAgLyoqXG4gICAqIEdldCBjdXJyZW50bHkgY29uZmlndXJlZCBkZWJ1ZyBuYW1lc3BhY2VzLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBgYGB0eXBlc2NyaXB0XG4gICAqIHdpbmRvdy5ERUJVRy5nZXQoKTsgLy8gcmV0dXJucyBbJ2ZvbycsICdiYXI6KicsICctYmF6J11cbiAgICogYGBgXG4gICAqXG4gICAqIEByZXR1cm5zIEFycmF5IG9mIGVuYWJsZWQgYW5kIGRpc2FibGVkIChwcmVmaXhlZCB3aXRoIGAtYCkgZGVidWcgbmFtZXNwYWNlc1xuICAgKi9cbiAgZ2V0KCk6IHN0cmluZ1tdO1xuXG4gIC8qKlxuICAgKiBTZXQgZGVidWcgbmFtZXNwYWNlcywgcmVwbGFjaW5nIGFsbCBwcmV2aW91cyBjb25maWd1cmF0aW9ucy5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogYGBgdHlwZXNjcmlwdFxuICAgKiB3aW5kb3cuREVCVUcuc2V0KFsnZm9vJywgJ2JhcjoqJywgJy1iYXonXSk7IC8vIEVuYWJsZSAnZm9vJyBhbmQgJ2JhcjoqJywgZXhwbGljaXRseSBkaXNhYmxlICdiYXonXG4gICAqIHdpbmRvdy5ERUJVRy5zZXQoJ2ZvbyxiYXI6KiwtYmF6Jyk7IC8vIFNhbWUgdGhpbmcgdXNpbmcgY29tbWEtc2VwYXJhdGVkIHN0cmluZ1xuICAgKiB3aW5kb3cuREVCVUcuc2V0KCcqJyk7IC8vIEVuYWJsZSBhbGwgZGVidWcgbWVzc2FnZXNcbiAgICogd2luZG93LkRFQlVHLnNldCgnJyk7IC8vIERpc2FibGUgYWxsIGRlYnVnIG1lc3NhZ2VzXG4gICAqIGBgYFxuICAgKlxuICAgKiBAcGFyYW0gbmFtZXNwYWNlcyAtIFN0cmluZyBvciBhcnJheSBvZiBuYW1lc3BhY2UgcGF0dGVybnNcbiAgICovXG4gIHNldChuYW1lc3BhY2VzOiBzdHJpbmcgfCBzdHJpbmdbXSk6IHZvaWQ7XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7IiwKICAibmFtZXMiOiBbXQp9Cg==
|
@@ -0,0 +1,85 @@
|
|
1
|
+
/**
|
2
|
+
* @packageDocumentation
|
3
|
+
* Provides the interface for controlling debug output through namespace management.
|
4
|
+
*
|
5
|
+
* Debug namespaces follow the pattern 'foo', `foo:bar`, `foo:bar:baz`, etc, and can use wildcards (`*`).
|
6
|
+
*
|
7
|
+
* @example
|
8
|
+
* - `foo:*` matches all submodules of 'foo'
|
9
|
+
* - `*:bar` matches all plugins' `bar` submodules
|
10
|
+
* - `*` matches everything
|
11
|
+
*
|
12
|
+
* Special syntax:
|
13
|
+
* - Namespaces prefixed with '-' are explicitly disabled
|
14
|
+
* - Multiple namespaces can be combined with commas: `foo,-foo:bar,baz:*`
|
15
|
+
*
|
16
|
+
* @see {@link https://github.com/mnaoumov/obsidian-dev-utils/?tab=readme-ov-file#debugging}
|
17
|
+
*/
|
18
|
+
/**
|
19
|
+
* Controls debug output by managing debug namespaces.
|
20
|
+
* Exposed globally as `window.DEBUG`.
|
21
|
+
*
|
22
|
+
* @remarks
|
23
|
+
* Debug settings persist across plugin reloads in localStorage.
|
24
|
+
*/
|
25
|
+
export interface DebugController {
|
26
|
+
/**
|
27
|
+
* Disable specific debug namespaces. Disabled namespaces take precedence
|
28
|
+
* over enabled ones when there's a conflict.
|
29
|
+
*
|
30
|
+
* @example
|
31
|
+
* ```typescript
|
32
|
+
* window.DEBUG.disable('foo'); // hide all debug messages from the `foo` plugin
|
33
|
+
* window.DEBUG.disable('foo:*'); // hide all debug messages from the `foo` plugin submodules
|
34
|
+
* window.DEBUG.disable(['foo', 'bar']); // disable multiple namespaces
|
35
|
+
* window.DEBUG.disable('foo,bar'); // disable multiple namespaces using comma-separated string
|
36
|
+
* window.DEBUG.disable('*'); // disable all debug messages
|
37
|
+
* ```
|
38
|
+
*
|
39
|
+
* @param namespaces - Single namespace string or array of namespace strings to disable
|
40
|
+
*/
|
41
|
+
disable(namespaces: string | string[]): void;
|
42
|
+
/**
|
43
|
+
* Enable specific debug namespaces. Note that explicitly disabled
|
44
|
+
* namespaces (prefixed with '-') will remain disabled.
|
45
|
+
*
|
46
|
+
* @example
|
47
|
+
* ```typescript
|
48
|
+
* window.DEBUG.enable('foo'); // show all debug messages from the `foo` plugin
|
49
|
+
* window.DEBUG.enable('foo:obsidian-dev-utils:*'); // show all debug messages from the `obsidian-dev-utils` library within the `foo` plugin
|
50
|
+
* window.DEBUG.enable('foo:*'); // show all debug messages from the `foo` plugin and its submodules
|
51
|
+
* window.DEBUG.enable('*:obsidian-dev-utils:*'); // show all debug messages for the `obsidian-dev-utils` library within any plugin
|
52
|
+
* window.DEBUG.enable(['foo', 'bar']); // enable multiple namespaces
|
53
|
+
* window.DEBUG.enable('foo,bar'); // enable multiple namespaces using comma-separated string
|
54
|
+
* window.DEBUG.enable('*'); // show all debug messages
|
55
|
+
* ```
|
56
|
+
*
|
57
|
+
* @param namespaces - Single namespace string or array of namespace strings to enable
|
58
|
+
*/
|
59
|
+
enable(namespaces: string | string[]): void;
|
60
|
+
/**
|
61
|
+
* Get currently configured debug namespaces.
|
62
|
+
*
|
63
|
+
* @example
|
64
|
+
* ```typescript
|
65
|
+
* window.DEBUG.get(); // returns ['foo', 'bar:*', '-baz']
|
66
|
+
* ```
|
67
|
+
*
|
68
|
+
* @returns Array of enabled and disabled (prefixed with `-`) debug namespaces
|
69
|
+
*/
|
70
|
+
get(): string[];
|
71
|
+
/**
|
72
|
+
* Set debug namespaces, replacing all previous configurations.
|
73
|
+
*
|
74
|
+
* @example
|
75
|
+
* ```typescript
|
76
|
+
* window.DEBUG.set(['foo', 'bar:*', '-baz']); // Enable 'foo' and 'bar:*', explicitly disable 'baz'
|
77
|
+
* window.DEBUG.set('foo,bar:*,-baz'); // Same thing using comma-separated string
|
78
|
+
* window.DEBUG.set('*'); // Enable all debug messages
|
79
|
+
* window.DEBUG.set(''); // Disable all debug messages
|
80
|
+
* ```
|
81
|
+
*
|
82
|
+
* @param namespaces - String or array of namespace patterns
|
83
|
+
*/
|
84
|
+
set(namespaces: string | string[]): void;
|
85
|
+
}
|
package/dist/lib/index.cjs
CHANGED
@@ -40,6 +40,7 @@ __export(index_exports, {
|
|
40
40
|
Async: () => Async,
|
41
41
|
Blob: () => Blob,
|
42
42
|
Debug: () => Debug,
|
43
|
+
DebugController: () => DebugController,
|
43
44
|
Error: () => Error2,
|
44
45
|
Function: () => Function,
|
45
46
|
HTMLElement: () => HTMLElement,
|
@@ -58,6 +59,7 @@ var _types = __toESM(__extractDefault(require('./@types.cjs')), 1);
|
|
58
59
|
var Async = __toESM(__extractDefault(require('./Async.cjs')), 1);
|
59
60
|
var Blob = __toESM(__extractDefault(require('./Blob.cjs')), 1);
|
60
61
|
var Debug = __toESM(__extractDefault(require('./Debug.cjs')), 1);
|
62
|
+
var DebugController = __toESM(__extractDefault(require('./DebugController.cjs')), 1);
|
61
63
|
var Error2 = __toESM(__extractDefault(require('./Error.cjs')), 1);
|
62
64
|
var Function = __toESM(__extractDefault(require('./Function.cjs')), 1);
|
63
65
|
var HTMLElement = __toESM(__extractDefault(require('./HTMLElement.cjs')), 1);
|
@@ -74,6 +76,7 @@ var ValueProvider = __toESM(__extractDefault(require('./ValueProvider.cjs')), 1)
|
|
74
76
|
Async,
|
75
77
|
Blob,
|
76
78
|
Debug,
|
79
|
+
DebugController,
|
77
80
|
Error,
|
78
81
|
Function,
|
79
82
|
HTMLElement,
|
@@ -87,4 +90,4 @@ var ValueProvider = __toESM(__extractDefault(require('./ValueProvider.cjs')), 1)
|
|
87
90
|
scripts,
|
88
91
|
url
|
89
92
|
});
|
90
|
-
//# sourceMappingURL=data:application/json;base64,
|
93
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKiBUSElTIElTIEEgR0VORVJBVEVEL0JVTkRMRUQgRklMRSBCWSBCVUlMRCBTQ1JJUFQgKi9cblxuZXhwb3J0ICogYXMgX3R5cGVzIGZyb20gJy4vQHR5cGVzLnRzJztcbmV4cG9ydCAqIGFzIEFzeW5jIGZyb20gJy4vQXN5bmMudHMnO1xuZXhwb3J0ICogYXMgQmxvYiBmcm9tICcuL0Jsb2IudHMnO1xuZXhwb3J0ICogYXMgRGVidWcgZnJvbSAnLi9EZWJ1Zy50cyc7XG5leHBvcnQgKiBhcyBEZWJ1Z0NvbnRyb2xsZXIgZnJvbSAnLi9EZWJ1Z0NvbnRyb2xsZXIudHMnO1xuZXhwb3J0ICogYXMgRXJyb3IgZnJvbSAnLi9FcnJvci50cyc7XG5leHBvcnQgKiBhcyBGdW5jdGlvbiBmcm9tICcuL0Z1bmN0aW9uLnRzJztcbmV4cG9ydCAqIGFzIEhUTUxFbGVtZW50IGZyb20gJy4vSFRNTEVsZW1lbnQudHMnO1xuZXhwb3J0ICogYXMgT2JqZWN0IGZyb20gJy4vT2JqZWN0LnRzJztcbmV4cG9ydCAqIGFzIG9ic2lkaWFuIGZyb20gJy4vb2JzaWRpYW4vaW5kZXgudHMnO1xuZXhwb3J0ICogYXMgUGF0aCBmcm9tICcuL1BhdGgudHMnO1xuZXhwb3J0ICogYXMgUmVnRXhwIGZyb20gJy4vUmVnRXhwLnRzJztcbmV4cG9ydCAqIGFzIHNjcmlwdHMgZnJvbSAnLi9zY3JpcHRzL2luZGV4LnRzJztcbmV4cG9ydCAqIGFzIFN0cmluZyBmcm9tICcuL1N0cmluZy50cyc7XG5leHBvcnQgKiBhcyB1cmwgZnJvbSAnLi91cmwudHMnO1xuZXhwb3J0ICogYXMgVmFsdWVQcm92aWRlciBmcm9tICcuL1ZhbHVlUHJvdmlkZXIudHMnO1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLGVBQUFBO0FBQUEsRUFBQTtBQUFBO0FBQUEsZ0JBQUFDO0FBQUEsRUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUVBLGFBQXdCO0FBQ3hCLFlBQXVCO0FBQ3ZCLFdBQXNCO0FBQ3RCLFlBQXVCO0FBQ3ZCLHNCQUFpQztBQUNqQyxJQUFBRCxTQUF1QjtBQUN2QixlQUEwQjtBQUMxQixrQkFBNkI7QUFDN0IsSUFBQUMsVUFBd0I7QUFDeEIsZUFBMEI7QUFDMUIsV0FBc0I7QUFDdEIsYUFBd0I7QUFDeEIsY0FBeUI7QUFDekIsYUFBd0I7QUFDeEIsVUFBcUI7QUFDckIsb0JBQStCOyIsCiAgIm5hbWVzIjogWyJFcnJvciIsICJPYmplY3QiXQp9Cg==
|
package/dist/lib/index.d.ts
CHANGED
@@ -2,6 +2,7 @@ export * as _types from './@types.ts';
|
|
2
2
|
export * as Async from './Async.ts';
|
3
3
|
export * as Blob from './Blob.ts';
|
4
4
|
export * as Debug from './Debug.ts';
|
5
|
+
export * as DebugController from './DebugController.ts';
|
5
6
|
export * as Error from './Error.ts';
|
6
7
|
export * as Function from './Function.ts';
|
7
8
|
export * as HTMLElement from './HTMLElement.ts';
|
@@ -32,35 +32,35 @@ __export(Logger_exports, {
|
|
32
32
|
module.exports = __toCommonJS(Logger_exports);
|
33
33
|
var import_Debug = require('../Debug.cjs');
|
34
34
|
var import_Error = require('../Error.cjs');
|
35
|
-
const invokeAsyncAndLogDebugger = (0, import_Debug.getDebugger)("obsidian-dev-utils:Logger:invokeAsyncAndLog");
|
36
35
|
async function invokeAsyncAndLog(title, fn, stackTrace) {
|
36
|
+
const _debugger = (0, import_Debug.getLibDebugger)("Logger:invokeAsyncAndLog");
|
37
37
|
const timestampStart = performance.now();
|
38
38
|
stackTrace ??= (0, import_Error.getStackTrace)(1);
|
39
|
-
|
39
|
+
_debugger(`${title}:start`, {
|
40
40
|
fn,
|
41
41
|
timestampStart
|
42
42
|
});
|
43
|
-
|
43
|
+
_debugger.printStackTrace(stackTrace);
|
44
44
|
try {
|
45
45
|
await fn();
|
46
46
|
const timestampEnd = performance.now();
|
47
|
-
|
47
|
+
_debugger(`${title}:end`, {
|
48
48
|
duration: timestampEnd - timestampStart,
|
49
49
|
fn,
|
50
50
|
timestampEnd,
|
51
51
|
timestampStart
|
52
52
|
});
|
53
|
-
|
53
|
+
_debugger.printStackTrace(stackTrace);
|
54
54
|
} catch (error) {
|
55
55
|
const timestampEnd = performance.now();
|
56
|
-
|
56
|
+
_debugger(`${title}:error`, {
|
57
57
|
duration: timestampEnd - timestampStart,
|
58
58
|
error,
|
59
59
|
fn,
|
60
60
|
timestampEnd,
|
61
61
|
timestampStart
|
62
62
|
});
|
63
|
-
|
63
|
+
_debugger.printStackTrace(stackTrace);
|
64
64
|
throw error;
|
65
65
|
}
|
66
66
|
}
|
@@ -68,4 +68,4 @@ async function invokeAsyncAndLog(title, fn, stackTrace) {
|
|
68
68
|
0 && (module.exports = {
|
69
69
|
invokeAsyncAndLog
|
70
70
|
});
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
71
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL29ic2lkaWFuL0xvZ2dlci50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb24gTG9nZ2VyXG4gKiBDb250YWlucyB1dGlsaXR5IGZ1bmN0aW9ucyBmb3IgbG9nZ2luZyBpbiBPYnNpZGlhbi5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7IE1heWJlUHJvbWlzZSB9IGZyb20gJy4uL0FzeW5jLnRzJztcblxuaW1wb3J0IHsgZ2V0TGliRGVidWdnZXIgfSBmcm9tICcuLi9EZWJ1Zy50cyc7XG5pbXBvcnQgeyBnZXRTdGFja1RyYWNlIH0gZnJvbSAnLi4vRXJyb3IudHMnO1xuXG4vKipcbiAqIEludm9rZXMgYSBmdW5jdGlvbiBhbmQgbG9ncyB0aGUgc3RhcnQsIGVuZCwgYW5kIGR1cmF0aW9uIG9mIHRoZSBpbnZvY2F0aW9uLlxuICpcbiAqIEBwYXJhbSB0aXRsZSAtIFRoZSB0aXRsZSBvZiB0aGUgbG9nLlxuICogQHBhcmFtIGZuIC0gVGhlIGZ1bmN0aW9uIHRvIGludm9rZS5cbiAqIEBwYXJhbSBzdGFja1RyYWNlIC0gT3B0aW9uYWwgc3RhY2sgdHJhY2UuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBpbnZva2VBc3luY0FuZExvZyh0aXRsZTogc3RyaW5nLCBmbjogKCkgPT4gTWF5YmVQcm9taXNlPHZvaWQ+LCBzdGFja1RyYWNlPzogc3RyaW5nKTogUHJvbWlzZTx2b2lkPiB7XG4gIGNvbnN0IF9kZWJ1Z2dlciA9IGdldExpYkRlYnVnZ2VyKCdMb2dnZXI6aW52b2tlQXN5bmNBbmRMb2cnKTtcbiAgY29uc3QgdGltZXN0YW1wU3RhcnQgPSBwZXJmb3JtYW5jZS5ub3coKTtcbiAgc3RhY2tUcmFjZSA/Pz0gZ2V0U3RhY2tUcmFjZSgxKTtcbiAgX2RlYnVnZ2VyKGAke3RpdGxlfTpzdGFydGAsIHtcbiAgICBmbixcbiAgICB0aW1lc3RhbXBTdGFydFxuICB9KTtcbiAgX2RlYnVnZ2VyLnByaW50U3RhY2tUcmFjZShzdGFja1RyYWNlKTtcbiAgdHJ5IHtcbiAgICBhd2FpdCBmbigpO1xuICAgIGNvbnN0IHRpbWVzdGFtcEVuZCA9IHBlcmZvcm1hbmNlLm5vdygpO1xuICAgIF9kZWJ1Z2dlcihgJHt0aXRsZX06ZW5kYCwge1xuICAgICAgZHVyYXRpb246IHRpbWVzdGFtcEVuZCAtIHRpbWVzdGFtcFN0YXJ0LFxuICAgICAgZm4sXG4gICAgICB0aW1lc3RhbXBFbmQsXG4gICAgICB0aW1lc3RhbXBTdGFydFxuICAgIH0pO1xuICAgIF9kZWJ1Z2dlci5wcmludFN0YWNrVHJhY2Uoc3RhY2tUcmFjZSk7XG4gIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgY29uc3QgdGltZXN0YW1wRW5kID0gcGVyZm9ybWFuY2Uubm93KCk7XG4gICAgX2RlYnVnZ2VyKGAke3RpdGxlfTplcnJvcmAsIHtcbiAgICAgIGR1cmF0aW9uOiB0aW1lc3RhbXBFbmQgLSB0aW1lc3RhbXBTdGFydCxcbiAgICAgIGVycm9yLFxuICAgICAgZm4sXG4gICAgICB0aW1lc3RhbXBFbmQsXG4gICAgICB0aW1lc3RhbXBTdGFydFxuICAgIH0pO1xuICAgIF9kZWJ1Z2dlci5wcmludFN0YWNrVHJhY2Uoc3RhY2tUcmFjZSk7XG5cbiAgICB0aHJvdyBlcnJvcjtcbiAgfVxufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQU9BLG1CQUErQjtBQUMvQixtQkFBOEI7QUFTOUIsZUFBc0Isa0JBQWtCLE9BQWUsSUFBOEIsWUFBb0M7QUFDdkgsUUFBTSxnQkFBWSw2QkFBZSwwQkFBMEI7QUFDM0QsUUFBTSxpQkFBaUIsWUFBWSxJQUFJO0FBQ3ZDLHFCQUFlLDRCQUFjLENBQUM7QUFDOUIsWUFBVSxHQUFHLEtBQUssVUFBVTtBQUFBLElBQzFCO0FBQUEsSUFDQTtBQUFBLEVBQ0YsQ0FBQztBQUNELFlBQVUsZ0JBQWdCLFVBQVU7QUFDcEMsTUFBSTtBQUNGLFVBQU0sR0FBRztBQUNULFVBQU0sZUFBZSxZQUFZLElBQUk7QUFDckMsY0FBVSxHQUFHLEtBQUssUUFBUTtBQUFBLE1BQ3hCLFVBQVUsZUFBZTtBQUFBLE1BQ3pCO0FBQUEsTUFDQTtBQUFBLE1BQ0E7QUFBQSxJQUNGLENBQUM7QUFDRCxjQUFVLGdCQUFnQixVQUFVO0FBQUEsRUFDdEMsU0FBUyxPQUFPO0FBQ2QsVUFBTSxlQUFlLFlBQVksSUFBSTtBQUNyQyxjQUFVLEdBQUcsS0FBSyxVQUFVO0FBQUEsTUFDMUIsVUFBVSxlQUFlO0FBQUEsTUFDekI7QUFBQSxNQUNBO0FBQUEsTUFDQTtBQUFBLE1BQ0E7QUFBQSxJQUNGLENBQUM7QUFDRCxjQUFVLGdCQUFnQixVQUFVO0FBRXBDLFVBQU07QUFBQSxFQUNSO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
|
@@ -51,7 +51,7 @@ async function loop(options) {
|
|
51
51
|
const iterationStr = `# ${iterationCount.toString()} / ${items.length.toString()}`;
|
52
52
|
const message = options.buildNoticeMessage(item, iterationStr);
|
53
53
|
notice.setMessage(message);
|
54
|
-
(0, import_Debug.
|
54
|
+
(0, import_Debug.getLibDebugger)("Loop")(message);
|
55
55
|
try {
|
56
56
|
await options.processItem(item);
|
57
57
|
} catch (error) {
|
@@ -69,4 +69,4 @@ async function loop(options) {
|
|
69
69
|
0 && (module.exports = {
|
70
70
|
loop
|
71
71
|
});
|
72
|
-
//# sourceMappingURL=data:application/json;base64,
|
72
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL29ic2lkaWFuL0xvb3AudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbInZhciBfX3Byb2Nlc3MgPSBnbG9iYWxUaGlzWydwcm9jZXNzJ10gPz8ge1xuICBcImJyb3dzZXJcIjogdHJ1ZSxcbiAgXCJjd2RcIjogKCk9PlwiL1wiLFxuICBcImVudlwiOiB7fSxcbiAgXCJwbGF0Zm9ybVwiOiBcImFuZHJvaWRcIlxufTtcbi8qKlxuICogQHBhY2thZ2VEb2N1bWVudGF0aW9uIExvb3BcbiAqIENvbnRhaW5zIHV0aWxpdHkgZnVuY3Rpb25zIGZvciBsb29waW5nIGluIE9ic2lkaWFuLlxuICovXG5cbmltcG9ydCB0eXBlIHsgTWF5YmVQcm9taXNlIH0gZnJvbSAnLi4vQXN5bmMudHMnO1xuXG5pbXBvcnQgeyBnZXRMaWJEZWJ1Z2dlciB9IGZyb20gJy4uL0RlYnVnLnRzJztcbmltcG9ydCB7IGVtaXRBc3luY0Vycm9yRXZlbnQgfSBmcm9tICcuLi9FcnJvci50cyc7XG5cbi8qKlxuICogT3B0aW9ucyBmb3IgdGhlIGxvb3AgZnVuY3Rpb24uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTG9vcE9wdGlvbnM8VD4ge1xuICAvKipcbiAgICogQW4gb3B0aW9uYWwgYWJvcnQgc2lnbmFsIHRvIGNhbmNlbCB0aGUgbG9vcC5cbiAgICovXG4gIGFib3J0U2lnbmFsPzogQWJvcnRTaWduYWw7XG4gIC8qKlxuICAgKiBUaGUgZnVuY3Rpb24gdG8gYnVpbGQgdGhlIG5vdGljZSBtZXNzYWdlIGZvciBlYWNoIGl0ZW0uXG4gICAqL1xuICBidWlsZE5vdGljZU1lc3NhZ2UoaXRlbTogVCwgaXRlcmF0aW9uU3RyOiBzdHJpbmcpOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBUaGUgaXRlbXMgdG8gbG9vcCBvdmVyLlxuICAgKi9cbiAgaXRlbXM6IFRbXTtcbiAgLyoqXG4gICAqIFRoZSBmdW5jdGlvbiB0byBwcm9jZXNzIGVhY2ggaXRlbS5cbiAgICovXG4gIHByb2Nlc3NJdGVtKGl0ZW06IFQpOiBNYXliZVByb21pc2U8dm9pZD47XG4gIC8qKlxuICAgKiBXaGV0aGVyIHRvIGNvbnRpbnVlIHRoZSBsb29wIG9uIGVycm9yLlxuICAgKi9cbiAgc2hvdWxkQ29udGludWVPbkVycm9yPzogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBMb29wcyBvdmVyIGEgbGlzdCBvZiBpdGVtcyBhbmQgcHJvY2Vzc2VzIGVhY2ggaXRlbS5cbiAqXG4gKiBAcGFyYW0gb3B0aW9ucyAtIFRoZSBvcHRpb25zIGZvciB0aGUgbG9vcC5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGxvb3A8VD4ob3B0aW9uczogTG9vcE9wdGlvbnM8VD4pOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uc3QgaXRlbXMgPSBvcHRpb25zLml0ZW1zO1xuICBsZXQgaXRlcmF0aW9uQ291bnQgPSAwO1xuICBjb25zdCBub3RpY2UgPSBuZXcgTm90aWNlKCcnLCAwKTtcbiAgZm9yIChjb25zdCBpdGVtIG9mIGl0ZW1zKSB7XG4gICAgaWYgKG9wdGlvbnMuYWJvcnRTaWduYWw/LmFib3J0ZWQpIHtcbiAgICAgIG5vdGljZS5oaWRlKCk7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIGl0ZXJhdGlvbkNvdW50Kys7XG4gICAgY29uc3QgaXRlcmF0aW9uU3RyID0gYCMgJHtpdGVyYXRpb25Db3VudC50b1N0cmluZygpfSAvICR7aXRlbXMubGVuZ3RoLnRvU3RyaW5nKCl9YDtcbiAgICBjb25zdCBtZXNzYWdlID0gb3B0aW9ucy5idWlsZE5vdGljZU1lc3NhZ2UoaXRlbSwgaXRlcmF0aW9uU3RyKTtcbiAgICBub3RpY2Uuc2V0TWVzc2FnZShtZXNzYWdlKTtcbiAgICBnZXRMaWJEZWJ1Z2dlcignTG9vcCcpKG1lc3NhZ2UpO1xuXG4gICAgdHJ5IHtcbiAgICAgIGF3YWl0IG9wdGlvbnMucHJvY2Vzc0l0ZW0oaXRlbSk7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIGlmICghb3B0aW9ucy5zaG91bGRDb250aW51ZU9uRXJyb3IpIHtcbiAgICAgICAgbm90aWNlLmhpZGUoKTtcbiAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBlbWl0QXN5bmNFcnJvckV2ZW50KGVycm9yKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgbm90aWNlLmhpZGUoKTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFhQSxtQkFBK0I7QUFDL0IsbUJBQW9DO0FBZHBDLElBQUksWUFBWSxXQUFXLFNBQVMsS0FBSztBQUFBLEVBQ3ZDLFdBQVc7QUFBQSxFQUNYLE9BQU8sTUFBSTtBQUFBLEVBQ1gsT0FBTyxDQUFDO0FBQUEsRUFDUixZQUFZO0FBQ2Q7QUEwQ0EsZUFBc0IsS0FBUSxTQUF3QztBQUNwRSxRQUFNLFFBQVEsUUFBUTtBQUN0QixNQUFJLGlCQUFpQjtBQUNyQixRQUFNLFNBQVMsSUFBSSxPQUFPLElBQUksQ0FBQztBQUMvQixhQUFXLFFBQVEsT0FBTztBQUN4QixRQUFJLFFBQVEsYUFBYSxTQUFTO0FBQ2hDLGFBQU8sS0FBSztBQUNaO0FBQUEsSUFDRjtBQUNBO0FBQ0EsVUFBTSxlQUFlLEtBQUssZUFBZSxTQUFTLENBQUMsTUFBTSxNQUFNLE9BQU8sU0FBUyxDQUFDO0FBQ2hGLFVBQU0sVUFBVSxRQUFRLG1CQUFtQixNQUFNLFlBQVk7QUFDN0QsV0FBTyxXQUFXLE9BQU87QUFDekIscUNBQWUsTUFBTSxFQUFFLE9BQU87QUFFOUIsUUFBSTtBQUNGLFlBQU0sUUFBUSxZQUFZLElBQUk7QUFBQSxJQUNoQyxTQUFTLE9BQU87QUFDZCxVQUFJLENBQUMsUUFBUSx1QkFBdUI7QUFDbEMsZUFBTyxLQUFLO0FBQ1osY0FBTTtBQUFBLE1BQ1IsT0FBTztBQUNMLDhDQUFvQixLQUFLO0FBQUEsTUFDM0I7QUFBQSxJQUNGO0FBQUEsRUFDRjtBQUNBLFNBQU8sS0FBSztBQUNkOyIsCiAgIm5hbWVzIjogW10KfQo=
|