obsidian-dev-utils 32.0.0 → 32.0.2-beta.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 +8 -0
- package/dist/lib/cjs/AbortController.cjs +70 -12
- package/dist/lib/cjs/AbortController.d.cts +39 -2
- package/dist/lib/cjs/Array.cjs +4 -3
- package/dist/lib/cjs/Async.cjs +187 -100
- package/dist/lib/cjs/Async.d.cts +71 -26
- package/dist/lib/cjs/Debug.cjs +18 -14
- package/dist/lib/cjs/Error.cjs +37 -4
- package/dist/lib/cjs/Error.d.cts +16 -3
- package/dist/lib/cjs/Library.cjs +1 -1
- package/dist/lib/cjs/ScriptUtils/version.cjs +4 -4
- package/dist/lib/cjs/String.cjs +2 -2
- package/dist/lib/cjs/ValueProvider.cjs +2 -2
- package/dist/lib/cjs/obsidian/FileChange.cjs +3 -3
- package/dist/lib/cjs/obsidian/Link.cjs +3 -3
- package/dist/lib/cjs/obsidian/Logger.cjs +21 -10
- package/dist/lib/cjs/obsidian/Loop.cjs +5 -6
- package/dist/lib/cjs/obsidian/MarkdownCodeBlockProcessor.cjs +2 -2
- package/dist/lib/cjs/obsidian/Plugin/PluginBase.cjs +16 -4
- package/dist/lib/cjs/obsidian/Plugin/PluginBase.d.cts +7 -0
- package/dist/lib/cjs/obsidian/Queue.cjs +9 -10
- package/dist/lib/cjs/obsidian/RenameDeleteHandler.cjs +3 -3
- package/dist/lib/cjs/obsidian/Validation.cjs +1 -9
- package/dist/lib/cjs/obsidian/Validation.d.cts +0 -7
- package/dist/lib/esm/AbortController.d.mts +39 -2
- package/dist/lib/esm/AbortController.mjs +65 -11
- package/dist/lib/esm/Array.mjs +4 -3
- package/dist/lib/esm/Async.d.mts +71 -26
- package/dist/lib/esm/Async.mjs +184 -100
- package/dist/lib/esm/Debug.mjs +18 -14
- package/dist/lib/esm/Error.d.mts +16 -3
- package/dist/lib/esm/Error.mjs +35 -3
- package/dist/lib/esm/Library.mjs +1 -1
- package/dist/lib/esm/ScriptUtils/version.mjs +4 -4
- package/dist/lib/esm/String.mjs +2 -2
- package/dist/lib/esm/ValueProvider.mjs +2 -2
- package/dist/lib/esm/obsidian/FileChange.mjs +3 -3
- package/dist/lib/esm/obsidian/Link.mjs +3 -3
- package/dist/lib/esm/obsidian/Logger.mjs +21 -10
- package/dist/lib/esm/obsidian/Loop.mjs +9 -8
- package/dist/lib/esm/obsidian/MarkdownCodeBlockProcessor.mjs +2 -2
- package/dist/lib/esm/obsidian/Plugin/PluginBase.d.mts +7 -0
- package/dist/lib/esm/obsidian/Plugin/PluginBase.mjs +16 -4
- package/dist/lib/esm/obsidian/Queue.mjs +9 -10
- package/dist/lib/esm/obsidian/RenameDeleteHandler.mjs +3 -3
- package/dist/lib/esm/obsidian/Validation.d.mts +0 -7
- package/dist/lib/esm/obsidian/Validation.mjs +1 -8
- package/package.json +1 -1
package/dist/lib/cjs/Async.cjs
CHANGED
|
@@ -25,9 +25,9 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
25
25
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
26
26
|
var Async_exports = {};
|
|
27
27
|
__export(Async_exports, {
|
|
28
|
-
INFINITE_TIMEOUT: () => INFINITE_TIMEOUT,
|
|
29
28
|
addErrorHandler: () => addErrorHandler,
|
|
30
29
|
asyncFilter: () => asyncFilter,
|
|
30
|
+
asyncFilterInPlace: () => asyncFilterInPlace,
|
|
31
31
|
asyncFlatMap: () => asyncFlatMap,
|
|
32
32
|
asyncMap: () => asyncMap,
|
|
33
33
|
convertAsyncToSync: () => convertAsyncToSync,
|
|
@@ -36,11 +36,17 @@ __export(Async_exports, {
|
|
|
36
36
|
invokeAsyncSafely: () => invokeAsyncSafely,
|
|
37
37
|
invokeAsyncSafelyAfterDelay: () => invokeAsyncSafelyAfterDelay,
|
|
38
38
|
marksAsTerminateRetry: () => marksAsTerminateRetry,
|
|
39
|
+
neverEnds: () => neverEnds,
|
|
40
|
+
nextTickAsync: () => nextTickAsync,
|
|
41
|
+
promiseAllAsyncFnsSequentially: () => promiseAllAsyncFnsSequentially,
|
|
42
|
+
promiseAllSequentially: () => promiseAllSequentially,
|
|
43
|
+
queueMicrotaskAsync: () => queueMicrotaskAsync,
|
|
39
44
|
requestAnimationFrameAsync: () => requestAnimationFrameAsync,
|
|
40
45
|
retryWithTimeout: () => retryWithTimeout,
|
|
41
46
|
runWithTimeout: () => runWithTimeout,
|
|
47
|
+
setImmediateAsync: () => setImmediateAsync,
|
|
48
|
+
setTimeoutAsync: () => setTimeoutAsync,
|
|
42
49
|
sleep: () => sleep,
|
|
43
|
-
throwOnAbort: () => throwOnAbort,
|
|
44
50
|
timeout: () => timeout,
|
|
45
51
|
toArray: () => toArray
|
|
46
52
|
});
|
|
@@ -48,49 +54,126 @@ module.exports = __toCommonJS(Async_exports);
|
|
|
48
54
|
var import_AbortController = require('./AbortController.cjs');
|
|
49
55
|
var import_Debug = require('./Debug.cjs');
|
|
50
56
|
var import_Error = require('./Error.cjs');
|
|
51
|
-
|
|
52
|
-
async function addErrorHandler(asyncFn) {
|
|
53
|
-
|
|
57
|
+
var import_Function = require('./Function.cjs');
|
|
58
|
+
async function addErrorHandler(asyncFn, stackTrace) {
|
|
59
|
+
stackTrace ??= (0, import_Error.getStackTrace)(1);
|
|
54
60
|
try {
|
|
55
61
|
await asyncFn();
|
|
56
62
|
} catch (asyncError) {
|
|
57
|
-
|
|
58
|
-
(0, import_Error.emitAsyncErrorEvent)(asyncErrorWrapper);
|
|
63
|
+
(0, import_Error.emitAsyncErrorEvent)(new import_Error.CustomStackTraceError(import_Error.ASYNC_WRAPPER_ERROR_MESSAGE, stackTrace, asyncError));
|
|
59
64
|
}
|
|
60
65
|
}
|
|
61
66
|
async function asyncFilter(arr, predicate) {
|
|
62
|
-
const
|
|
63
|
-
|
|
67
|
+
const ans = [];
|
|
68
|
+
const length = arr.length;
|
|
69
|
+
for (let i = 0; i < length; i++) {
|
|
70
|
+
if (!Object.hasOwn(arr, i)) {
|
|
71
|
+
continue;
|
|
72
|
+
}
|
|
73
|
+
const item = arr[i];
|
|
74
|
+
if (await predicate(item, i, arr)) {
|
|
75
|
+
ans.push(item);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
return ans;
|
|
79
|
+
}
|
|
80
|
+
async function asyncFilterInPlace(arr, predicate) {
|
|
81
|
+
const length = arr.length;
|
|
82
|
+
let writeIndex = 0;
|
|
83
|
+
for (let readIndex = 0; readIndex < length; readIndex++) {
|
|
84
|
+
if (!Object.hasOwn(arr, readIndex)) {
|
|
85
|
+
continue;
|
|
86
|
+
}
|
|
87
|
+
const current = arr[readIndex];
|
|
88
|
+
if (await predicate(current, readIndex, arr)) {
|
|
89
|
+
arr[writeIndex++] = current;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
arr.length = writeIndex;
|
|
64
93
|
}
|
|
65
94
|
async function asyncFlatMap(arr, callback) {
|
|
66
95
|
return (await asyncMap(arr, callback)).flat();
|
|
67
96
|
}
|
|
68
97
|
async function asyncMap(arr, callback) {
|
|
69
|
-
return await
|
|
98
|
+
return await promiseAllSequentially(arr.map(callback));
|
|
70
99
|
}
|
|
71
|
-
function convertAsyncToSync(asyncFunc) {
|
|
100
|
+
function convertAsyncToSync(asyncFunc, stackTrace) {
|
|
101
|
+
stackTrace ??= (0, import_Error.getStackTrace)(1);
|
|
72
102
|
return (...args) => {
|
|
73
|
-
|
|
103
|
+
const innerStackTrace = (0, import_Error.getStackTrace)(1);
|
|
104
|
+
stackTrace = `${stackTrace ?? ""}
|
|
105
|
+
at --- convertAsyncToSync --- (0)
|
|
106
|
+
${innerStackTrace}`;
|
|
107
|
+
invokeAsyncSafely(() => asyncFunc(...args), stackTrace);
|
|
74
108
|
};
|
|
75
109
|
}
|
|
76
110
|
function convertSyncToAsync(syncFn) {
|
|
77
|
-
return (...args) =>
|
|
111
|
+
return async (...args) => {
|
|
112
|
+
await Promise.resolve();
|
|
113
|
+
return syncFn(...args);
|
|
114
|
+
};
|
|
78
115
|
}
|
|
79
116
|
async function ignoreError(promise, fallbackValue) {
|
|
117
|
+
const ignoreErrorDebugger = (0, import_Debug.getLibDebugger)("Async:ignoreError");
|
|
118
|
+
const stackTrace = (0, import_Error.getStackTrace)(1);
|
|
80
119
|
try {
|
|
81
120
|
return await promise;
|
|
82
|
-
} catch {
|
|
121
|
+
} catch (e) {
|
|
122
|
+
ignoreErrorDebugger("Ignored error", new import_Error.CustomStackTraceError("Ignored error", stackTrace, e));
|
|
83
123
|
return fallbackValue;
|
|
84
124
|
}
|
|
85
125
|
}
|
|
86
|
-
function invokeAsyncSafely(asyncFn) {
|
|
87
|
-
|
|
126
|
+
function invokeAsyncSafely(asyncFn, stackTrace) {
|
|
127
|
+
stackTrace ??= (0, import_Error.getStackTrace)(1);
|
|
128
|
+
void addErrorHandler(asyncFn, stackTrace);
|
|
88
129
|
}
|
|
89
|
-
function invokeAsyncSafelyAfterDelay(asyncFn, delayInMilliseconds = 0) {
|
|
90
|
-
|
|
130
|
+
function invokeAsyncSafelyAfterDelay(asyncFn, delayInMilliseconds = 0, stackTrace, abortSignal) {
|
|
131
|
+
abortSignal ??= (0, import_AbortController.abortSignalNever)();
|
|
132
|
+
abortSignal.throwIfAborted();
|
|
133
|
+
stackTrace ??= (0, import_Error.getStackTrace)(1);
|
|
134
|
+
invokeAsyncSafely(async () => {
|
|
135
|
+
await sleep(delayInMilliseconds, abortSignal, true);
|
|
136
|
+
await asyncFn(abortSignal);
|
|
137
|
+
}, stackTrace);
|
|
138
|
+
}
|
|
139
|
+
async function promiseAllAsyncFnsSequentially(asyncFns) {
|
|
140
|
+
const results = [];
|
|
141
|
+
for (const asyncFn of asyncFns) {
|
|
142
|
+
results.push(await asyncFn());
|
|
143
|
+
}
|
|
144
|
+
return results;
|
|
145
|
+
}
|
|
146
|
+
async function promiseAllSequentially(promises) {
|
|
147
|
+
return await promiseAllAsyncFnsSequentially(promises.map((promise) => () => promise));
|
|
148
|
+
}
|
|
149
|
+
const terminateRetryErrors = /* @__PURE__ */ new WeakSet();
|
|
150
|
+
class Result {
|
|
151
|
+
constructor(result) {
|
|
152
|
+
this.result = result;
|
|
153
|
+
}
|
|
91
154
|
}
|
|
92
155
|
function marksAsTerminateRetry(error) {
|
|
93
|
-
|
|
156
|
+
terminateRetryErrors.add(error);
|
|
157
|
+
}
|
|
158
|
+
async function neverEnds() {
|
|
159
|
+
await new Promise(() => {
|
|
160
|
+
(0, import_Function.noop)();
|
|
161
|
+
});
|
|
162
|
+
throw new Error("Should never happen");
|
|
163
|
+
}
|
|
164
|
+
async function nextTickAsync() {
|
|
165
|
+
return new Promise((resolve) => {
|
|
166
|
+
process.nextTick(() => {
|
|
167
|
+
resolve();
|
|
168
|
+
});
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
async function queueMicrotaskAsync() {
|
|
172
|
+
return new Promise((resolve) => {
|
|
173
|
+
queueMicrotask(() => {
|
|
174
|
+
resolve();
|
|
175
|
+
});
|
|
176
|
+
});
|
|
94
177
|
}
|
|
95
178
|
async function requestAnimationFrameAsync() {
|
|
96
179
|
return new Promise((resolve) => {
|
|
@@ -103,7 +186,7 @@ async function retryWithTimeout(fn, retryOptions, stackTrace) {
|
|
|
103
186
|
const retryWithTimeoutDebugger = (0, import_Debug.getLibDebugger)("Async:retryWithTimeout");
|
|
104
187
|
stackTrace ??= (0, import_Error.getStackTrace)(1);
|
|
105
188
|
const DEFAULT_RETRY_OPTIONS = {
|
|
106
|
-
abortSignal: import_AbortController.abortSignalNever,
|
|
189
|
+
abortSignal: (0, import_AbortController.abortSignalNever)(),
|
|
107
190
|
// eslint-disable-next-line no-magic-numbers
|
|
108
191
|
retryDelayInMilliseconds: 100,
|
|
109
192
|
shouldRetryOnError: false,
|
|
@@ -112,107 +195,105 @@ async function retryWithTimeout(fn, retryOptions, stackTrace) {
|
|
|
112
195
|
};
|
|
113
196
|
const fullOptions = { ...DEFAULT_RETRY_OPTIONS, ...retryOptions };
|
|
114
197
|
fullOptions.abortSignal.throwIfAborted();
|
|
115
|
-
await runWithTimeout(
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
198
|
+
await runWithTimeout(
|
|
199
|
+
fullOptions.timeoutInMilliseconds,
|
|
200
|
+
async (abortSignal) => {
|
|
201
|
+
const combinedAbortSignal = (0, import_AbortController.abortSignalAny)([fullOptions.abortSignal, abortSignal]);
|
|
119
202
|
combinedAbortSignal.throwIfAborted();
|
|
120
|
-
attempt
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
isSuccess
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
203
|
+
let attempt = 0;
|
|
204
|
+
while (!combinedAbortSignal.aborted) {
|
|
205
|
+
attempt++;
|
|
206
|
+
let isSuccess;
|
|
207
|
+
try {
|
|
208
|
+
isSuccess = await fn(combinedAbortSignal);
|
|
209
|
+
} catch (error) {
|
|
210
|
+
if (combinedAbortSignal.aborted || !fullOptions.shouldRetryOnError || terminateRetryErrors.has(error)) {
|
|
211
|
+
throw new import_Error.CustomStackTraceError("retryWithTimeout failed", stackTrace, error);
|
|
212
|
+
}
|
|
213
|
+
(0, import_Error.printError)(error);
|
|
214
|
+
isSuccess = false;
|
|
127
215
|
}
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
if (attempt > 1) {
|
|
133
|
-
retryWithTimeoutDebugger(`Retry completed successfully after ${String(attempt)} attempts`);
|
|
216
|
+
if (isSuccess) {
|
|
217
|
+
retryWithTimeoutDebugger(`Retry completed successfully after ${String(attempt)} attempts`, {
|
|
218
|
+
fn
|
|
219
|
+
});
|
|
134
220
|
retryWithTimeoutDebugger.printStackTrace(stackTrace);
|
|
221
|
+
return;
|
|
135
222
|
}
|
|
136
|
-
|
|
223
|
+
retryWithTimeoutDebugger(
|
|
224
|
+
`Retry attempt ${String(attempt)} completed unsuccessfully. Trying again in ${String(fullOptions.retryDelayInMilliseconds)} milliseconds`,
|
|
225
|
+
{
|
|
226
|
+
fn
|
|
227
|
+
}
|
|
228
|
+
);
|
|
229
|
+
retryWithTimeoutDebugger.printStackTrace(stackTrace);
|
|
230
|
+
await sleep(fullOptions.retryDelayInMilliseconds);
|
|
137
231
|
}
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
}
|
|
143
|
-
);
|
|
144
|
-
retryWithTimeoutDebugger.printStackTrace(stackTrace);
|
|
145
|
-
await sleep(fullOptions.retryDelayInMilliseconds);
|
|
146
|
-
}
|
|
147
|
-
}, { retryFn: fn });
|
|
232
|
+
},
|
|
233
|
+
{ retryFn: fn },
|
|
234
|
+
stackTrace
|
|
235
|
+
);
|
|
148
236
|
}
|
|
149
|
-
async function runWithTimeout(timeoutInMilliseconds, fn, context) {
|
|
150
|
-
|
|
151
|
-
let result = null;
|
|
237
|
+
async function runWithTimeout(timeoutInMilliseconds, fn, context, stackTrace) {
|
|
238
|
+
stackTrace ??= (0, import_Error.getStackTrace)(1);
|
|
152
239
|
const startTime = performance.now();
|
|
153
240
|
const abortController = new AbortController();
|
|
154
|
-
if (timeoutInMilliseconds === INFINITE_TIMEOUT) {
|
|
155
|
-
await run();
|
|
156
|
-
return result;
|
|
157
|
-
}
|
|
158
241
|
await Promise.race([run(), innerTimeout()]);
|
|
159
|
-
if (
|
|
160
|
-
|
|
242
|
+
if (abortController.signal.reason instanceof Result) {
|
|
243
|
+
return abortController.signal.reason.result;
|
|
161
244
|
}
|
|
162
|
-
|
|
245
|
+
throw new import_Error.CustomStackTraceError("Run with timeout failed", stackTrace, abortController.signal.reason);
|
|
163
246
|
async function run() {
|
|
164
247
|
try {
|
|
165
|
-
result = await fn(abortController.signal);
|
|
248
|
+
const result = await fn(abortController.signal);
|
|
166
249
|
const duration = performance.now() - startTime;
|
|
167
|
-
(0, import_Debug.getLibDebugger)("Async:runWithTimeout")
|
|
168
|
-
|
|
169
|
-
|
|
250
|
+
const runWithTimeoutDebugger = (0, import_Debug.getLibDebugger)("Async:runWithTimeout");
|
|
251
|
+
runWithTimeoutDebugger(`Execution time: ${String(duration)} milliseconds`, { context, fn });
|
|
252
|
+
runWithTimeoutDebugger.printStackTrace(stackTrace ?? "");
|
|
253
|
+
abortController.abort(new Result(result));
|
|
254
|
+
} catch (e) {
|
|
255
|
+
abortController.abort(e);
|
|
170
256
|
}
|
|
171
257
|
}
|
|
172
258
|
async function innerTimeout() {
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
259
|
+
while (!abortController.signal.aborted) {
|
|
260
|
+
await sleep(timeoutInMilliseconds, abortController.signal);
|
|
261
|
+
if (abortController.signal.aborted) {
|
|
262
|
+
return;
|
|
263
|
+
}
|
|
264
|
+
const duration = performance.now() - startTime;
|
|
265
|
+
console.warn(`Timed out after ${String(duration)} milliseconds`, { context, fn });
|
|
266
|
+
const timeoutDebugger = (0, import_Debug.getLibDebugger)("Async:runWithTimeout:timeout");
|
|
267
|
+
if (!timeoutDebugger.enabled) {
|
|
268
|
+
abortController.abort(new Error(`Timed out after ${String(duration)} milliseconds`));
|
|
269
|
+
return;
|
|
270
|
+
}
|
|
271
|
+
timeoutDebugger(
|
|
272
|
+
`The execution is not terminated because debugger ${timeoutDebugger.namespace} is enabled. See https://github.com/mnaoumov/obsidian-dev-utils/blob/main/docs/debugging.md for more information`
|
|
186
273
|
);
|
|
187
|
-
await innerTimeout();
|
|
188
274
|
}
|
|
189
|
-
abortController.abort();
|
|
190
275
|
}
|
|
191
276
|
}
|
|
192
|
-
async function
|
|
193
|
-
|
|
194
|
-
|
|
277
|
+
async function setImmediateAsync() {
|
|
278
|
+
return new Promise((resolve) => {
|
|
279
|
+
setImmediate(() => {
|
|
280
|
+
resolve();
|
|
281
|
+
});
|
|
195
282
|
});
|
|
196
283
|
}
|
|
197
|
-
function
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
return;
|
|
201
|
-
}
|
|
202
|
-
abortSignal.addEventListener("abort", handleAbort, { once: true });
|
|
203
|
-
function handleAbort() {
|
|
204
|
-
try {
|
|
205
|
-
abortSignal.throwIfAborted();
|
|
206
|
-
return false;
|
|
207
|
-
} catch (e) {
|
|
208
|
-
reject(e);
|
|
209
|
-
return true;
|
|
210
|
-
}
|
|
211
|
-
}
|
|
284
|
+
async function setTimeoutAsync(delay) {
|
|
285
|
+
await new Promise((resolve) => {
|
|
286
|
+
setTimeout(resolve, delay);
|
|
212
287
|
});
|
|
213
288
|
}
|
|
214
|
-
async function
|
|
215
|
-
await
|
|
289
|
+
async function sleep(milliseconds, abortSignal, shouldThrowOnAbort) {
|
|
290
|
+
await (0, import_AbortController.waitForAbort)((0, import_AbortController.abortSignalAny)([abortSignal ?? (0, import_AbortController.abortSignalNever)(), (0, import_AbortController.abortSignalTimeout)(milliseconds)]));
|
|
291
|
+
if (shouldThrowOnAbort) {
|
|
292
|
+
abortSignal?.throwIfAborted();
|
|
293
|
+
}
|
|
294
|
+
}
|
|
295
|
+
async function timeout(timeoutInMilliseconds, abortSignal, shouldThrowOnAbort) {
|
|
296
|
+
await sleep(timeoutInMilliseconds, abortSignal, shouldThrowOnAbort);
|
|
216
297
|
throw new Error(`Timed out in ${String(timeoutInMilliseconds)} milliseconds`);
|
|
217
298
|
}
|
|
218
299
|
async function toArray(iter) {
|
|
@@ -224,9 +305,9 @@ async function toArray(iter) {
|
|
|
224
305
|
}
|
|
225
306
|
// Annotate the CommonJS export names for ESM import in node:
|
|
226
307
|
0 && (module.exports = {
|
|
227
|
-
INFINITE_TIMEOUT,
|
|
228
308
|
addErrorHandler,
|
|
229
309
|
asyncFilter,
|
|
310
|
+
asyncFilterInPlace,
|
|
230
311
|
asyncFlatMap,
|
|
231
312
|
asyncMap,
|
|
232
313
|
convertAsyncToSync,
|
|
@@ -235,12 +316,18 @@ async function toArray(iter) {
|
|
|
235
316
|
invokeAsyncSafely,
|
|
236
317
|
invokeAsyncSafelyAfterDelay,
|
|
237
318
|
marksAsTerminateRetry,
|
|
319
|
+
neverEnds,
|
|
320
|
+
nextTickAsync,
|
|
321
|
+
promiseAllAsyncFnsSequentially,
|
|
322
|
+
promiseAllSequentially,
|
|
323
|
+
queueMicrotaskAsync,
|
|
238
324
|
requestAnimationFrameAsync,
|
|
239
325
|
retryWithTimeout,
|
|
240
326
|
runWithTimeout,
|
|
327
|
+
setImmediateAsync,
|
|
328
|
+
setTimeoutAsync,
|
|
241
329
|
sleep,
|
|
242
|
-
throwOnAbort,
|
|
243
330
|
timeout,
|
|
244
331
|
toArray
|
|
245
332
|
});
|
|
246
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/Async.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for asynchronous operations.\n */\n\nimport type { Promisable } from 'type-fest';\n\nimport {\n  abortSignalAny,\n  abortSignalNever\n} from './AbortController.ts';\nimport { getLibDebugger } from './Debug.ts';\nimport {\n  ASYNC_ERROR_WRAPPER_MESSAGE,\n  emitAsyncErrorEvent,\n  getStackTrace,\n  printError\n} from './Error.ts';\n\n/**\n * A type representing a function that resolves a {@link Promise}.\n *\n * @typeParam T - The type of the value.\n */\nexport type PromiseResolve<T> = undefined extends T ? (value?: PromiseLike<T> | T) => void\n  : (value: PromiseLike<T> | T) => void;\n\n/**\n * A constant representing an infinite timeout.\n */\nexport const INFINITE_TIMEOUT = Number.POSITIVE_INFINITY;\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 {@link 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 {@link Promise} that resolves when the asynchronous function completes or emits async error event.\n */\nexport async function addErrorHandler(asyncFn: () => Promise<unknown>): Promise<void> {\n  const asyncErrorWrapper = new Error(ASYNC_ERROR_WRAPPER_MESSAGE);\n  try {\n    await asyncFn();\n  } catch (asyncError) {\n    asyncErrorWrapper.cause = asyncError;\n    emitAsyncErrorEvent(asyncErrorWrapper);\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 {@link 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[]) => Promisable<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 {@link 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[]) => Promisable<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 {@link 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[]) => Promisable<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 {@link 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 * Ignores an error that is thrown by an asynchronous function.\n *\n * @param promise - The promise to ignore the error of.\n * @param fallbackValue - Always `undefined`.\n * @returns A {@link Promise} that resolves when the asynchronous function completes or fails.\n */\nexport async function ignoreError(promise: Promise<unknown>, fallbackValue?: undefined): Promise<void>;\n\n/**\n * Invokes an asynchronous function and returns a fallback value if an error is thrown.\n *\n * @typeParam T - The type of the value returned by the asynchronous function.\n * @param promise - The promise to ignore the error of.\n * @param fallbackValue - The value to return if an error is thrown.\n * @returns A {@link Promise} that resolves with the value returned by the asynchronous function or the fallback value if an error is thrown.\n */\nexport async function ignoreError<T>(promise: Promise<T>, fallbackValue: T): Promise<T> {\n  try {\n    return await promise;\n  } catch {\n    return fallbackValue;\n  }\n}\n\n/**\n * Invokes a {@link 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  // eslint-disable-next-line no-void\n  void addErrorHandler(asyncFn);\n}\n\n/**\n * Invokes an asynchronous function after a delay.\n *\n * @param asyncFn - The asynchronous function to invoke.\n * @param delayInMilliseconds - The delay in milliseconds.\n */\nexport function invokeAsyncSafelyAfterDelay(asyncFn: () => Promisable<unknown>, delayInMilliseconds = 0): void {\n  window.setTimeout(convertAsyncToSync(async () => await asyncFn()), delayInMilliseconds);\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 * Gets the next request animation frame.\n *\n * @returns A promise that resolves when the next request animation frame is available.\n */\nexport async function requestAnimationFrameAsync(): Promise<void> {\n  return new Promise((resolve) => {\n    requestAnimationFrame(() => {\n      resolve();\n    });\n  });\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 {@link Promise} that resolves when the function returns true or rejects when the timeout is reached.\n */\nexport async function retryWithTimeout(fn: (abortSignal: AbortSignal) => Promisable<boolean>, retryOptions?: RetryOptions, stackTrace?: string): Promise<void> {\n  const retryWithTimeoutDebugger = getLibDebugger('Async:retryWithTimeout');\n  stackTrace ??= getStackTrace(1);\n  const DEFAULT_RETRY_OPTIONS = {\n    abortSignal: abortSignalNever,\n    // eslint-disable-next-line no-magic-numbers\n    retryDelayInMilliseconds: 100,\n    shouldRetryOnError: false,\n    // eslint-disable-next-line no-magic-numbers\n    timeoutInMilliseconds: 5000\n  };\n  const fullOptions = { ...DEFAULT_RETRY_OPTIONS, ...retryOptions };\n  fullOptions.abortSignal.throwIfAborted();\n\n  await runWithTimeout(fullOptions.timeoutInMilliseconds, async (abortSignal: AbortSignal) => {\n    const combinedAbortSignal = abortSignalAny([fullOptions.abortSignal, abortSignal]);\n    let attempt = 0;\n    // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n    while (true) {\n      combinedAbortSignal.throwIfAborted();\n      attempt++;\n      let isSuccess: boolean;\n      try {\n        isSuccess = await fn(combinedAbortSignal);\n      } catch (error) {\n        if (combinedAbortSignal.aborted || !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 ${String(attempt)} attempts`);\n          retryWithTimeoutDebugger.printStackTrace(stackTrace);\n        }\n        return;\n      }\n\n      retryWithTimeoutDebugger(\n        `Retry attempt ${String(attempt)} completed unsuccessfully. Trying again in ${String(fullOptions.retryDelayInMilliseconds)} milliseconds`,\n        {\n          fn\n        }\n      );\n      retryWithTimeoutDebugger.printStackTrace(stackTrace);\n      await sleep(fullOptions.retryDelayInMilliseconds);\n    }\n  }, { retryFn: fn });\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 * @param context - The context of the function.\n * @returns A {@link 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: (abortSignal: AbortSignal) => Promisable<R>, context?: unknown): Promise<R> {\n  let isTimedOut = true;\n  let result: R = null as R;\n  const startTime = performance.now();\n\n  const abortController = new AbortController();\n\n  if (timeoutInMilliseconds === INFINITE_TIMEOUT) {\n    await run();\n    return result;\n  }\n\n  await Promise.race([run(), innerTimeout()]);\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    try {\n      result = await fn(abortController.signal);\n      const duration = performance.now() - startTime;\n      getLibDebugger('Async:runWithTimeout')(`Execution time: ${String(duration)} milliseconds`, { context, fn });\n    } finally {\n      isTimedOut = false;\n    }\n  }\n\n  async function innerTimeout(): 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 ${String(duration)} milliseconds`, { context, fn });\n    const _debugger = getLibDebugger('Async:runWithTimeout:timeout');\n    if (_debugger.enabled) {\n      _debugger(\n        `The execution is not terminated because debugger ${_debugger.namespace} is enabled. See https://github.com/mnaoumov/obsidian-dev-utils/blob/main/docs/debugging.md for more information`\n      );\n      await innerTimeout();\n    }\n    abortController.abort();\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 {@link Promise} that resolves after the specified delay.\n */\nexport async function sleep(milliseconds: number): Promise<void> {\n  await new Promise((resolve) => {\n    window.setTimeout(resolve, milliseconds);\n  });\n}\n\n/**\n * Returns a {@link Promise} that rejects when the abort signal is aborted.\n *\n * @param abortSignal - The abort signal to listen to.\n * @returns A {@link Promise} that rejects when the abort signal is aborted.\n */\nexport function throwOnAbort(abortSignal: AbortSignal): Promise<void> {\n  return new Promise((_resolve, reject) => {\n    if (handleAbort()) {\n      return;\n    }\n    abortSignal.addEventListener('abort', handleAbort, { once: true });\n\n    function handleAbort(): boolean {\n      try {\n        abortSignal.throwIfAborted();\n        return false;\n      } catch (e) {\n        reject(e as Error);\n        return true;\n      }\n    }\n  });\n}\n\n/**\n * Returns a {@link Promise} that rejects after the specified timeout period.\n *\n * @param timeoutInMilliseconds - The timeout period in milliseconds.\n * @returns A {@link 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 ${String(timeoutInMilliseconds)} 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 {@link 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": []
}

|
|
333
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/Async.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for asynchronous operations.\n */\n\nimport type { Promisable } from 'type-fest';\n\nimport {\n  abortSignalAny,\n  abortSignalNever,\n  abortSignalTimeout,\n  waitForAbort\n} from './AbortController.ts';\nimport { getLibDebugger } from './Debug.ts';\nimport {\n  ASYNC_WRAPPER_ERROR_MESSAGE,\n  CustomStackTraceError,\n  emitAsyncErrorEvent,\n  getStackTrace,\n  printError\n} from './Error.ts';\nimport { noop } from './Function.ts';\n\n/**\n * A type representing a function that resolves a {@link Promise}.\n *\n * @typeParam T - The type of the value.\n */\nexport type PromiseResolve<T> = undefined extends T ? (value?: PromiseLike<T> | T) => void\n  : (value: PromiseLike<T> | T) => void;\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 * Adds an error handler to a {@link 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 * @param stackTrace - The stack trace of the source function.\n * @returns A {@link Promise} that resolves when the asynchronous function completes or emits async error event.\n */\nexport async function addErrorHandler(asyncFn: () => Promise<unknown>, stackTrace?: string): Promise<void> {\n  stackTrace ??= getStackTrace(1);\n  try {\n    await asyncFn();\n  } catch (asyncError) {\n    emitAsyncErrorEvent(new CustomStackTraceError(ASYNC_WRAPPER_ERROR_MESSAGE, stackTrace, 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 {@link 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[]) => Promisable<boolean>): Promise<T[]> {\n  const ans: T[] = [];\n\n  const length = arr.length;\n  for (let i = 0; i < length; i++) {\n    if (!Object.hasOwn(arr, i)) {\n      continue;\n    }\n\n    const item = arr[i] as T;\n    if (await predicate(item, i, arr)) {\n      ans.push(item);\n    }\n  }\n\n  return ans;\n}\n\n/**\n * Filters an array asynchronously in place, 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 {@link Promise} that resolves when the array is filtered.\n */\nexport async function asyncFilterInPlace<T>(arr: T[], predicate: (value: T, index: number, array: T[]) => Promisable<boolean>): Promise<void> {\n  const length = arr.length;\n  let writeIndex = 0;\n  for (let readIndex = 0; readIndex < length; readIndex++) {\n    if (!Object.hasOwn(arr, readIndex)) {\n      continue;\n    }\n\n    const current = arr[readIndex] as T;\n    if (await predicate(current, readIndex, arr)) {\n      // eslint-disable-next-line require-atomic-updates\n      arr[writeIndex++] = current;\n    }\n  }\n  arr.length = writeIndex;\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 {@link 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[]) => Promisable<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 {@link 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[]) => Promisable<U>): Promise<U[]> {\n  return await promiseAllSequentially(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 * @param stackTrace - The stack trace of the source function.\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>, stackTrace?: string): (...args: Args) => void {\n  stackTrace ??= getStackTrace(1);\n  return (...args: Args): void => {\n    const innerStackTrace = getStackTrace(1);\n    stackTrace = `${stackTrace ?? ''}\\n    at --- convertAsyncToSync --- (0)\\n${innerStackTrace}`;\n    invokeAsyncSafely(() => asyncFunc(...args), stackTrace);\n  };\n}\n\n/**\n * Converts a synchronous function to an asynchronous one by wrapping it in a {@link 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 async (...args: Args): Promise<Result> => {\n    await Promise.resolve();\n    return syncFn(...args);\n  };\n}\n\n/**\n * Ignores an error that is thrown by an asynchronous function.\n *\n * @param promise - The promise to ignore the error of.\n * @param fallbackValue - Always `undefined`.\n * @returns A {@link Promise} that resolves when the asynchronous function completes or fails.\n */\nexport async function ignoreError(promise: Promise<unknown>, fallbackValue?: undefined): Promise<void>;\n\n/**\n * Invokes an asynchronous function and returns a fallback value if an error is thrown.\n *\n * @typeParam T - The type of the value returned by the asynchronous function.\n * @param promise - The promise to ignore the error of.\n * @param fallbackValue - The value to return if an error is thrown.\n * @returns A {@link Promise} that resolves with the value returned by the asynchronous function or the fallback value if an error is thrown.\n */\nexport async function ignoreError<T>(promise: Promise<T>, fallbackValue: T): Promise<T> {\n  const ignoreErrorDebugger = getLibDebugger('Async:ignoreError');\n  const stackTrace = getStackTrace(1);\n  try {\n    return await promise;\n  } catch (e) {\n    ignoreErrorDebugger('Ignored error', new CustomStackTraceError('Ignored error', stackTrace, e));\n    return fallbackValue;\n  }\n}\n\n/**\n * Invokes a {@link 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 * @param stackTrace - The stack trace of the source function.\n */\nexport function invokeAsyncSafely(asyncFn: () => Promise<unknown>, stackTrace?: string): void {\n  stackTrace ??= getStackTrace(1);\n  // eslint-disable-next-line no-void\n  void addErrorHandler(asyncFn, stackTrace);\n}\n\n/**\n * Invokes an asynchronous function after a delay.\n *\n * @param asyncFn - The asynchronous function to invoke.\n * @param delayInMilliseconds - The delay in milliseconds.\n * @param stackTrace - The stack trace of the source function.\n * @param abortSignal - The abort signal to listen to.\n */\nexport function invokeAsyncSafelyAfterDelay(\n  asyncFn: (abortSignal: AbortSignal) => Promisable<void>,\n  delayInMilliseconds = 0,\n  stackTrace?: string,\n  abortSignal?: AbortSignal\n): void {\n  abortSignal ??= abortSignalNever();\n  abortSignal.throwIfAborted();\n  stackTrace ??= getStackTrace(1);\n  invokeAsyncSafely(async () => {\n    await sleep(delayInMilliseconds, abortSignal, true);\n    await asyncFn(abortSignal);\n  }, stackTrace);\n}\n\n/**\n * Executes async functions sequentially.\n *\n * @typeParam T - The type of the value.\n * @param asyncFns - The async functions to execute sequentially.\n * @returns A {@link Promise} that resolves with an array of the results of the async functions.\n */\nexport async function promiseAllAsyncFnsSequentially<T>(asyncFns: (() => Promisable<T>)[]): Promise<T[]> {\n  const results: T[] = [];\n  for (const asyncFn of asyncFns) {\n    results.push(await asyncFn());\n  }\n  return results;\n}\n\n/**\n * Executes promises sequentially.\n *\n * @typeParam T - The type of the value.\n * @param promises - The promises to execute sequentially.\n * @returns A {@link Promise} that resolves with an array of the results of the promises.\n */\nexport async function promiseAllSequentially<T>(promises: Promisable<T>[]): Promise<T[]> {\n  return await promiseAllAsyncFnsSequentially(promises.map((promise) => () => promise));\n}\n\nconst terminateRetryErrors = new WeakSet<Error>();\n\nclass Result<R> {\n  public constructor(public readonly result: R) {}\n}\n\n/**\n * Marks an error to terminate retry logic.\n *\n * @param error - The error to mark to terminate retry logic.\n */\nexport function marksAsTerminateRetry(error: Error): void {\n  terminateRetryErrors.add(error);\n}\n\n/**\n * An async function that never ends.\n *\n * @returns A {@link Promise} that never resolves.\n */\nexport async function neverEnds(): Promise<never> {\n  await new Promise(() => {\n    noop();\n  });\n  throw new Error('Should never happen');\n}\n\n/**\n * Gets the next tick.\n *\n * @returns A promise that resolves when the next tick is available.\n */\nexport async function nextTickAsync(): Promise<void> {\n  return new Promise((resolve) => {\n    process.nextTick(() => {\n      resolve();\n    });\n  });\n}\n\n/**\n * Gets the next queue microtask.\n *\n * @returns A promise that resolves when the next queue microtask is available.\n */\nexport async function queueMicrotaskAsync(): Promise<void> {\n  return new Promise((resolve) => {\n    queueMicrotask(() => {\n      resolve();\n    });\n  });\n}\n\n/**\n * Gets the next request animation frame.\n *\n * @returns A promise that resolves when the next request animation frame is available.\n */\nexport async function requestAnimationFrameAsync(): Promise<void> {\n  return new Promise((resolve) => {\n    requestAnimationFrame(() => {\n      resolve();\n    });\n  });\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 {@link Promise} that resolves when the function returns true or rejects when the timeout is reached.\n */\nexport async function retryWithTimeout(fn: (abortSignal: AbortSignal) => Promisable<boolean>, retryOptions?: RetryOptions, stackTrace?: string): Promise<void> {\n  const retryWithTimeoutDebugger = getLibDebugger('Async:retryWithTimeout');\n  stackTrace ??= getStackTrace(1);\n  const DEFAULT_RETRY_OPTIONS = {\n    abortSignal: abortSignalNever(),\n    // eslint-disable-next-line no-magic-numbers\n    retryDelayInMilliseconds: 100,\n    shouldRetryOnError: false,\n    // eslint-disable-next-line no-magic-numbers\n    timeoutInMilliseconds: 5000\n  };\n  const fullOptions = { ...DEFAULT_RETRY_OPTIONS, ...retryOptions };\n  fullOptions.abortSignal.throwIfAborted();\n\n  await runWithTimeout(\n    fullOptions.timeoutInMilliseconds,\n    async (abortSignal: AbortSignal) => {\n      const combinedAbortSignal = abortSignalAny([fullOptions.abortSignal, abortSignal]);\n      combinedAbortSignal.throwIfAborted();\n      let attempt = 0;\n      while (!combinedAbortSignal.aborted) {\n        attempt++;\n        let isSuccess: boolean;\n        try {\n          isSuccess = await fn(combinedAbortSignal);\n        } catch (error) {\n          // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n          if (combinedAbortSignal.aborted || !fullOptions.shouldRetryOnError || terminateRetryErrors.has(error as Error)) {\n            throw new CustomStackTraceError('retryWithTimeout failed', stackTrace, error);\n          }\n          printError(error);\n          isSuccess = false;\n        }\n        if (isSuccess) {\n          retryWithTimeoutDebugger(`Retry completed successfully after ${String(attempt)} attempts`, {\n            fn\n          });\n          retryWithTimeoutDebugger.printStackTrace(stackTrace);\n          return;\n        }\n\n        retryWithTimeoutDebugger(\n          `Retry attempt ${String(attempt)} completed unsuccessfully. Trying again in ${String(fullOptions.retryDelayInMilliseconds)} milliseconds`,\n          {\n            fn\n          }\n        );\n        retryWithTimeoutDebugger.printStackTrace(stackTrace);\n        await sleep(fullOptions.retryDelayInMilliseconds);\n      }\n    },\n    { retryFn: fn },\n    stackTrace\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 * @param context - The context of the function.\n * @param stackTrace - The stack trace of the source function.\n * @returns A {@link Promise} that resolves with the result of the asynchronous function or rejects if it times out.\n */\nexport async function runWithTimeout<R>(\n  timeoutInMilliseconds: number,\n  fn: (abortSignal: AbortSignal) => Promisable<R>,\n  context?: unknown,\n  stackTrace?: string\n): Promise<R> {\n  stackTrace ??= getStackTrace(1);\n  const startTime = performance.now();\n\n  const abortController = new AbortController();\n\n  await Promise.race([run(), innerTimeout()]);\n  if (abortController.signal.reason instanceof Result) {\n    return abortController.signal.reason.result as R;\n  }\n\n  throw new CustomStackTraceError('Run with timeout failed', stackTrace, abortController.signal.reason as unknown);\n\n  async function run(): Promise<void> {\n    try {\n      const result = await fn(abortController.signal);\n      const duration = performance.now() - startTime;\n      const runWithTimeoutDebugger = getLibDebugger('Async:runWithTimeout');\n      runWithTimeoutDebugger(`Execution time: ${String(duration)} milliseconds`, { context, fn });\n      runWithTimeoutDebugger.printStackTrace(stackTrace ?? '');\n      abortController.abort(new Result(result));\n    } catch (e) {\n      abortController.abort(e);\n    }\n  }\n\n  async function innerTimeout(): Promise<void> {\n    while (!abortController.signal.aborted) {\n      await sleep(timeoutInMilliseconds, abortController.signal);\n      // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n      if (abortController.signal.aborted) {\n        return;\n      }\n      const duration = performance.now() - startTime;\n      console.warn(`Timed out after ${String(duration)} milliseconds`, { context, fn });\n      const timeoutDebugger = getLibDebugger('Async:runWithTimeout:timeout');\n      if (!timeoutDebugger.enabled) {\n        abortController.abort(new Error(`Timed out after ${String(duration)} milliseconds`));\n        return;\n      }\n\n      timeoutDebugger(\n        `The execution is not terminated because debugger ${timeoutDebugger.namespace} is enabled. See https://github.com/mnaoumov/obsidian-dev-utils/blob/main/docs/debugging.md for more information`\n      );\n    }\n  }\n}\n\n/**\n * Gets the next set immediate.\n *\n * @returns A promise that resolves when the next set immediate is available.\n */\nexport async function setImmediateAsync(): Promise<void> {\n  return new Promise((resolve) => {\n    setImmediate(() => {\n      resolve();\n    });\n  });\n}\n\n/**\n * Delays execution for a specified number of milliseconds.\n *\n * @param delay - The time to wait in milliseconds.\n * @returns A {@link Promise} that resolves after the specified delay.\n */\nexport async function setTimeoutAsync(delay?: number): Promise<void> {\n  await new Promise((resolve) => {\n    setTimeout(resolve, delay);\n  });\n}\n\n/**\n * Delays execution for a specified number of milliseconds.\n *\n * @param milliseconds - The time to wait in milliseconds.\n * @param abortSignal - The abort signal to listen to.\n * @param shouldThrowOnAbort - Whether to throw an error if the abort signal is aborted.\n * @returns A {@link Promise} that resolves after the specified delay.\n */\nexport async function sleep(milliseconds: number, abortSignal?: AbortSignal, shouldThrowOnAbort?: boolean): Promise<void> {\n  await waitForAbort(abortSignalAny([abortSignal ?? abortSignalNever(), abortSignalTimeout(milliseconds)]));\n  if (shouldThrowOnAbort) {\n    abortSignal?.throwIfAborted();\n  }\n}\n\n/**\n * Returns a {@link Promise} that rejects after the specified timeout period.\n *\n * @param timeoutInMilliseconds - The timeout period in milliseconds.\n * @param abortSignal - The abort signal to listen to.\n * @param shouldThrowOnAbort - Whether to throw an error if the abort signal is aborted.\n * @returns A {@link Promise} that always rejects with a timeout error.\n */\nexport async function timeout(timeoutInMilliseconds: number, abortSignal?: AbortSignal, shouldThrowOnAbort?: boolean): Promise<never> {\n  await sleep(timeoutInMilliseconds, abortSignal, shouldThrowOnAbort);\n  throw new Error(`Timed out in ${String(timeoutInMilliseconds)} 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 {@link 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": []
}

|