obsidian-dev-utils 4.10.0 → 4.12.0
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 +11 -0
- package/dist/lib/@types/compare-versions.d.ts +1 -0
- package/dist/lib/Async.cjs +50 -35
- package/dist/lib/Async.d.ts +66 -66
- package/dist/lib/Blob.cjs +11 -11
- package/dist/lib/Blob.d.ts +7 -7
- package/dist/lib/Error.cjs +17 -17
- package/dist/lib/Error.d.ts +14 -14
- package/dist/lib/Function.cjs +8 -8
- package/dist/lib/Function.d.ts +12 -12
- package/dist/lib/Object.cjs +36 -36
- package/dist/lib/Object.d.ts +55 -55
- package/dist/lib/Path.cjs +16 -16
- package/dist/lib/Path.d.ts +28 -28
- package/dist/lib/String.cjs +35 -35
- package/dist/lib/String.d.ts +55 -55
- package/dist/lib/ValueProvider.cjs +4 -4
- package/dist/lib/obsidian/App.cjs +6 -6
- package/dist/lib/obsidian/App.d.ts +7 -7
- package/dist/lib/obsidian/AttachmentPath.cjs +9 -9
- package/dist/lib/obsidian/AttachmentPath.d.ts +8 -8
- package/dist/lib/obsidian/Backlink.cjs +28 -28
- package/dist/lib/obsidian/Backlink.d.ts +22 -22
- package/dist/lib/obsidian/Callout.cjs +13 -13
- package/dist/lib/obsidian/Dataview.cjs +40 -40
- package/dist/lib/obsidian/Dataview.d.ts +69 -69
- package/dist/lib/obsidian/FileChange.cjs +7 -7
- package/dist/lib/obsidian/FileChange.d.ts +22 -22
- package/dist/lib/obsidian/FileManager.cjs +18 -18
- package/dist/lib/obsidian/FileManager.d.ts +11 -11
- package/dist/lib/obsidian/FileSystem.cjs +31 -31
- package/dist/lib/obsidian/FileSystem.d.ts +41 -41
- package/dist/lib/obsidian/FrontMatter.cjs +1 -1
- package/dist/lib/obsidian/FrontMatter.d.ts +6 -6
- package/dist/lib/obsidian/Link.cjs +154 -154
- package/dist/lib/obsidian/Link.d.ts +163 -163
- package/dist/lib/obsidian/MetadataCache.cjs +61 -61
- package/dist/lib/obsidian/MetadataCache.d.ts +28 -28
- package/dist/lib/obsidian/Modal/Alert.cjs +7 -7
- package/dist/lib/obsidian/Modal/Confirm.cjs +7 -7
- package/dist/lib/obsidian/Modal/Prompt.cjs +15 -15
- package/dist/lib/obsidian/Modal/SelectItem.cjs +7 -7
- package/dist/lib/obsidian/ObsidianSettings.cjs +4 -4
- package/dist/lib/obsidian/ObsidianSettings.d.ts +6 -6
- package/dist/lib/obsidian/Plugin/Plugin.cjs +6 -6
- package/dist/lib/obsidian/Plugin/Plugin.d.ts +7 -7
- package/dist/lib/obsidian/Plugin/PluginBase.cjs +52 -52
- package/dist/lib/obsidian/Plugin/PluginBase.d.ts +29 -29
- package/dist/lib/obsidian/Plugin/PluginSettings.cjs +4 -4
- package/dist/lib/obsidian/Plugin/PluginSettings.d.ts +8 -8
- package/dist/lib/obsidian/Plugin/ValueComponent.cjs +1 -1
- package/dist/lib/obsidian/Plugin/ValueComponent.d.ts +51 -51
- package/dist/lib/obsidian/Queue.cjs +76 -0
- package/dist/lib/obsidian/Queue.d.ts +28 -0
- package/dist/lib/obsidian/Reference.cjs +12 -12
- package/dist/lib/obsidian/Reference.d.ts +7 -7
- package/dist/lib/obsidian/RenameDeleteHandler.cjs +130 -130
- package/dist/lib/obsidian/Vault.cjs +116 -116
- package/dist/lib/obsidian/Vault.d.ts +70 -70
- package/dist/lib/obsidian/index.cjs +4 -4
- package/dist/lib/obsidian/index.d.ts +1 -1
- package/dist/lib/scripts/CliUtils.cjs +30 -30
- package/dist/lib/scripts/CliUtils.d.ts +11 -11
- package/dist/lib/scripts/ESLint/@types/@guardian__eslint-plugin-tsdoc-required.d.ts +2 -0
- package/dist/lib/scripts/ESLint/@types/eslint-plugin-modules-newlines.d.ts +2 -0
- package/dist/lib/scripts/ESLint/@types/eslint-plugin-verify-tsdoc.d.ts +2 -0
- package/dist/lib/scripts/ESLint/eslint.config.cjs +2 -1
- package/dist/lib/scripts/Exec.cjs +1 -1
- package/dist/lib/scripts/Exec.d.ts +21 -21
- package/dist/lib/scripts/Fs.cjs +11 -11
- package/dist/lib/scripts/Fs.d.ts +13 -13
- package/dist/lib/scripts/JSON.cjs +7 -7
- package/dist/lib/scripts/JSON.d.ts +16 -16
- package/dist/lib/scripts/Npm.cjs +13 -13
- package/dist/lib/scripts/Npm.d.ts +43 -43
- package/dist/lib/scripts/Root.cjs +4 -4
- package/dist/lib/scripts/Root.d.ts +8 -8
- package/dist/lib/scripts/build.cjs +4 -4
- package/dist/lib/scripts/build.d.ts +8 -8
- package/dist/lib/scripts/cli.cjs +1 -1
- package/dist/lib/scripts/esbuild/Dependency.cjs +21 -21
- package/dist/lib/scripts/esbuild/Dependency.d.ts +6 -6
- package/dist/lib/scripts/esbuild/fixSourceMapsPlugin.cjs +5 -5
- package/dist/lib/scripts/version.cjs +134 -134
- package/dist/lib/scripts/version.d.ts +70 -70
- package/package.json +11 -11
- package/dist/lib/obsidian/ChainedPromise.cjs +0 -59
- package/dist/lib/obsidian/ChainedPromise.d.ts +0 -26
package/CHANGELOG.md
CHANGED
package/dist/lib/Async.cjs
CHANGED
@@ -41,6 +41,37 @@ __export(Async_exports, {
|
|
41
41
|
});
|
42
42
|
module.exports = __toCommonJS(Async_exports);
|
43
43
|
var import_Error = require('./Error.cjs');
|
44
|
+
async function addErrorHandler(asyncFn) {
|
45
|
+
try {
|
46
|
+
await asyncFn();
|
47
|
+
} catch (asyncError) {
|
48
|
+
(0, import_Error.emitAsyncErrorEvent)(asyncError);
|
49
|
+
}
|
50
|
+
}
|
51
|
+
async function asyncFilter(arr, predicate) {
|
52
|
+
const predicateResults = await asyncMap(arr, predicate);
|
53
|
+
return arr.filter((_, index) => predicateResults[index]);
|
54
|
+
}
|
55
|
+
async function asyncFlatMap(arr, callback) {
|
56
|
+
return (await asyncMap(arr, callback)).flat();
|
57
|
+
}
|
58
|
+
async function asyncMap(arr, callback) {
|
59
|
+
return await Promise.all(arr.map(callback));
|
60
|
+
}
|
61
|
+
function convertAsyncToSync(asyncFunc) {
|
62
|
+
return (...args) => {
|
63
|
+
invokeAsyncSafely(() => asyncFunc(...args));
|
64
|
+
};
|
65
|
+
}
|
66
|
+
function convertSyncToAsync(syncFn) {
|
67
|
+
return (...args) => Promise.resolve().then(() => syncFn(...args));
|
68
|
+
}
|
69
|
+
function invokeAsyncSafely(asyncFn) {
|
70
|
+
void addErrorHandler(asyncFn);
|
71
|
+
}
|
72
|
+
function marksAsTerminateRetry(error) {
|
73
|
+
return Object.assign(error, { __terminateRetry: true });
|
74
|
+
}
|
44
75
|
async function retryWithTimeout(fn, retryOptions = {}) {
|
45
76
|
const stackTrace = (0, import_Error.getStackTrace)();
|
46
77
|
const DEFAULT_RETRY_OPTIONS = {
|
@@ -77,44 +108,31 @@ async function retryWithTimeout(fn, retryOptions = {}) {
|
|
77
108
|
}
|
78
109
|
});
|
79
110
|
}
|
111
|
+
async function runWithTimeout(timeoutInMilliseconds, fn) {
|
112
|
+
let timedOut = false;
|
113
|
+
let result = null;
|
114
|
+
await Promise.race([run(), timeout2()]);
|
115
|
+
if (timedOut) {
|
116
|
+
console.error(`Timed out in ${timeoutInMilliseconds.toString()} milliseconds`, { fn });
|
117
|
+
throw new Error("Timed out");
|
118
|
+
}
|
119
|
+
return result;
|
120
|
+
async function run() {
|
121
|
+
result = await fn();
|
122
|
+
timedOut = false;
|
123
|
+
}
|
124
|
+
async function timeout2() {
|
125
|
+
await sleep(timeoutInMilliseconds);
|
126
|
+
timedOut = true;
|
127
|
+
}
|
128
|
+
}
|
80
129
|
async function sleep(milliseconds) {
|
81
130
|
await new Promise((resolve) => setTimeout(resolve, milliseconds));
|
82
131
|
}
|
83
|
-
async function runWithTimeout(timeoutInMilliseconds, fn) {
|
84
|
-
return await Promise.race([fn(), timeout(timeoutInMilliseconds)]);
|
85
|
-
}
|
86
132
|
async function timeout(timeoutInMilliseconds) {
|
87
133
|
await sleep(timeoutInMilliseconds);
|
88
134
|
throw new Error(`Timed out in ${timeoutInMilliseconds.toString()} milliseconds`);
|
89
135
|
}
|
90
|
-
function invokeAsyncSafely(asyncFn) {
|
91
|
-
void addErrorHandler(asyncFn);
|
92
|
-
}
|
93
|
-
async function addErrorHandler(asyncFn) {
|
94
|
-
try {
|
95
|
-
await asyncFn();
|
96
|
-
} catch (asyncError) {
|
97
|
-
(0, import_Error.emitAsyncErrorEvent)(asyncError);
|
98
|
-
}
|
99
|
-
}
|
100
|
-
function convertAsyncToSync(asyncFunc) {
|
101
|
-
return (...args) => {
|
102
|
-
invokeAsyncSafely(() => asyncFunc(...args));
|
103
|
-
};
|
104
|
-
}
|
105
|
-
function convertSyncToAsync(syncFn) {
|
106
|
-
return (...args) => Promise.resolve().then(() => syncFn(...args));
|
107
|
-
}
|
108
|
-
async function asyncMap(arr, callback) {
|
109
|
-
return await Promise.all(arr.map(callback));
|
110
|
-
}
|
111
|
-
async function asyncFilter(arr, predicate) {
|
112
|
-
const predicateResults = await asyncMap(arr, predicate);
|
113
|
-
return arr.filter((_, index) => predicateResults[index]);
|
114
|
-
}
|
115
|
-
async function asyncFlatMap(arr, callback) {
|
116
|
-
return (await asyncMap(arr, callback)).flat();
|
117
|
-
}
|
118
136
|
async function toArray(iter) {
|
119
137
|
const arr = [];
|
120
138
|
for await (const item of iter) {
|
@@ -122,9 +140,6 @@ async function toArray(iter) {
|
|
122
140
|
}
|
123
141
|
return arr;
|
124
142
|
}
|
125
|
-
function marksAsTerminateRetry(error) {
|
126
|
-
return Object.assign(error, { __terminateRetry: true });
|
127
|
-
}
|
128
143
|
// Annotate the CommonJS export names for ESM import in node:
|
129
144
|
0 && (module.exports = {
|
130
145
|
addErrorHandler,
|
@@ -141,4 +156,4 @@ function marksAsTerminateRetry(error) {
|
|
141
156
|
timeout,
|
142
157
|
toArray
|
143
158
|
});
|
144
|
-
//# 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 {\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 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 * 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 * @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: Partial<RetryOptions> = {}): Promise<void> {\n  const stackTrace = getStackTrace();\n  const DEFAULT_RETRY_OPTIONS: RetryOptions = {\n    retryDelayInMilliseconds: 100,\n    shouldRetryOnError: true,\n    timeoutInMilliseconds: 5000\n  };\n  const overriddenOptions: RetryOptions = { ...DEFAULT_RETRY_OPTIONS, ...retryOptions };\n  await runWithTimeout(overriddenOptions.timeoutInMilliseconds, async () => {\n    let attempt = 0;\n    for (; ;) {\n      attempt++;\n      let isSuccess: boolean;\n      try {\n        isSuccess = await fn();\n      } catch (error) {\n        if (!overriddenOptions.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          console.debug(`Retry completed successfully after ${attempt.toString()} attempts`);\n        }\n        return;\n      }\n\n      console.debug(`Retry attempt ${attempt.toString()} completed unsuccessfully. Trying again in ${overriddenOptions.retryDelayInMilliseconds.toString()} milliseconds`, {\n        fn,\n        stackTrace\n      });\n      await sleep(overriddenOptions.retryDelayInMilliseconds);\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 * 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 * @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  return await Promise.race([fn(), timeout(timeoutInMilliseconds)]);\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 * 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 * 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 * 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 * 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 * 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]);\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 * 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\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 * 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);\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAKA,mBAIO;AAmCP,eAAsB,iBAAiB,IAAiC,eAAsC,CAAC,GAAkB;AAC/H,QAAM,iBAAa,4BAAc;AACjC,QAAM,wBAAsC;AAAA,IAC1C,0BAA0B;AAAA,IAC1B,oBAAoB;AAAA,IACpB,uBAAuB;AAAA,EACzB;AACA,QAAM,oBAAkC,EAAE,GAAG,uBAAuB,GAAG,aAAa;AACpF,QAAM,eAAe,kBAAkB,uBAAuB,YAAY;AACxE,QAAI,UAAU;AACd,eAAU;AACR;AACA,UAAI;AACJ,UAAI;AACF,oBAAY,MAAM,GAAG;AAAA,MACvB,SAAS,OAAO;AACd,YAAI,CAAC,kBAAkB,sBAAuB,MAAkC,kBAAkB;AAChG,gBAAM;AAAA,QACR;AACA,qCAAW,KAAK;AAChB,oBAAY;AAAA,MACd;AACA,UAAI,WAAW;AACb,YAAI,UAAU,GAAG;AACf,kBAAQ,MAAM,sCAAsC,QAAQ,SAAS,CAAC,WAAW;AAAA,QACnF;AACA;AAAA,MACF;AAEA,cAAQ,MAAM,iBAAiB,QAAQ,SAAS,CAAC,8CAA8C,kBAAkB,yBAAyB,SAAS,CAAC,iBAAiB;AAAA,QACnK;AAAA,QACA;AAAA,MACF,CAAC;AACD,YAAM,MAAM,kBAAkB,wBAAwB;AAAA,IACxD;AAAA,EACF,CAAC;AACH;AAQA,eAAsB,MAAM,cAAqC;AAC/D,QAAM,IAAI,QAAQ,CAAC,YAAY,WAAW,SAAS,YAAY,CAAC;AAClE;AAUA,eAAsB,eAAkB,uBAA+B,IAAuC;AAC5G,SAAO,MAAM,QAAQ,KAAK,CAAC,GAAG,GAAG,QAAQ,qBAAqB,CAAC,CAAC;AAClE;AAQA,eAAsB,QAAQ,uBAA+C;AAC3E,QAAM,MAAM,qBAAqB;AACjC,QAAM,IAAI,MAAM,gBAAgB,sBAAsB,SAAS,CAAC,eAAe;AACjF;AAOO,SAAS,kBAAkB,SAAuC;AACvE,OAAK,gBAAgB,OAAO;AAC9B;AAQA,eAAsB,gBAAgB,SAAgD;AACpF,MAAI;AACF,UAAM,QAAQ;AAAA,EAChB,SAAS,YAAY;AACnB,0CAAoB,UAAU;AAAA,EAChC;AACF;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;AAWA,eAAsB,SAAe,KAAU,UAAkF;AAC/H,SAAO,MAAM,QAAQ,IAAI,IAAI,IAAI,QAAQ,CAAC;AAC5C;AAUA,eAAsB,YAAe,KAAU,WAAyF;AACtI,QAAM,mBAAmB,MAAM,SAAS,KAAK,SAAS;AACtD,SAAO,IAAI,OAAO,CAAC,GAAG,UAAU,iBAAiB,KAAK,CAAC;AACzD;AAWA,eAAsB,aAAmB,KAAU,UAAoF;AACrI,UAAQ,MAAM,SAAS,KAAK,QAAQ,GAAG,KAAK;AAC9C;AASA,eAAsB,QAAW,MAA8C;AAC7E,QAAM,MAAW,CAAC;AAClB,mBAAiB,QAAQ,MAAM;AAC7B,QAAI,KAAK,IAAI;AAAA,EACf;AACA,SAAO;AACT;AAkBO,SAAS,sBAA4C,OAAwC;AAClG,SAAO,OAAO,OAAO,OAAO,EAAE,kBAAkB,KAAK,CAAmB;AAC1E;",
  "names": []
}

|
159
|
+
//# 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 {\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 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]);\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);\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 * @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: Partial<RetryOptions> = {}): Promise<void> {\n  const stackTrace = getStackTrace();\n  const DEFAULT_RETRY_OPTIONS: RetryOptions = {\n    retryDelayInMilliseconds: 100,\n    shouldRetryOnError: true,\n    timeoutInMilliseconds: 5000\n  };\n  const overriddenOptions: RetryOptions = { ...DEFAULT_RETRY_OPTIONS, ...retryOptions };\n  await runWithTimeout(overriddenOptions.timeoutInMilliseconds, async () => {\n    let attempt = 0;\n    for (; ;) {\n      attempt++;\n      let isSuccess: boolean;\n      try {\n        isSuccess = await fn();\n      } catch (error) {\n        if (!overriddenOptions.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          console.debug(`Retry completed successfully after ${attempt.toString()} attempts`);\n        }\n        return;\n      }\n\n      console.debug(`Retry attempt ${attempt.toString()} completed unsuccessfully. Trying again in ${overriddenOptions.retryDelayInMilliseconds.toString()} milliseconds`, {\n        fn,\n        stackTrace\n      });\n      await sleep(overriddenOptions.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 * @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 timedOut = false;\n  let result: R = null as R;\n\n  await Promise.race([run(), timeout()]);\n  // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n  if (timedOut) {\n    console.error(`Timed out in ${timeoutInMilliseconds.toString()} milliseconds`, { fn });\n    throw new Error('Timed out');\n  }\n  return result;\n\n  async function run(): Promise<void> {\n    result = await fn();\n    timedOut = false;\n  }\n\n  async function timeout(): Promise<void> {\n    await sleep(timeoutInMilliseconds);\n    timedOut = true;\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,mBAIO;AA4CP,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,CAAC;AACzD;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,CAAmB;AAC1E;AASA,eAAsB,iBAAiB,IAAiC,eAAsC,CAAC,GAAkB;AAC/H,QAAM,iBAAa,4BAAc;AACjC,QAAM,wBAAsC;AAAA,IAC1C,0BAA0B;AAAA,IAC1B,oBAAoB;AAAA,IACpB,uBAAuB;AAAA,EACzB;AACA,QAAM,oBAAkC,EAAE,GAAG,uBAAuB,GAAG,aAAa;AACpF,QAAM,eAAe,kBAAkB,uBAAuB,YAAY;AACxE,QAAI,UAAU;AACd,eAAU;AACR;AACA,UAAI;AACJ,UAAI;AACF,oBAAY,MAAM,GAAG;AAAA,MACvB,SAAS,OAAO;AACd,YAAI,CAAC,kBAAkB,sBAAuB,MAAkC,kBAAkB;AAChG,gBAAM;AAAA,QACR;AACA,qCAAW,KAAK;AAChB,oBAAY;AAAA,MACd;AACA,UAAI,WAAW;AACb,YAAI,UAAU,GAAG;AACf,kBAAQ,MAAM,sCAAsC,QAAQ,SAAS,CAAC,WAAW;AAAA,QACnF;AACA;AAAA,MACF;AAEA,cAAQ,MAAM,iBAAiB,QAAQ,SAAS,CAAC,8CAA8C,kBAAkB,yBAAyB,SAAS,CAAC,iBAAiB;AAAA,QACnK;AAAA,QACA;AAAA,MACF,CAAC;AACD,YAAM,MAAM,kBAAkB,wBAAwB;AAAA,IACxD;AAAA,EACF,CAAC;AACH;AAUA,eAAsB,eAAkB,uBAA+B,IAAuC;AAC5G,MAAI,WAAW;AACf,MAAI,SAAY;AAEhB,QAAM,QAAQ,KAAK,CAAC,IAAI,GAAGA,SAAQ,CAAC,CAAC;AAErC,MAAI,UAAU;AACZ,YAAQ,MAAM,gBAAgB,sBAAsB,SAAS,CAAC,iBAAiB,EAAE,GAAG,CAAC;AACrF,UAAM,IAAI,MAAM,WAAW;AAAA,EAC7B;AACA,SAAO;AAEP,iBAAe,MAAqB;AAClC,aAAS,MAAM,GAAG;AAClB,eAAW;AAAA,EACb;AAEA,iBAAeA,WAAyB;AACtC,UAAM,MAAM,qBAAqB;AACjC,eAAW;AAAA,EACb;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/Async.d.ts
CHANGED
@@ -25,49 +25,50 @@ export interface RetryOptions {
|
|
25
25
|
timeoutInMilliseconds: number;
|
26
26
|
}
|
27
27
|
/**
|
28
|
-
*
|
29
|
-
*
|
30
|
-
* @param fn - The function to retry.
|
31
|
-
* @param retryOptions - Optional parameters to configure the retry behavior.
|
32
|
-
* @returns A Promise that resolves when the function returns true or rejects when the timeout is reached.
|
33
|
-
*/
|
34
|
-
export declare function retryWithTimeout(fn: () => MaybePromise<boolean>, retryOptions?: Partial<RetryOptions>): Promise<void>;
|
35
|
-
/**
|
36
|
-
* Delays execution for a specified number of milliseconds.
|
37
|
-
*
|
38
|
-
* @param milliseconds - The time to wait in milliseconds.
|
39
|
-
* @returns A Promise that resolves after the specified delay.
|
28
|
+
* A marker interface to indicate that an error should terminate retry logic.
|
40
29
|
*/
|
41
|
-
export
|
30
|
+
export interface TerminateRetry {
|
31
|
+
/**
|
32
|
+
* A marker property to indicate that an error should terminate retry logic.
|
33
|
+
*/
|
34
|
+
__terminateRetry: true;
|
35
|
+
}
|
42
36
|
/**
|
43
|
-
*
|
37
|
+
* Adds an error handler to a Promise that catches any errors and emits an async error event.
|
44
38
|
*
|
45
|
-
* @
|
46
|
-
* @
|
47
|
-
* @param fn - The function to execute.
|
48
|
-
* @returns A Promise that resolves with the result of the asynchronous function or rejects if it times out.
|
39
|
+
* @param asyncFn - The asynchronous function to add an error handler to.
|
40
|
+
* @returns A Promise that resolves when the asynchronous function completes or emits async error event.
|
49
41
|
*/
|
50
|
-
export declare function
|
42
|
+
export declare function addErrorHandler(asyncFn: () => Promise<unknown>): Promise<void>;
|
51
43
|
/**
|
52
|
-
*
|
44
|
+
* Filters an array asynchronously, keeping only the elements that satisfy the provided predicate function.
|
53
45
|
*
|
54
|
-
* @
|
55
|
-
* @
|
46
|
+
* @typeParam T - The type of elements in the input array.
|
47
|
+
* @param arr - The array to filter.
|
48
|
+
* @param predicate - The predicate function to test each element.
|
49
|
+
* @returns A Promise that resolves with an array of elements that satisfy the predicate function.
|
56
50
|
*/
|
57
|
-
export declare function
|
51
|
+
export declare function asyncFilter<T>(arr: T[], predicate: (value: T, index: number, array: T[]) => MaybePromise<boolean>): Promise<T[]>;
|
58
52
|
/**
|
59
|
-
*
|
53
|
+
* Maps over an array asynchronously, applying the provided callback function to each element, and then flattens the results into a single array.
|
60
54
|
*
|
61
|
-
* @
|
55
|
+
* @typeParam T - The type of elements in the input array.
|
56
|
+
* @typeParam U - The type of elements in the output array.
|
57
|
+
* @param arr - The array to map over and flatten.
|
58
|
+
* @param callback - The callback function to apply to each element.
|
59
|
+
* @returns A Promise that resolves with a flattened array of the results of the callback function.
|
62
60
|
*/
|
63
|
-
export declare function
|
61
|
+
export declare function asyncFlatMap<T, U>(arr: T[], callback: (value: T, index: number, array: T[]) => MaybePromise<U[]>): Promise<U[]>;
|
64
62
|
/**
|
65
|
-
*
|
63
|
+
* Maps over an array asynchronously, applying the provided callback function to each element.
|
66
64
|
*
|
67
|
-
* @
|
68
|
-
* @
|
65
|
+
* @typeParam T - The type of elements in the input array.
|
66
|
+
* @typeParam U - The type of elements in the output array.
|
67
|
+
* @param arr - The array to map over.
|
68
|
+
* @param callback - The callback function to apply to each element.
|
69
|
+
* @returns A Promise that resolves with an array of the results of the callback function.
|
69
70
|
*/
|
70
|
-
export declare function
|
71
|
+
export declare function asyncMap<T, U>(arr: T[], callback: (value: T, index: number, array: T[]) => MaybePromise<U>): Promise<U[]>;
|
71
72
|
/**
|
72
73
|
* Converts an asynchronous function to a synchronous one by automatically handling the Promise rejection.
|
73
74
|
*
|
@@ -86,55 +87,54 @@ export declare function convertAsyncToSync<Args extends unknown[]>(asyncFunc: (.
|
|
86
87
|
*/
|
87
88
|
export declare function convertSyncToAsync<Args extends unknown[], Result>(syncFn: (...args: Args) => Result): (...args: Args) => Promise<Result>;
|
88
89
|
/**
|
89
|
-
*
|
90
|
+
* Invokes a Promise and safely handles any errors by catching them and emitting an async error event.
|
90
91
|
*
|
91
|
-
* @
|
92
|
-
* @typeParam U - The type of elements in the output array.
|
93
|
-
* @param arr - The array to map over.
|
94
|
-
* @param callback - The callback function to apply to each element.
|
95
|
-
* @returns A Promise that resolves with an array of the results of the callback function.
|
92
|
+
* @param asyncFn - The asynchronous function to invoke safely.
|
96
93
|
*/
|
97
|
-
export declare function
|
94
|
+
export declare function invokeAsyncSafely(asyncFn: () => Promise<unknown>): void;
|
98
95
|
/**
|
99
|
-
*
|
96
|
+
* Marks an error to terminate retry logic.
|
100
97
|
*
|
101
|
-
* @
|
102
|
-
* @
|
103
|
-
* @param predicate - The predicate function to test each element.
|
104
|
-
* @returns A Promise that resolves with an array of elements that satisfy the predicate function.
|
98
|
+
* @param error - The error to mark to terminate retry logic.
|
99
|
+
* @returns An error that should terminate retry logic.
|
105
100
|
*/
|
106
|
-
export declare function
|
101
|
+
export declare function marksAsTerminateRetry<TError extends Error>(error: TError): TerminateRetry & TError;
|
107
102
|
/**
|
108
|
-
*
|
103
|
+
* Retries the provided function until it returns true or the timeout is reached.
|
109
104
|
*
|
110
|
-
* @
|
111
|
-
* @
|
112
|
-
* @
|
113
|
-
* @param callback - The callback function to apply to each element.
|
114
|
-
* @returns A Promise that resolves with a flattened array of the results of the callback function.
|
105
|
+
* @param fn - The function to retry.
|
106
|
+
* @param retryOptions - Optional parameters to configure the retry behavior.
|
107
|
+
* @returns A Promise that resolves when the function returns true or rejects when the timeout is reached.
|
115
108
|
*/
|
116
|
-
export declare function
|
109
|
+
export declare function retryWithTimeout(fn: () => MaybePromise<boolean>, retryOptions?: Partial<RetryOptions>): Promise<void>;
|
117
110
|
/**
|
118
|
-
*
|
111
|
+
* Executes a function with a timeout. If the function does not complete within the specified time, it is considered to have timed out.
|
119
112
|
*
|
120
|
-
* @typeParam
|
121
|
-
* @param
|
122
|
-
* @
|
113
|
+
* @typeParam R - The type of the result from the asynchronous function.
|
114
|
+
* @param timeoutInMilliseconds - The maximum time to wait in milliseconds.
|
115
|
+
* @param fn - The function to execute.
|
116
|
+
* @returns A Promise that resolves with the result of the asynchronous function or rejects if it times out.
|
123
117
|
*/
|
124
|
-
export declare function
|
118
|
+
export declare function runWithTimeout<R>(timeoutInMilliseconds: number, fn: () => MaybePromise<R>): Promise<R>;
|
125
119
|
/**
|
126
|
-
*
|
120
|
+
* Delays execution for a specified number of milliseconds.
|
121
|
+
*
|
122
|
+
* @param milliseconds - The time to wait in milliseconds.
|
123
|
+
* @returns A Promise that resolves after the specified delay.
|
127
124
|
*/
|
128
|
-
export
|
129
|
-
/**
|
130
|
-
* A marker property to indicate that an error should terminate retry logic.
|
131
|
-
*/
|
132
|
-
__terminateRetry: true;
|
133
|
-
}
|
125
|
+
export declare function sleep(milliseconds: number): Promise<void>;
|
134
126
|
/**
|
135
|
-
*
|
127
|
+
* Returns a Promise that rejects after the specified timeout period.
|
136
128
|
*
|
137
|
-
* @param
|
138
|
-
* @returns
|
129
|
+
* @param timeoutInMilliseconds - The timeout period in milliseconds.
|
130
|
+
* @returns A Promise that always rejects with a timeout error.
|
139
131
|
*/
|
140
|
-
export declare function
|
132
|
+
export declare function timeout(timeoutInMilliseconds: number): Promise<never>;
|
133
|
+
/**
|
134
|
+
* Converts an AsyncIterableIterator to an array by consuming all its elements.
|
135
|
+
*
|
136
|
+
* @typeParam T - The type of elements produced by the AsyncIterableIterator.
|
137
|
+
* @param iter - The AsyncIterableIterator to convert.
|
138
|
+
* @returns A Promise that resolves with an array of all the elements in the AsyncIterableIterator.
|
139
|
+
*/
|
140
|
+
export declare function toArray<T>(iter: AsyncIterableIterator<T>): Promise<T[]>;
|
package/dist/lib/Blob.cjs
CHANGED
@@ -32,6 +32,16 @@ __export(Blob_exports, {
|
|
32
32
|
});
|
33
33
|
module.exports = __toCommonJS(Blob_exports);
|
34
34
|
var import_Error = require('./Error.cjs');
|
35
|
+
function base64ToArrayBuffer(code) {
|
36
|
+
const parts = code.split(";base64,");
|
37
|
+
const raw = window.atob(parts[1] ?? (0, import_Error.throwExpression)(new Error("Invalid base64 string")));
|
38
|
+
const rawLength = raw.length;
|
39
|
+
const uInt8Array = new Uint8Array(rawLength);
|
40
|
+
for (let i = 0; i < rawLength; ++i) {
|
41
|
+
uInt8Array[i] = raw.charCodeAt(i);
|
42
|
+
}
|
43
|
+
return uInt8Array.buffer;
|
44
|
+
}
|
35
45
|
async function blobToArrayBuffer(blob) {
|
36
46
|
return await new Promise((resolve) => {
|
37
47
|
const reader = new FileReader();
|
@@ -72,16 +82,6 @@ async function blobToJpegArrayBuffer(blob, jpegQuality) {
|
|
72
82
|
reader.readAsDataURL(blob);
|
73
83
|
});
|
74
84
|
}
|
75
|
-
function base64ToArrayBuffer(code) {
|
76
|
-
const parts = code.split(";base64,");
|
77
|
-
const raw = window.atob(parts[1] ?? (0, import_Error.throwExpression)(new Error("Invalid base64 string")));
|
78
|
-
const rawLength = raw.length;
|
79
|
-
const uInt8Array = new Uint8Array(rawLength);
|
80
|
-
for (let i = 0; i < rawLength; ++i) {
|
81
|
-
uInt8Array[i] = raw.charCodeAt(i);
|
82
|
-
}
|
83
|
-
return uInt8Array.buffer;
|
84
|
-
}
|
85
85
|
function isImageFile(file) {
|
86
86
|
return file.type.startsWith("image/");
|
87
87
|
}
|
@@ -92,4 +92,4 @@ function isImageFile(file) {
|
|
92
92
|
blobToJpegArrayBuffer,
|
93
93
|
isImageFile
|
94
94
|
});
|
95
|
-
//# sourceMappingURL=data:application/json;base64,
|
95
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL0Jsb2IudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQHBhY2thZ2VEb2N1bWVudGF0aW9uIEFzeW5jXG4gKiBDb250YWlucyB1dGlsaXR5IGZ1bmN0aW9ucyBmb3IgQmxvYiBvYmplY3RzLlxuICovXG5cbmltcG9ydCB7IHRocm93RXhwcmVzc2lvbiB9IGZyb20gJy4vRXJyb3IudHMnO1xuXG4vKipcbiAqIENvbnZlcnRzIGEgYmFzZTY0IGVuY29kZWQgc3RyaW5nIHRvIGFuIEFycmF5QnVmZmVyLlxuICpcbiAqIEBwYXJhbSBjb2RlIC0gVGhlIGJhc2U2NCBlbmNvZGVkIHN0cmluZy5cbiAqIEByZXR1cm5zIFRoZSBkZWNvZGVkIEFycmF5QnVmZmVyLlxuICovXG5leHBvcnQgZnVuY3Rpb24gYmFzZTY0VG9BcnJheUJ1ZmZlcihjb2RlOiBzdHJpbmcpOiBBcnJheUJ1ZmZlciB7XG4gIGNvbnN0IHBhcnRzID0gY29kZS5zcGxpdCgnO2Jhc2U2NCwnKTtcbiAgY29uc3QgcmF3ID0gd2luZG93LmF0b2IocGFydHNbMV0gPz8gdGhyb3dFeHByZXNzaW9uKG5ldyBFcnJvcignSW52YWxpZCBiYXNlNjQgc3RyaW5nJykpKTtcbiAgY29uc3QgcmF3TGVuZ3RoID0gcmF3Lmxlbmd0aDtcblxuICBjb25zdCB1SW50OEFycmF5ID0gbmV3IFVpbnQ4QXJyYXkocmF3TGVuZ3RoKTtcblxuICBmb3IgKGxldCBpID0gMDsgaSA8IHJhd0xlbmd0aDsgKytpKSB7XG4gICAgdUludDhBcnJheVtpXSA9IHJhdy5jaGFyQ29kZUF0KGkpO1xuICB9XG4gIHJldHVybiB1SW50OEFycmF5LmJ1ZmZlcjtcbn1cblxuLyoqXG4gKiBDb252ZXJ0cyBhIEJsb2Igb2JqZWN0IHRvIGFuIEFycmF5QnVmZmVyLlxuICpcbiAqIEBwYXJhbSBibG9iIC0gVGhlIEJsb2Igb2JqZWN0IHRvIGNvbnZlcnQuXG4gKiBAcmV0dXJucyBBIHByb21pc2UgdGhhdCByZXNvbHZlcyB0byBhbiBBcnJheUJ1ZmZlci5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJsb2JUb0FycmF5QnVmZmVyKGJsb2I6IEJsb2IpOiBQcm9taXNlPEFycmF5QnVmZmVyPiB7XG4gIHJldHVybiBhd2FpdCBuZXcgUHJvbWlzZSgocmVzb2x2ZSkgPT4ge1xuICAgIGNvbnN0IHJlYWRlciA9IG5ldyBGaWxlUmVhZGVyKCk7XG4gICAgcmVhZGVyLm9ubG9hZGVuZCA9ICgpOiB2b2lkID0+IHtcbiAgICAgIHJlc29sdmUocmVhZGVyLnJlc3VsdCBhcyBBcnJheUJ1ZmZlcik7XG4gICAgfTtcbiAgICByZWFkZXIucmVhZEFzQXJyYXlCdWZmZXIoYmxvYik7XG4gIH0pO1xufVxuXG4vKipcbiAqIENvbnZlcnRzIGEgQmxvYiBvYmplY3QgdG8gYSBKUEVHIEFycmF5QnVmZmVyIHdpdGggdGhlIHNwZWNpZmllZCBxdWFsaXR5LlxuICpcbiAqIEBwYXJhbSBibG9iIC0gVGhlIEJsb2Igb2JqZWN0IHRvIGNvbnZlcnQuXG4gKiBAcGFyYW0ganBlZ1F1YWxpdHkgLSBUaGUgcXVhbGl0eSBvZiB0aGUgSlBFRyBpbWFnZSAoMCB0byAxKS5cbiAqIEByZXR1cm5zIEEgcHJvbWlzZSB0aGF0IHJlc29sdmVzIHRvIGFuIEFycmF5QnVmZmVyLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gYmxvYlRvSnBlZ0FycmF5QnVmZmVyKGJsb2I6IEJsb2IsIGpwZWdRdWFsaXR5OiBudW1iZXIpOiBQcm9taXNlPEFycmF5QnVmZmVyPiB7XG4gIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSkgPT4ge1xuICAgIGNvbnN0IHJlYWRlciA9IG5ldyBGaWxlUmVhZGVyKCk7XG4gICAgcmVhZGVyLm9ubG9hZGVuZCA9ICgpOiB2b2lkID0+IHtcbiAgICAgIGNvbnN0IGltYWdlID0gbmV3IEltYWdlKCk7XG4gICAgICBpbWFnZS5vbmxvYWQgPSAoKTogdm9pZCA9PiB7XG4gICAgICAgIGNvbnN0IGNhbnZhcyA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ2NhbnZhcycpO1xuICAgICAgICBjb25zdCBjb250ZXh0ID0gY2FudmFzLmdldENvbnRleHQoJzJkJyk7XG4gICAgICAgIGlmICghY29udGV4dCkge1xuICAgICAgICAgIHRocm93IG5ldyBFcnJvcignQ291bGQgbm90IGdldCAyRCBjb250ZXh0LicpO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IGltYWdlV2lkdGggPSBpbWFnZS53aWR0aDtcbiAgICAgICAgY29uc3QgaW1hZ2VIZWlnaHQgPSBpbWFnZS5oZWlnaHQ7XG4gICAgICAgIGxldCBkYXRhID0gJyc7XG5cbiAgICAgICAgY2FudmFzLndpZHRoID0gaW1hZ2VXaWR0aDtcbiAgICAgICAgY2FudmFzLmhlaWdodCA9IGltYWdlSGVpZ2h0O1xuXG4gICAgICAgIGNvbnRleHQuZmlsbFN0eWxlID0gJyNmZmYnO1xuICAgICAgICBjb250ZXh0LmZpbGxSZWN0KDAsIDAsIGltYWdlV2lkdGgsIGltYWdlSGVpZ2h0KTtcbiAgICAgICAgY29udGV4dC5zYXZlKCk7XG5cbiAgICAgICAgY29udGV4dC50cmFuc2xhdGUoaW1hZ2VXaWR0aCAvIDIsIGltYWdlSGVpZ2h0IC8gMik7XG4gICAgICAgIGNvbnRleHQuZHJhd0ltYWdlKGltYWdlLCAwLCAwLCBpbWFnZVdpZHRoLCBpbWFnZUhlaWdodCwgLWltYWdlV2lkdGggLyAyLCAtaW1hZ2VIZWlnaHQgLyAyLCBpbWFnZVdpZHRoLCBpbWFnZUhlaWdodCk7XG4gICAgICAgIGNvbnRleHQucmVzdG9yZSgpO1xuXG4gICAgICAgIGRhdGEgPSBjYW52YXMudG9EYXRhVVJMKCdpbWFnZS9qcGVnJywganBlZ1F1YWxpdHkpO1xuXG4gICAgICAgIGNvbnN0IGFycmF5QnVmZmVyID0gYmFzZTY0VG9BcnJheUJ1ZmZlcihkYXRhKTtcbiAgICAgICAgcmVzb2x2ZShhcnJheUJ1ZmZlcik7XG4gICAgICB9O1xuXG4gICAgICBpbWFnZS5zcmMgPSByZWFkZXIucmVzdWx0IGFzIHN0cmluZztcbiAgICB9O1xuICAgIHJlYWRlci5yZWFkQXNEYXRhVVJMKGJsb2IpO1xuICB9KTtcbn1cblxuLyoqXG4gKiBDaGVja3MgaWYgYSBnaXZlbiBmaWxlIGlzIGFuIGltYWdlLlxuICpcbiAqIEBwYXJhbSBmaWxlIC0gVGhlIGZpbGUgdG8gY2hlY2suXG4gKiBAcmV0dXJucyBUcnVlIGlmIHRoZSBmaWxlIGlzIGFuIGltYWdlLCBmYWxzZSBvdGhlcndpc2UuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpc0ltYWdlRmlsZShmaWxlOiBGaWxlKTogYm9vbGVhbiB7XG4gIHJldHVybiBmaWxlLnR5cGUuc3RhcnRzV2l0aCgnaW1hZ2UvJyk7XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUtBLG1CQUFnQztBQVF6QixTQUFTLG9CQUFvQixNQUEyQjtBQUM3RCxRQUFNLFFBQVEsS0FBSyxNQUFNLFVBQVU7QUFDbkMsUUFBTSxNQUFNLE9BQU8sS0FBSyxNQUFNLENBQUMsU0FBSyw4QkFBZ0IsSUFBSSxNQUFNLHVCQUF1QixDQUFDLENBQUM7QUFDdkYsUUFBTSxZQUFZLElBQUk7QUFFdEIsUUFBTSxhQUFhLElBQUksV0FBVyxTQUFTO0FBRTNDLFdBQVMsSUFBSSxHQUFHLElBQUksV0FBVyxFQUFFLEdBQUc7QUFDbEMsZUFBVyxDQUFDLElBQUksSUFBSSxXQUFXLENBQUM7QUFBQSxFQUNsQztBQUNBLFNBQU8sV0FBVztBQUNwQjtBQVFBLGVBQXNCLGtCQUFrQixNQUFrQztBQUN4RSxTQUFPLE1BQU0sSUFBSSxRQUFRLENBQUMsWUFBWTtBQUNwQyxVQUFNLFNBQVMsSUFBSSxXQUFXO0FBQzlCLFdBQU8sWUFBWSxNQUFZO0FBQzdCLGNBQVEsT0FBTyxNQUFxQjtBQUFBLElBQ3RDO0FBQ0EsV0FBTyxrQkFBa0IsSUFBSTtBQUFBLEVBQy9CLENBQUM7QUFDSDtBQVNBLGVBQXNCLHNCQUFzQixNQUFZLGFBQTJDO0FBQ2pHLFNBQU8sSUFBSSxRQUFRLENBQUMsWUFBWTtBQUM5QixVQUFNLFNBQVMsSUFBSSxXQUFXO0FBQzlCLFdBQU8sWUFBWSxNQUFZO0FBQzdCLFlBQU0sUUFBUSxJQUFJLE1BQU07QUFDeEIsWUFBTSxTQUFTLE1BQVk7QUFDekIsY0FBTSxTQUFTLFNBQVMsY0FBYyxRQUFRO0FBQzlDLGNBQU0sVUFBVSxPQUFPLFdBQVcsSUFBSTtBQUN0QyxZQUFJLENBQUMsU0FBUztBQUNaLGdCQUFNLElBQUksTUFBTSwyQkFBMkI7QUFBQSxRQUM3QztBQUNBLGNBQU0sYUFBYSxNQUFNO0FBQ3pCLGNBQU0sY0FBYyxNQUFNO0FBQzFCLFlBQUksT0FBTztBQUVYLGVBQU8sUUFBUTtBQUNmLGVBQU8sU0FBUztBQUVoQixnQkFBUSxZQUFZO0FBQ3BCLGdCQUFRLFNBQVMsR0FBRyxHQUFHLFlBQVksV0FBVztBQUM5QyxnQkFBUSxLQUFLO0FBRWIsZ0JBQVEsVUFBVSxhQUFhLEdBQUcsY0FBYyxDQUFDO0FBQ2pELGdCQUFRLFVBQVUsT0FBTyxHQUFHLEdBQUcsWUFBWSxhQUFhLENBQUMsYUFBYSxHQUFHLENBQUMsY0FBYyxHQUFHLFlBQVksV0FBVztBQUNsSCxnQkFBUSxRQUFRO0FBRWhCLGVBQU8sT0FBTyxVQUFVLGNBQWMsV0FBVztBQUVqRCxjQUFNLGNBQWMsb0JBQW9CLElBQUk7QUFDNUMsZ0JBQVEsV0FBVztBQUFBLE1BQ3JCO0FBRUEsWUFBTSxNQUFNLE9BQU87QUFBQSxJQUNyQjtBQUNBLFdBQU8sY0FBYyxJQUFJO0FBQUEsRUFDM0IsQ0FBQztBQUNIO0FBUU8sU0FBUyxZQUFZLE1BQXFCO0FBQy9DLFNBQU8sS0FBSyxLQUFLLFdBQVcsUUFBUTtBQUN0QzsiLAogICJuYW1lcyI6IFtdCn0K
|
package/dist/lib/Blob.d.ts
CHANGED
@@ -2,6 +2,13 @@
|
|
2
2
|
* @packageDocumentation Async
|
3
3
|
* Contains utility functions for Blob objects.
|
4
4
|
*/
|
5
|
+
/**
|
6
|
+
* Converts a base64 encoded string to an ArrayBuffer.
|
7
|
+
*
|
8
|
+
* @param code - The base64 encoded string.
|
9
|
+
* @returns The decoded ArrayBuffer.
|
10
|
+
*/
|
11
|
+
export declare function base64ToArrayBuffer(code: string): ArrayBuffer;
|
5
12
|
/**
|
6
13
|
* Converts a Blob object to an ArrayBuffer.
|
7
14
|
*
|
@@ -17,13 +24,6 @@ export declare function blobToArrayBuffer(blob: Blob): Promise<ArrayBuffer>;
|
|
17
24
|
* @returns A promise that resolves to an ArrayBuffer.
|
18
25
|
*/
|
19
26
|
export declare function blobToJpegArrayBuffer(blob: Blob, jpegQuality: number): Promise<ArrayBuffer>;
|
20
|
-
/**
|
21
|
-
* Converts a base64 encoded string to an ArrayBuffer.
|
22
|
-
*
|
23
|
-
* @param code - The base64 encoded string.
|
24
|
-
* @returns The decoded ArrayBuffer.
|
25
|
-
*/
|
26
|
-
export declare function base64ToArrayBuffer(code: string): ArrayBuffer;
|
27
27
|
/**
|
28
28
|
* Checks if a given file is an image.
|
29
29
|
*
|
package/dist/lib/Error.cjs
CHANGED
@@ -37,15 +37,16 @@ var import_eventemitter3 = require('eventemitter3');
|
|
37
37
|
const ASYNC_ERROR_EVENT = "asyncError";
|
38
38
|
const asyncErrorEventEmitter = new import_eventemitter3.EventEmitter();
|
39
39
|
asyncErrorEventEmitter.on(ASYNC_ERROR_EVENT, handleAsyncError);
|
40
|
-
function handleAsyncError(asyncError) {
|
41
|
-
printError(new Error("An unhandled error occurred executing async operation", { cause: asyncError }));
|
42
|
-
}
|
43
40
|
function emitAsyncErrorEvent(asyncError) {
|
44
41
|
asyncErrorEventEmitter.emit(ASYNC_ERROR_EVENT, asyncError);
|
45
42
|
}
|
46
|
-
function
|
47
|
-
|
48
|
-
|
43
|
+
function errorToString(error) {
|
44
|
+
return parseErrorEntries(error).map((entry) => " ".repeat(entry.level) + entry.message).join("\n");
|
45
|
+
}
|
46
|
+
function getStackTrace() {
|
47
|
+
const stack = new Error().stack ?? "";
|
48
|
+
const lines = stack.split("\n");
|
49
|
+
return lines.slice(2).join("\n");
|
49
50
|
}
|
50
51
|
function printError(error) {
|
51
52
|
const entries = parseErrorEntries(error);
|
@@ -57,8 +58,15 @@ function printError(error) {
|
|
57
58
|
}
|
58
59
|
}
|
59
60
|
}
|
60
|
-
function
|
61
|
-
|
61
|
+
function registerAsyncErrorEventHandler(handler) {
|
62
|
+
asyncErrorEventEmitter.on(ASYNC_ERROR_EVENT, handler);
|
63
|
+
return () => asyncErrorEventEmitter.off(ASYNC_ERROR_EVENT, handler);
|
64
|
+
}
|
65
|
+
function throwExpression(error) {
|
66
|
+
throw error;
|
67
|
+
}
|
68
|
+
function handleAsyncError(asyncError) {
|
69
|
+
printError(new Error("An unhandled error occurred executing async operation", { cause: asyncError }));
|
62
70
|
}
|
63
71
|
function parseErrorEntries(error, level = 0, entries = []) {
|
64
72
|
if (error === void 0) {
|
@@ -89,14 +97,6 @@ ${restStack}` });
|
|
89
97
|
}
|
90
98
|
return entries;
|
91
99
|
}
|
92
|
-
function throwExpression(error) {
|
93
|
-
throw error;
|
94
|
-
}
|
95
|
-
function getStackTrace() {
|
96
|
-
const stack = new Error().stack ?? "";
|
97
|
-
const lines = stack.split("\n");
|
98
|
-
return lines.slice(2).join("\n");
|
99
|
-
}
|
100
100
|
// Annotate the CommonJS export names for ESM import in node:
|
101
101
|
0 && (module.exports = {
|
102
102
|
emitAsyncErrorEvent,
|
@@ -106,4 +106,4 @@ function getStackTrace() {
|
|
106
106
|
registerAsyncErrorEventHandler,
|
107
107
|
throwExpression
|
108
108
|
});
|
109
|
-
//# sourceMappingURL=data:application/json;base64,
|
109
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL0Vycm9yLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvbiBFcnJvclxuICogQ29udGFpbnMgdXRpbGl0eSBmdW5jdGlvbnMgZm9yIGVycm9yIGhhbmRsaW5nLlxuICovXG5cbmltcG9ydCB7IEV2ZW50RW1pdHRlciB9IGZyb20gJ2V2ZW50ZW1pdHRlcjMnO1xuXG5jb25zdCBBU1lOQ19FUlJPUl9FVkVOVCA9ICdhc3luY0Vycm9yJztcblxuY29uc3QgYXN5bmNFcnJvckV2ZW50RW1pdHRlciA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcbmFzeW5jRXJyb3JFdmVudEVtaXR0ZXIub24oQVNZTkNfRVJST1JfRVZFTlQsIGhhbmRsZUFzeW5jRXJyb3IpO1xuXG5pbnRlcmZhY2UgRXJyb3JFbnRyeSB7XG4gIGxldmVsOiBudW1iZXI7XG4gIG1lc3NhZ2U6IHN0cmluZztcbiAgc2hvdWxkQ2xlYXJBbnNpU2VxdWVuY2U/OiBib29sZWFuO1xufVxuXG4vKipcbiAqIEVtaXRzIGFuIGFzeW5jaHJvbm91cyBlcnJvciBldmVudC5cbiAqXG4gKiBAcGFyYW0gYXN5bmNFcnJvciAtIFRoZSBlcnJvciB0byBlbWl0IGFzIGFuIGFzeW5jaHJvbm91cyBlcnJvciBldmVudC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGVtaXRBc3luY0Vycm9yRXZlbnQoYXN5bmNFcnJvcjogdW5rbm93bik6IHZvaWQge1xuICBhc3luY0Vycm9yRXZlbnRFbWl0dGVyLmVtaXQoQVNZTkNfRVJST1JfRVZFTlQsIGFzeW5jRXJyb3IpO1xufVxuXG4vKipcbiAqIENvbnZlcnRzIGFuIGVycm9yIHRvIGEgc3RyaW5nIHJlcHJlc2VudGF0aW9uLCBpbmNsdWRpbmcgbmVzdGVkIGNhdXNlcyB3aXRoIGluZGVudGF0aW9uLlxuICpcbiAqIEBwYXJhbSBlcnJvciAtIFRoZSBlcnJvciB0byBjb252ZXJ0IHRvIGEgc3RyaW5nLlxuICogQHJldHVybnMgVGhlIHN0cmluZyByZXByZXNlbnRhdGlvbiBvZiB0aGUgZXJyb3IuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBlcnJvclRvU3RyaW5nKGVycm9yOiB1bmtub3duKTogc3RyaW5nIHtcbiAgcmV0dXJuIHBhcnNlRXJyb3JFbnRyaWVzKGVycm9yKS5tYXAoKGVudHJ5KSA9PiAnICAnLnJlcGVhdChlbnRyeS5sZXZlbCkgKyBlbnRyeS5tZXNzYWdlKS5qb2luKCdcXG4nKTtcbn1cblxuLyoqXG4gKiBHZXRzIHRoZSBjdXJyZW50IHN0YWNrIHRyYWNlIGFzIGEgc3RyaW5nLCBleGNsdWRpbmcgdGhlIGN1cnJlbnQgZnVuY3Rpb24gY2FsbC5cbiAqXG4gKiBAcmV0dXJucyBBIHN0cmluZyByZXByZXNlbnRhdGlvbiBvZiB0aGUgY3VycmVudCBzdGFjayB0cmFjZSwgZXhjbHVkaW5nIHRoZSBjdXJyZW50IGZ1bmN0aW9uIGNhbGwuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRTdGFja1RyYWNlKCk6IHN0cmluZyB7XG4gIGNvbnN0IHN0YWNrID0gbmV3IEVycm9yKCkuc3RhY2sgPz8gJyc7XG4gIGNvbnN0IGxpbmVzID0gc3RhY2suc3BsaXQoJ1xcbicpO1xuICByZXR1cm4gbGluZXMuc2xpY2UoMikuam9pbignXFxuJyk7XG59XG5cbi8qKlxuICogUHJpbnRzIGFuIGVycm9yIHRvIHRoZSBjb25zb2xlLCBpbmNsdWRpbmcgbmVzdGVkIGNhdXNlcyBhbmQgb3B0aW9uYWwgQU5TSSBzZXF1ZW5jZSBjbGVhcmluZy5cbiAqXG4gKiBAcGFyYW0gZXJyb3IgLSBUaGUgZXJyb3IgdG8gcHJpbnQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwcmludEVycm9yKGVycm9yOiB1bmtub3duKTogdm9pZCB7XG4gIGNvbnN0IGVudHJpZXMgPSBwYXJzZUVycm9yRW50cmllcyhlcnJvcik7XG5cbiAgZm9yIChjb25zdCBlbnRyeSBvZiBlbnRyaWVzKSB7XG4gICAgaWYgKGVudHJ5LnNob3VsZENsZWFyQW5zaVNlcXVlbmNlKSB7XG4gICAgICBjb25zb2xlLmVycm9yKGBcXHgxYlswbSR7ZW50cnkubWVzc2FnZX1cXHgxYlswbWApO1xuICAgIH0gZWxzZSB7XG4gICAgICBjb25zb2xlLmVycm9yKGVudHJ5Lm1lc3NhZ2UpO1xuICAgIH1cbiAgfVxufVxuXG4vKipcbiAqIFJlZ2lzdGVycyBhbiBldmVudCBoYW5kbGVyIGZvciBhc3luY2hyb25vdXMgZXJyb3JzLlxuICpcbiAqIEBwYXJhbSBoYW5kbGVyIC0gVGhlIGhhbmRsZXIgZnVuY3Rpb24gdG8gYmUgY2FsbGVkIHdoZW4gYW4gYXN5bmNocm9ub3VzIGVycm9yIGV2ZW50IG9jY3Vycy5cbiAqIEByZXR1cm5zIEEgZnVuY3Rpb24gdG8gdW5yZWdpc3RlciB0aGUgaGFuZGxlci5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHJlZ2lzdGVyQXN5bmNFcnJvckV2ZW50SGFuZGxlcihoYW5kbGVyOiAoYXN5bmNFcnJvcjogdW5rbm93bikgPT4gdm9pZCk6ICgpID0+IHZvaWQge1xuICBhc3luY0Vycm9yRXZlbnRFbWl0dGVyLm9uKEFTWU5DX0VSUk9SX0VWRU5ULCBoYW5kbGVyKTtcbiAgcmV0dXJuICgpID0+IGFzeW5jRXJyb3JFdmVudEVtaXR0ZXIub2ZmKEFTWU5DX0VSUk9SX0VWRU5ULCBoYW5kbGVyKTtcbn1cblxuLyoqXG4gKiBUaHJvd3MgYW4gZXJyb3Igd2l0aCB0aGUgc3BlY2lmaWVkIG1lc3NhZ2UuXG4gKlxuICogQHBhcmFtIGVycm9yIC0gVGhlIGVycm9yIHRvIHRocm93LlxuICogQHJldHVybnMgQSBuZXZlci1yZXR1cm5pbmcgZnVuY3Rpb24uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB0aHJvd0V4cHJlc3Npb24oZXJyb3I6IHVua25vd24pOiBuZXZlciB7XG4gIHRocm93IGVycm9yO1xufVxuXG4vKipcbiAqIEhhbmRsZXMgYXN5bmNocm9ub3VzIGVycm9ycyBieSBwcmludGluZyB0aGVtLlxuICpcbiAqIEBwYXJhbSBhc3luY0Vycm9yIC0gVGhlIGFzeW5jaHJvbm91cyBlcnJvciB0byBoYW5kbGUuXG4gKi9cbmZ1bmN0aW9uIGhhbmRsZUFzeW5jRXJyb3IoYXN5bmNFcnJvcjogdW5rbm93bik6IHZvaWQge1xuICBwcmludEVycm9yKG5ldyBFcnJvcignQW4gdW5oYW5kbGVkIGVycm9yIG9jY3VycmVkIGV4ZWN1dGluZyBhc3luYyBvcGVyYXRpb24nLCB7IGNhdXNlOiBhc3luY0Vycm9yIH0pKTtcbn1cblxuLyoqXG4gKiBQYXJzZXMgYW4gZXJyb3IgaW50byBhbiBhcnJheSBvZiBFcnJvckVudHJ5IG9iamVjdHMsIGluY2x1ZGluZyBuZXN0ZWQgY2F1c2VzLlxuICpcbiAqIEBwYXJhbSBlcnJvciAtIFRoZSBlcnJvciB0byBwYXJzZS5cbiAqIEBwYXJhbSBsZXZlbCAtIFRoZSBjdXJyZW50IGluZGVudGF0aW9uIGxldmVsIGZvciBuZXN0ZWQgY2F1c2VzLlxuICogQHBhcmFtIGVudHJpZXMgLSBUaGUgYXJyYXkgb2YgRXJyb3JFbnRyeSBvYmplY3RzIHRvIHBvcHVsYXRlLlxuICogQHJldHVybnMgQW4gYXJyYXkgb2YgRXJyb3JFbnRyeSBvYmplY3RzIHJlcHJlc2VudGluZyB0aGUgZXJyb3IgYW5kIGl0cyBjYXVzZXMuXG4gKi9cbmZ1bmN0aW9uIHBhcnNlRXJyb3JFbnRyaWVzKGVycm9yOiB1bmtub3duLCBsZXZlbCA9IDAsIGVudHJpZXM6IEVycm9yRW50cnlbXSA9IFtdKTogRXJyb3JFbnRyeVtdIHtcbiAgaWYgKGVycm9yID09PSB1bmRlZmluZWQpIHtcbiAgICByZXR1cm4gZW50cmllcztcbiAgfVxuXG4gIGlmICghKGVycm9yIGluc3RhbmNlb2YgRXJyb3IpKSB7XG4gICAgbGV0IHN0ciA9ICcnO1xuXG4gICAgaWYgKGVycm9yID09PSBudWxsKSB7XG4gICAgICBzdHIgPSAnKG51bGwpJztcbiAgICB9IGVsc2UgaWYgKHR5cGVvZiBlcnJvciA9PT0gJ3N0cmluZycpIHtcbiAgICAgIHN0ciA9IGVycm9yO1xuICAgIH0gZWxzZSB7XG4gICAgICBzdHIgPSBKU09OLnN0cmluZ2lmeShlcnJvcik7XG4gICAgfVxuXG4gICAgZW50cmllcy5wdXNoKHsgbGV2ZWwsIG1lc3NhZ2U6IHN0ciB9KTtcbiAgICByZXR1cm4gZW50cmllcztcbiAgfVxuXG4gIGNvbnN0IHRpdGxlID0gYCR7ZXJyb3IubmFtZX06ICR7ZXJyb3IubWVzc2FnZX1gO1xuICBlbnRyaWVzLnB1c2goeyBsZXZlbCwgbWVzc2FnZTogdGl0bGUsIHNob3VsZENsZWFyQW5zaVNlcXVlbmNlOiB0cnVlIH0pO1xuXG4gIGlmIChlcnJvci5zdGFjaykge1xuICAgIGNvbnN0IHJlc3RTdGFjayA9IGVycm9yLnN0YWNrLnN0YXJ0c1dpdGgodGl0bGUpID8gZXJyb3Iuc3RhY2suc2xpY2UodGl0bGUubGVuZ3RoICsgMSkgOiBlcnJvci5zdGFjaztcbiAgICBlbnRyaWVzLnB1c2goeyBsZXZlbCwgbWVzc2FnZTogYEVycm9yIHN0YWNrOlxcbiR7cmVzdFN0YWNrfWAgfSk7XG4gIH1cblxuICBpZiAoZXJyb3IuY2F1c2UgIT09IHVuZGVmaW5lZCkge1xuICAgIGVudHJpZXMucHVzaCh7IGxldmVsLCBtZXNzYWdlOiAnQ2F1c2VkIGJ5OicgfSk7XG4gICAgcGFyc2VFcnJvckVudHJpZXMoZXJyb3IuY2F1c2UsIGxldmVsICsgMSwgZW50cmllcyk7XG4gIH1cblxuICByZXR1cm4gZW50cmllcztcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUtBLDJCQUE2QjtBQUU3QixNQUFNLG9CQUFvQjtBQUUxQixNQUFNLHlCQUF5QixJQUFJLGtDQUFhO0FBQ2hELHVCQUF1QixHQUFHLG1CQUFtQixnQkFBZ0I7QUFhdEQsU0FBUyxvQkFBb0IsWUFBMkI7QUFDN0QseUJBQXVCLEtBQUssbUJBQW1CLFVBQVU7QUFDM0Q7QUFRTyxTQUFTLGNBQWMsT0FBd0I7QUFDcEQsU0FBTyxrQkFBa0IsS0FBSyxFQUFFLElBQUksQ0FBQyxVQUFVLEtBQUssT0FBTyxNQUFNLEtBQUssSUFBSSxNQUFNLE9BQU8sRUFBRSxLQUFLLElBQUk7QUFDcEc7QUFPTyxTQUFTLGdCQUF3QjtBQUN0QyxRQUFNLFFBQVEsSUFBSSxNQUFNLEVBQUUsU0FBUztBQUNuQyxRQUFNLFFBQVEsTUFBTSxNQUFNLElBQUk7QUFDOUIsU0FBTyxNQUFNLE1BQU0sQ0FBQyxFQUFFLEtBQUssSUFBSTtBQUNqQztBQU9PLFNBQVMsV0FBVyxPQUFzQjtBQUMvQyxRQUFNLFVBQVUsa0JBQWtCLEtBQUs7QUFFdkMsYUFBVyxTQUFTLFNBQVM7QUFDM0IsUUFBSSxNQUFNLHlCQUF5QjtBQUNqQyxjQUFRLE1BQU0sVUFBVSxNQUFNLE9BQU8sU0FBUztBQUFBLElBQ2hELE9BQU87QUFDTCxjQUFRLE1BQU0sTUFBTSxPQUFPO0FBQUEsSUFDN0I7QUFBQSxFQUNGO0FBQ0Y7QUFRTyxTQUFTLCtCQUErQixTQUFvRDtBQUNqRyx5QkFBdUIsR0FBRyxtQkFBbUIsT0FBTztBQUNwRCxTQUFPLE1BQU0sdUJBQXVCLElBQUksbUJBQW1CLE9BQU87QUFDcEU7QUFRTyxTQUFTLGdCQUFnQixPQUF1QjtBQUNyRCxRQUFNO0FBQ1I7QUFPQSxTQUFTLGlCQUFpQixZQUEyQjtBQUNuRCxhQUFXLElBQUksTUFBTSx5REFBeUQsRUFBRSxPQUFPLFdBQVcsQ0FBQyxDQUFDO0FBQ3RHO0FBVUEsU0FBUyxrQkFBa0IsT0FBZ0IsUUFBUSxHQUFHLFVBQXdCLENBQUMsR0FBaUI7QUFDOUYsTUFBSSxVQUFVLFFBQVc7QUFDdkIsV0FBTztBQUFBLEVBQ1Q7QUFFQSxNQUFJLEVBQUUsaUJBQWlCLFFBQVE7QUFDN0IsUUFBSSxNQUFNO0FBRVYsUUFBSSxVQUFVLE1BQU07QUFDbEIsWUFBTTtBQUFBLElBQ1IsV0FBVyxPQUFPLFVBQVUsVUFBVTtBQUNwQyxZQUFNO0FBQUEsSUFDUixPQUFPO0FBQ0wsWUFBTSxLQUFLLFVBQVUsS0FBSztBQUFBLElBQzVCO0FBRUEsWUFBUSxLQUFLLEVBQUUsT0FBTyxTQUFTLElBQUksQ0FBQztBQUNwQyxXQUFPO0FBQUEsRUFDVDtBQUVBLFFBQU0sUUFBUSxHQUFHLE1BQU0sSUFBSSxLQUFLLE1BQU0sT0FBTztBQUM3QyxVQUFRLEtBQUssRUFBRSxPQUFPLFNBQVMsT0FBTyx5QkFBeUIsS0FBSyxDQUFDO0FBRXJFLE1BQUksTUFBTSxPQUFPO0FBQ2YsVUFBTSxZQUFZLE1BQU0sTUFBTSxXQUFXLEtBQUssSUFBSSxNQUFNLE1BQU0sTUFBTSxNQUFNLFNBQVMsQ0FBQyxJQUFJLE1BQU07QUFDOUYsWUFBUSxLQUFLLEVBQUUsT0FBTyxTQUFTO0FBQUEsRUFBaUIsU0FBUyxHQUFHLENBQUM7QUFBQSxFQUMvRDtBQUVBLE1BQUksTUFBTSxVQUFVLFFBQVc7QUFDN0IsWUFBUSxLQUFLLEVBQUUsT0FBTyxTQUFTLGFBQWEsQ0FBQztBQUM3QyxzQkFBa0IsTUFBTSxPQUFPLFFBQVEsR0FBRyxPQUFPO0FBQUEsRUFDbkQ7QUFFQSxTQUFPO0FBQ1Q7IiwKICAibmFtZXMiOiBbXQp9Cg==
|
package/dist/lib/Error.d.ts
CHANGED
@@ -9,12 +9,18 @@
|
|
9
9
|
*/
|
10
10
|
export declare function emitAsyncErrorEvent(asyncError: unknown): void;
|
11
11
|
/**
|
12
|
-
*
|
12
|
+
* Converts an error to a string representation, including nested causes with indentation.
|
13
13
|
*
|
14
|
-
* @param
|
15
|
-
* @returns
|
14
|
+
* @param error - The error to convert to a string.
|
15
|
+
* @returns The string representation of the error.
|
16
16
|
*/
|
17
|
-
export declare function
|
17
|
+
export declare function errorToString(error: unknown): string;
|
18
|
+
/**
|
19
|
+
* Gets the current stack trace as a string, excluding the current function call.
|
20
|
+
*
|
21
|
+
* @returns A string representation of the current stack trace, excluding the current function call.
|
22
|
+
*/
|
23
|
+
export declare function getStackTrace(): string;
|
18
24
|
/**
|
19
25
|
* Prints an error to the console, including nested causes and optional ANSI sequence clearing.
|
20
26
|
*
|
@@ -22,12 +28,12 @@ export declare function registerAsyncErrorEventHandler(handler: (asyncError: unk
|
|
22
28
|
*/
|
23
29
|
export declare function printError(error: unknown): void;
|
24
30
|
/**
|
25
|
-
*
|
31
|
+
* Registers an event handler for asynchronous errors.
|
26
32
|
*
|
27
|
-
* @param
|
28
|
-
* @returns
|
33
|
+
* @param handler - The handler function to be called when an asynchronous error event occurs.
|
34
|
+
* @returns A function to unregister the handler.
|
29
35
|
*/
|
30
|
-
export declare function
|
36
|
+
export declare function registerAsyncErrorEventHandler(handler: (asyncError: unknown) => void): () => void;
|
31
37
|
/**
|
32
38
|
* Throws an error with the specified message.
|
33
39
|
*
|
@@ -35,9 +41,3 @@ export declare function errorToString(error: unknown): string;
|
|
35
41
|
* @returns A never-returning function.
|
36
42
|
*/
|
37
43
|
export declare function throwExpression(error: unknown): never;
|
38
|
-
/**
|
39
|
-
* Gets the current stack trace as a string, excluding the current function call.
|
40
|
-
*
|
41
|
-
* @returns A string representation of the current stack trace, excluding the current function call.
|
42
|
-
*/
|
43
|
-
export declare function getStackTrace(): string;
|