nalloc 0.0.1 → 0.0.2
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/README.md +124 -38
- package/build/index.cjs +12 -68
- package/build/index.cjs.map +1 -1
- package/build/index.d.ts +1 -4
- package/build/index.js +1 -3
- package/build/index.js.map +1 -1
- package/build/iter.cjs +105 -0
- package/build/iter.cjs.map +1 -0
- package/build/iter.d.ts +61 -0
- package/build/iter.js +78 -0
- package/build/iter.js.map +1 -0
- package/build/option.cjs +19 -5
- package/build/option.cjs.map +1 -1
- package/build/option.d.ts +22 -1
- package/build/option.js +14 -6
- package/build/option.js.map +1 -1
- package/build/result.cjs +125 -54
- package/build/result.cjs.map +1 -1
- package/build/result.d.ts +83 -53
- package/build/result.js +100 -38
- package/build/result.js.map +1 -1
- package/build/safe.cjs +34 -15
- package/build/safe.cjs.map +1 -1
- package/build/safe.d.ts +4 -27
- package/build/safe.js +3 -14
- package/build/safe.js.map +1 -1
- package/build/types.cjs +38 -7
- package/build/types.cjs.map +1 -1
- package/build/types.d.ts +26 -4
- package/build/types.js +23 -7
- package/build/types.js.map +1 -1
- package/build/unsafe.cjs +14 -61
- package/build/unsafe.cjs.map +1 -1
- package/build/unsafe.d.ts +2 -27
- package/build/unsafe.js +2 -9
- package/build/unsafe.js.map +1 -1
- package/package.json +13 -16
- package/src/__tests__/index.ts +42 -0
- package/src/__tests__/iter.ts +218 -0
- package/src/__tests__/option.ts +48 -19
- package/src/__tests__/result.ts +286 -91
- package/src/__tests__/result.types.ts +3 -22
- package/src/__tests__/safe.ts +9 -15
- package/src/__tests__/unsafe.ts +11 -12
- package/src/index.ts +1 -18
- package/src/iter.ts +129 -0
- package/src/option.ts +36 -7
- package/src/result.ts +216 -113
- package/src/safe.ts +5 -42
- package/src/types.ts +52 -14
- package/src/unsafe.ts +2 -47
- package/build/devtools.cjs +0 -79
- package/build/devtools.cjs.map +0 -1
- package/build/devtools.d.ts +0 -82
- package/build/devtools.js +0 -43
- package/build/devtools.js.map +0 -1
- package/build/testing.cjs +0 -111
- package/build/testing.cjs.map +0 -1
- package/build/testing.d.ts +0 -85
- package/build/testing.js +0 -81
- package/build/testing.js.map +0 -1
- package/src/__tests__/tooling.ts +0 -86
- package/src/devtools.ts +0 -97
- package/src/testing.ts +0 -159
package/build/result.cjs
CHANGED
|
@@ -18,9 +18,6 @@ _export(exports, {
|
|
|
18
18
|
get andThen () {
|
|
19
19
|
return andThen;
|
|
20
20
|
},
|
|
21
|
-
get andThenAsync () {
|
|
22
|
-
return andThenAsync;
|
|
23
|
-
},
|
|
24
21
|
get any () {
|
|
25
22
|
return any;
|
|
26
23
|
},
|
|
@@ -45,15 +42,18 @@ _export(exports, {
|
|
|
45
42
|
get expectErr () {
|
|
46
43
|
return expectErr;
|
|
47
44
|
},
|
|
45
|
+
get filterErr () {
|
|
46
|
+
return filterErr;
|
|
47
|
+
},
|
|
48
|
+
get filterOk () {
|
|
49
|
+
return filterOk;
|
|
50
|
+
},
|
|
48
51
|
get flatMap () {
|
|
49
52
|
return flatMap;
|
|
50
53
|
},
|
|
51
54
|
get flatten () {
|
|
52
55
|
return flatten;
|
|
53
56
|
},
|
|
54
|
-
get fromPromise () {
|
|
55
|
-
return fromPromise;
|
|
56
|
-
},
|
|
57
57
|
get isErr () {
|
|
58
58
|
return _typescjs.isErr;
|
|
59
59
|
},
|
|
@@ -72,9 +72,6 @@ _export(exports, {
|
|
|
72
72
|
get map () {
|
|
73
73
|
return map;
|
|
74
74
|
},
|
|
75
|
-
get mapAsync () {
|
|
76
|
-
return mapAsync;
|
|
77
|
-
},
|
|
78
75
|
get mapErr () {
|
|
79
76
|
return mapErr;
|
|
80
77
|
},
|
|
@@ -87,15 +84,9 @@ _export(exports, {
|
|
|
87
84
|
get match () {
|
|
88
85
|
return match;
|
|
89
86
|
},
|
|
90
|
-
get matchAsync () {
|
|
91
|
-
return matchAsync;
|
|
92
|
-
},
|
|
93
87
|
get of () {
|
|
94
88
|
return of;
|
|
95
89
|
},
|
|
96
|
-
get ofAsync () {
|
|
97
|
-
return ofAsync;
|
|
98
|
-
},
|
|
99
90
|
get or () {
|
|
100
91
|
return or;
|
|
101
92
|
},
|
|
@@ -108,6 +99,24 @@ _export(exports, {
|
|
|
108
99
|
get partitionAsync () {
|
|
109
100
|
return partitionAsync;
|
|
110
101
|
},
|
|
102
|
+
get partitionMaybePromise () {
|
|
103
|
+
return partitionMaybePromise;
|
|
104
|
+
},
|
|
105
|
+
get partitionMaybePromiseAsync () {
|
|
106
|
+
return partitionMaybePromiseAsync;
|
|
107
|
+
},
|
|
108
|
+
get safeTry () {
|
|
109
|
+
return safeTry;
|
|
110
|
+
},
|
|
111
|
+
get safeTryAsync () {
|
|
112
|
+
return safeTryAsync;
|
|
113
|
+
},
|
|
114
|
+
get settleMaybePromise () {
|
|
115
|
+
return settleMaybePromise;
|
|
116
|
+
},
|
|
117
|
+
get settledToResult () {
|
|
118
|
+
return settledToResult;
|
|
119
|
+
},
|
|
111
120
|
get tap () {
|
|
112
121
|
return tap;
|
|
113
122
|
},
|
|
@@ -123,12 +132,12 @@ _export(exports, {
|
|
|
123
132
|
get transpose () {
|
|
124
133
|
return transpose;
|
|
125
134
|
},
|
|
126
|
-
get tryAsync () {
|
|
127
|
-
return tryAsync;
|
|
128
|
-
},
|
|
129
135
|
get tryCatch () {
|
|
130
136
|
return tryCatch;
|
|
131
137
|
},
|
|
138
|
+
get tryCatchMaybePromise () {
|
|
139
|
+
return tryCatchMaybePromise;
|
|
140
|
+
},
|
|
132
141
|
get unwrap () {
|
|
133
142
|
return unwrap;
|
|
134
143
|
},
|
|
@@ -162,23 +171,17 @@ function tryCatch(fn, onError) {
|
|
|
162
171
|
function of(fn) {
|
|
163
172
|
return tryCatch(fn);
|
|
164
173
|
}
|
|
165
|
-
|
|
174
|
+
function tryCatchMaybePromise(fn, onError) {
|
|
166
175
|
try {
|
|
167
|
-
|
|
176
|
+
const result = fn();
|
|
177
|
+
if ((0, _typescjs.isThenable)(result)) {
|
|
178
|
+
return Promise.resolve(result).then((value)=>value, (error)=>(0, _typescjs.err)(onError ? onError(error) : error));
|
|
179
|
+
}
|
|
180
|
+
return result;
|
|
168
181
|
} catch (error) {
|
|
169
182
|
return (0, _typescjs.err)(onError ? onError(error) : error);
|
|
170
183
|
}
|
|
171
184
|
}
|
|
172
|
-
function ofAsync(fn) {
|
|
173
|
-
return tryAsync(fn);
|
|
174
|
-
}
|
|
175
|
-
async function fromPromise(promise, onRejected) {
|
|
176
|
-
try {
|
|
177
|
-
return await promise;
|
|
178
|
-
} catch (error) {
|
|
179
|
-
return (0, _typescjs.err)(onRejected ? onRejected(error) : error);
|
|
180
|
-
}
|
|
181
|
-
}
|
|
182
185
|
function unwrapOrReturn(result, onErr) {
|
|
183
186
|
return (0, _typescjs.isOk)(result) ? result : onErr(result.error);
|
|
184
187
|
}
|
|
@@ -208,7 +211,7 @@ function flatMap(result, fn) {
|
|
|
208
211
|
return fn(result);
|
|
209
212
|
}
|
|
210
213
|
function andThen(result, fn) {
|
|
211
|
-
return
|
|
214
|
+
return (0, _typescjs.isErr)(result) ? result : fn(result);
|
|
212
215
|
}
|
|
213
216
|
function tap(result, fn) {
|
|
214
217
|
if ((0, _typescjs.isOk)(result)) {
|
|
@@ -226,9 +229,7 @@ function bimap(result, okFn, errFn) {
|
|
|
226
229
|
return (0, _typescjs.isOk)(result) ? okFn(result) : (0, _typescjs.err)(errFn(result.error));
|
|
227
230
|
}
|
|
228
231
|
function unwrap(result) {
|
|
229
|
-
if ((0, _typescjs.isErr)(result))
|
|
230
|
-
throw new Error(`Called unwrap on Err: ${String(result.error)}`);
|
|
231
|
-
}
|
|
232
|
+
if ((0, _typescjs.isErr)(result)) throw result.error;
|
|
232
233
|
return result;
|
|
233
234
|
}
|
|
234
235
|
function unwrapErr(result) {
|
|
@@ -310,12 +311,24 @@ function partition(results) {
|
|
|
310
311
|
errs
|
|
311
312
|
];
|
|
312
313
|
}
|
|
314
|
+
function filterOk(results) {
|
|
315
|
+
const oks = [];
|
|
316
|
+
for (const result of results){
|
|
317
|
+
if ((0, _typescjs.isOk)(result)) oks.push(result);
|
|
318
|
+
}
|
|
319
|
+
return oks;
|
|
320
|
+
}
|
|
321
|
+
function filterErr(results) {
|
|
322
|
+
const errs = [];
|
|
323
|
+
for (const result of results){
|
|
324
|
+
if ((0, _typescjs.isErr)(result)) errs.push(result.error);
|
|
325
|
+
}
|
|
326
|
+
return errs;
|
|
327
|
+
}
|
|
313
328
|
function collect(results) {
|
|
314
329
|
const values = [];
|
|
315
330
|
for (const result of results){
|
|
316
|
-
if ((0, _typescjs.isErr)(result))
|
|
317
|
-
return result;
|
|
318
|
-
}
|
|
331
|
+
if ((0, _typescjs.isErr)(result)) return result;
|
|
319
332
|
values.push(result);
|
|
320
333
|
}
|
|
321
334
|
return values;
|
|
@@ -328,12 +341,11 @@ function all(results) {
|
|
|
328
341
|
return collect(results);
|
|
329
342
|
}
|
|
330
343
|
function any(results) {
|
|
331
|
-
const
|
|
332
|
-
|
|
333
|
-
for(let i = 0; i < len; i++){
|
|
344
|
+
const errors = [];
|
|
345
|
+
for(let i = 0; i < results.length; i++){
|
|
334
346
|
const result = results[i];
|
|
335
347
|
if ((0, _typescjs.isOk)(result)) return result;
|
|
336
|
-
errors
|
|
348
|
+
errors.push(result.error);
|
|
337
349
|
}
|
|
338
350
|
return (0, _typescjs.err)(errors);
|
|
339
351
|
}
|
|
@@ -350,22 +362,47 @@ function isOkAnd(result, predicate) {
|
|
|
350
362
|
function isErrAnd(result, predicate) {
|
|
351
363
|
return (0, _typescjs.isErr)(result) && predicate(result.error);
|
|
352
364
|
}
|
|
353
|
-
|
|
354
|
-
if (
|
|
355
|
-
return
|
|
365
|
+
function settledToResult(result) {
|
|
366
|
+
if (result.status === 'fulfilled') return result.value;
|
|
367
|
+
return (0, _typescjs.err)(result.reason);
|
|
356
368
|
}
|
|
357
|
-
async function
|
|
358
|
-
|
|
359
|
-
return
|
|
369
|
+
async function partitionAsync(promises) {
|
|
370
|
+
const settled = await Promise.allSettled(promises);
|
|
371
|
+
return partition(settled.map(settledToResult));
|
|
360
372
|
}
|
|
361
|
-
|
|
362
|
-
|
|
373
|
+
function settleMaybePromise(values) {
|
|
374
|
+
const len = values.length;
|
|
375
|
+
const results = new Array(len);
|
|
376
|
+
let pendingIndices;
|
|
377
|
+
let pendingPromises;
|
|
378
|
+
for(let i = 0; i < len; i++){
|
|
379
|
+
const v = values[i];
|
|
380
|
+
if ((0, _typescjs.isThenable)(v)) {
|
|
381
|
+
(pendingIndices ??= []).push(i);
|
|
382
|
+
(pendingPromises ??= []).push(Promise.resolve(v));
|
|
383
|
+
} else {
|
|
384
|
+
results[i] = v;
|
|
385
|
+
}
|
|
386
|
+
}
|
|
387
|
+
if (!pendingPromises) return results;
|
|
388
|
+
return Promise.allSettled(pendingPromises).then((settled)=>{
|
|
389
|
+
for(let i = 0; i < settled.length; i++){
|
|
390
|
+
const s = settled[i];
|
|
391
|
+
results[pendingIndices[i]] = s.status === 'fulfilled' ? s.value : (0, _typescjs.err)(s.reason);
|
|
392
|
+
}
|
|
393
|
+
return results;
|
|
394
|
+
});
|
|
363
395
|
}
|
|
364
|
-
async function
|
|
365
|
-
const
|
|
366
|
-
const
|
|
367
|
-
for
|
|
368
|
-
const
|
|
396
|
+
async function partitionMaybePromiseAsync(values, oks, errs, startIndex = 0) {
|
|
397
|
+
const suffixLength = values.length - startIndex;
|
|
398
|
+
const pending = new Array(suffixLength);
|
|
399
|
+
for(let i = 0; i < suffixLength; i++){
|
|
400
|
+
const value = values[startIndex + i];
|
|
401
|
+
pending[i] = Promise.resolve(value).then((result)=>result, (error)=>(0, _typescjs.err)(error));
|
|
402
|
+
}
|
|
403
|
+
const resolved = await Promise.all(pending);
|
|
404
|
+
for(let i = 0; i < resolved.length; i++){
|
|
405
|
+
const result = resolved[i];
|
|
369
406
|
if ((0, _typescjs.isOk)(result)) {
|
|
370
407
|
oks.push(result);
|
|
371
408
|
} else {
|
|
@@ -377,5 +414,39 @@ async function partitionAsync(results) {
|
|
|
377
414
|
errs
|
|
378
415
|
];
|
|
379
416
|
}
|
|
417
|
+
function partitionMaybePromise(values) {
|
|
418
|
+
const len = values.length;
|
|
419
|
+
const oks = [];
|
|
420
|
+
const errs = [];
|
|
421
|
+
for(let i = 0; i < len; i++){
|
|
422
|
+
const value = values[i];
|
|
423
|
+
if ((0, _typescjs.isThenable)(value)) {
|
|
424
|
+
return partitionMaybePromiseAsync(values, oks, errs, i);
|
|
425
|
+
}
|
|
426
|
+
if ((0, _typescjs.isOk)(value)) {
|
|
427
|
+
oks.push(value);
|
|
428
|
+
} else {
|
|
429
|
+
errs.push(value.error);
|
|
430
|
+
}
|
|
431
|
+
}
|
|
432
|
+
return [
|
|
433
|
+
oks,
|
|
434
|
+
errs
|
|
435
|
+
];
|
|
436
|
+
}
|
|
437
|
+
function safeTry(fn) {
|
|
438
|
+
try {
|
|
439
|
+
return fn();
|
|
440
|
+
} catch (e) {
|
|
441
|
+
return (0, _typescjs.err)(e);
|
|
442
|
+
}
|
|
443
|
+
}
|
|
444
|
+
async function safeTryAsync(fn) {
|
|
445
|
+
try {
|
|
446
|
+
return await fn();
|
|
447
|
+
} catch (e) {
|
|
448
|
+
return (0, _typescjs.err)(e);
|
|
449
|
+
}
|
|
450
|
+
}
|
|
380
451
|
|
|
381
452
|
//# sourceMappingURL=result.cjs.map
|
package/build/result.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/result.ts"],"sourcesContent":["import { err as ERR, isOk, isErr, isSome, isNone, NONE, optionOf } from './types.js';\nimport type { Ok, Err, Result, Option, Widen, WidenNever } from './types.js';\n\nexport type { Ok, Err, Result };\nexport { isOk, isErr };\n\n/**\n * Executes a function and captures the result or error.\n * @param fn - Function to execute\n * @param onError - Optional error transformer\n * @returns Ok(result) if successful, Err(error) if thrown\n * @example\n * tryCatch(() => JSON.parse('{\"a\":1}')) // Ok({a: 1})\n * tryCatch(() => JSON.parse('invalid')) // Err(SyntaxError)\n * tryCatch(() => { throw 'oops' }, e => e) // Err('oops')\n */\nexport function tryCatch<T, E = unknown>(fn: () => T, onError?: (error: unknown) => E): Result<T, E> {\n try {\n return fn() as Ok<T>;\n } catch (error) {\n return ERR(onError ? onError(error) : (error as E));\n }\n}\n\n/**\n * Alias for tryCatch. Executes a function and captures the result or error.\n * @param fn - Function to execute\n * @returns Ok(result) if successful, Err(error) if thrown\n */\nexport function of<T, E = unknown>(fn: () => T): Result<T, E> {\n return tryCatch(fn);\n}\n\n/**\n * Executes an async function and captures the result or error.\n * @param fn - Async function to execute\n * @param onError - Optional error transformer\n * @returns Promise of Ok(result) if successful, Err(error) if rejected\n * @example\n * await tryAsync(() => fetch('/api').then(r => r.json())) // Ok(data) or Err(error)\n */\nexport async function tryAsync<T, E = unknown>(fn: () => Promise<T>, onError?: (error: unknown) => E): Promise<Result<T, E>> {\n try {\n return (await fn()) as Ok<T>;\n } catch (error) {\n return ERR(onError ? onError(error) : (error as E));\n }\n}\n\n/**\n * Alias for tryAsync. Executes an async function and captures the result or error.\n * @param fn - Async function to execute\n * @returns Promise of Ok(result) if successful, Err(error) if rejected\n */\nexport function ofAsync<T, E = unknown>(fn: () => Promise<T>): Promise<Result<T, E>> {\n return tryAsync(fn);\n}\n\n/**\n * Converts a Promise to a Result.\n * @param promise - The promise to convert\n * @param onRejected - Optional rejection handler\n * @returns Promise of Ok(value) if resolved, Err(error) if rejected\n * @example\n * await fromPromise(Promise.resolve(42)) // Ok(42)\n * await fromPromise(Promise.reject('error')) // Err('error')\n */\nexport async function fromPromise<T, E = unknown>(promise: Promise<T>, onRejected?: (reason: unknown) => E): Promise<Result<T, E>> {\n try {\n return (await promise) as Ok<T>;\n } catch (error) {\n return ERR(onRejected ? onRejected(error) : (error as E));\n }\n}\n\n/**\n * Unwraps an Ok value or returns a computed value for Err.\n * @param result - The Result to unwrap\n * @param onErr - Function called with error if Err\n * @returns The Ok value or result of onErr(error)\n * @example\n * unwrapOrReturn(ok(42), e => 0) // 42\n * unwrapOrReturn(err('fail'), e => 0) // 0\n */\nexport function unwrapOrReturn<T, E, const R>(result: Result<T, E>, onErr: (error: E) => R): T | R {\n return isOk(result) ? result : onErr(result.error);\n}\n\n/**\n * Asserts that a Result is Ok, throwing if Err.\n * @param result - The Result to assert\n * @param message - Custom error message\n * @throws Error if result is Err\n * @example\n * assertOk(ok(42)) // passes\n * assertOk(err('failed')) // throws Error\n */\nexport function assertOk<T, E>(result: Result<T, E>, message?: string): asserts result is Ok<T> {\n if (isErr(result)) {\n throw new Error(message ?? `Expected Ok result. Received error: ${String((result as Err<E>).error)}`);\n }\n}\n\n/**\n * Asserts that a Result is Err, throwing if Ok.\n * @param result - The Result to assert\n * @param message - Custom error message\n * @throws Error if result is Ok\n * @example\n * assertErr(err('failed')) // passes\n * assertErr(ok(42)) // throws Error\n */\nexport function assertErr<T, E>(result: Result<T, E>, message?: string): asserts result is Err<E> {\n if (isOk(result)) {\n throw new Error(message ?? 'Expected Err result.');\n }\n}\n\n/**\n * Checks if result is Err with a non-null error value.\n * @param result - The Result to check\n * @returns true if Err with Some error value\n */\nexport function isSomeErr<T, E>(result: Result<T, E>): boolean {\n return isErr(result) && isSome((result as Err<E>).error);\n}\n\n/**\n * Transforms the Ok value, leaving Err unchanged.\n * @param result - The Result to map\n * @param fn - Transform function\n * @returns Ok(fn(value)) if Ok, Err unchanged\n * @example\n * map(ok(2), x => x * 2) // Ok(4)\n * map(err('e'), x => x * 2) // Err('e')\n */\nexport function map<T, U, E>(result: Err<E>, fn: (value: T) => U): Err<E>;\nexport function map<T, U>(result: Ok<T>, fn: (value: T) => U): Ok<U>;\nexport function map<T, U, E>(result: Result<T, E>, fn: (value: T) => U): Result<U, E>;\nexport function map<T, U, E>(result: Result<T, E>, fn: (value: T) => U): Result<U, E> {\n if (isErr(result)) return result as Err<E>;\n return fn(result as Ok<T>) as Ok<U>;\n}\n\n/**\n * Transforms the Err value, leaving Ok unchanged.\n * @param result - The Result to map\n * @param fn - Error transform function\n * @returns Err(fn(error)) if Err, Ok unchanged\n * @example\n * mapErr(err('e'), e => e.toUpperCase()) // Err('E')\n * mapErr(ok(42), e => e.toUpperCase()) // Ok(42)\n */\nexport function mapErr<T, E, F>(result: Ok<T>, fn: (error: E) => F): Ok<T>;\nexport function mapErr<E, F>(result: Err<E>, fn: (error: E) => F): Err<F>;\nexport function mapErr<T, E, F>(result: Result<T, E>, fn: (error: E) => F): Result<T, F>;\nexport function mapErr<T, E, F>(result: Result<T, E>, fn: (error: E) => F): Result<T, F> {\n if (isOk(result)) return result;\n return ERR(fn(result.error));\n}\n\n/**\n * Chains Result-returning functions. Returns Err if the input is Err.\n * @param result - The Result to chain\n * @param fn - Function returning a Result\n * @returns The result of fn(value) if Ok, Err unchanged\n * @example\n * flatMap(ok(2), x => ok(x * 2)) // Ok(4)\n * flatMap(ok(2), x => err('fail')) // Err('fail')\n * flatMap(err('e'), x => ok(x * 2)) // Err('e')\n */\nexport function flatMap<T, U, E>(result: Err<E>, fn: (value: T) => Result<U, E>): Err<E>;\nexport function flatMap<T, U, E>(result: Result<T, E>, fn: (value: T) => Result<U, E>): Result<U, E>;\nexport function flatMap<T, U, E>(result: Result<T, E>, fn: (value: T) => Result<U, E>): Result<U, E> {\n if (isErr(result)) return result as Err<E>;\n return fn(result as Ok<T>);\n}\n\n/**\n * Alias for flatMap. Chains Result-returning functions.\n * @param result - The Result to chain\n * @param fn - Function returning a Result\n * @returns The result of fn(value) if Ok, Err unchanged\n */\nexport function andThen<T, U, E>(result: Err<E>, fn: (value: T) => Result<U, E>): Err<E>;\nexport function andThen<T, U, E>(result: Result<T, E>, fn: (value: T) => Result<U, E>): Result<U, E>;\nexport function andThen<T, U, E>(result: Result<T, E>, fn: (value: T) => Result<U, E>): Result<U, E> {\n return flatMap(result, fn);\n}\n\n/**\n * Executes a side effect if Ok, then returns the original Result.\n * @param result - The Result to tap\n * @param fn - Side effect function\n * @returns The original Result unchanged\n * @example\n * tap(ok(42), x => console.log(x)) // logs 42, returns Ok(42)\n */\nexport function tap<T, E>(result: Err<E>, fn: (value: T) => void): Err<E>;\nexport function tap<T>(result: Ok<T>, fn: (value: T) => void): Ok<T>;\nexport function tap<T, E>(result: Result<T, E>, fn: (value: T) => void): Result<T, E>;\nexport function tap<T, E>(result: Result<T, E>, fn: (value: T) => void): Result<T, E> {\n if (isOk(result)) {\n fn(result);\n }\n return result;\n}\n\n/**\n * Executes a side effect if Err, then returns the original Result.\n * @param result - The Result to tap\n * @param fn - Side effect function for error\n * @returns The original Result unchanged\n * @example\n * tapErr(err('fail'), e => console.log(e)) // logs 'fail', returns Err('fail')\n */\nexport function tapErr<T, E>(result: Ok<T>, fn: (error: E) => void): Ok<T>;\nexport function tapErr<E>(result: Err<E>, fn: (error: E) => void): Err<E>;\nexport function tapErr<T, E>(result: Result<T, E>, fn: (error: E) => void): Result<T, E>;\nexport function tapErr<T, E>(result: Result<T, E>, fn: (error: E) => void): Result<T, E> {\n if (isErr(result)) {\n fn((result as Err<E>).error);\n }\n return result;\n}\n\n/**\n * Maps both Ok and Err values simultaneously.\n * @param result - The Result to map\n * @param okFn - Transform for Ok value\n * @param errFn - Transform for Err value\n * @returns Ok(okFn(value)) if Ok, Err(errFn(error)) if Err\n * @example\n * bimap(ok(2), x => x * 2, e => e.toUpperCase()) // Ok(4)\n * bimap(err('e'), x => x * 2, e => e.toUpperCase()) // Err('E')\n */\nexport function bimap<T, U, E, F>(result: Ok<T>, okFn: (value: T) => U, errFn: (error: E) => F): Ok<U>;\nexport function bimap<T, U, E, F>(result: Err<E>, okFn: (value: T) => U, errFn: (error: E) => F): Err<F>;\nexport function bimap<T, U, E, F>(result: Result<T, E>, okFn: (value: T) => U, errFn: (error: E) => F): Result<U, F>;\nexport function bimap<T, U, E, F>(result: Result<T, E>, okFn: (value: T) => U, errFn: (error: E) => F): Result<U, F> {\n return isOk(result) ? (okFn(result) as Ok<U>) : ERR(errFn(result.error));\n}\n\n/**\n * Extracts the Ok value, throws if Err.\n * @param result - The Result to unwrap\n * @returns The contained Ok value\n * @throws Error if result is Err\n * @example\n * unwrap(ok(42)) // 42\n * unwrap(err('failed')) // throws Error\n */\nexport function unwrap<T, E>(result: Result<T, E>): T {\n if (isErr(result)) {\n throw new Error(`Called unwrap on Err: ${String((result as Err<E>).error)}`);\n }\n return result as T;\n}\n\n/**\n * Extracts the Err value, throws if Ok.\n * @param result - The Result to unwrap\n * @returns The contained error\n * @throws Error if result is Ok\n * @example\n * unwrapErr(err('failed')) // 'failed'\n * unwrapErr(ok(42)) // throws Error\n */\nexport function unwrapErr<T, E>(result: Result<T, E>): E {\n if (isOk(result)) {\n throw new Error(`Called unwrapErr on Ok: ${String(result)}`);\n }\n return result.error;\n}\n\n/**\n * Extracts the Ok value, or returns a default.\n * @param result - The Result to unwrap\n * @param defaultValue - Value if Err\n * @returns The Ok value or defaultValue\n * @example\n * unwrapOr(ok(42), 0) // 42\n * unwrapOr(err('failed'), 0) // 0\n */\nexport function unwrapOr<T, E>(result: Result<T, E>, defaultValue: T): T {\n return isOk(result) ? result : defaultValue;\n}\n\n/**\n * Extracts the Ok value, or computes a default from the error.\n * @param result - The Result to unwrap\n * @param fn - Function to compute default from error\n * @returns The Ok value or fn(error)\n * @example\n * unwrapOrElse(ok(42), e => 0) // 42\n * unwrapOrElse(err('failed'), e => 0) // 0\n */\nexport function unwrapOrElse<T, E>(result: Result<T, E>, fn: (error: E) => T): T {\n return isOk(result) ? result : fn(result.error);\n}\n\n/**\n * Maps the Ok value and returns it, or returns a default.\n * @param result - The Result to map\n * @param defaultValue - Value if Err\n * @param fn - Transform function\n * @returns fn(value) if Ok, defaultValue otherwise\n * @example\n * mapOr(ok(2), 0, x => x * 2) // 4\n * mapOr(err('e'), 0, x => x * 2) // 0\n */\nexport function mapOr<T, E, U>(result: Result<T, E>, defaultValue: U, fn: (value: T) => U): U {\n return isOk(result) ? fn(result) : defaultValue;\n}\n\n/**\n * Maps the Ok value and returns it, or computes a default.\n * @param result - The Result to map\n * @param defaultFn - Function to compute default\n * @param fn - Transform function\n * @returns fn(value) if Ok, defaultFn() otherwise\n * @example\n * mapOrElse(ok(2), () => 0, x => x * 2) // 4\n * mapOrElse(err('e'), () => 0, x => x * 2) // 0\n */\nexport function mapOrElse<T, E, U>(result: Result<T, E>, defaultFn: () => U, fn: (value: T) => U): U {\n return isOk(result) ? fn(result) : defaultFn();\n}\n\n/**\n * Extracts the Ok value, throws with custom message if Err.\n * @param result - The Result to unwrap\n * @param message - Error message prefix if Err\n * @returns The Ok value\n * @throws Error with message if Err\n * @example\n * expect(ok(42), 'missing value') // 42\n * expect(err('fail'), 'missing value') // throws Error('missing value: fail')\n */\nexport function expect<T, E>(result: Result<T, E>, message: string): T {\n if (isErr(result)) {\n throw new Error(`${message}: ${String((result as Err<E>).error)}`);\n }\n return result as Ok<T>;\n}\n\n/**\n * Extracts the Err value, throws with custom message if Ok.\n * @param result - The Result to unwrap\n * @param message - Error message prefix if Ok\n * @returns The error value\n * @throws Error with message if Ok\n * @example\n * expectErr(err('fail'), 'expected error') // 'fail'\n * expectErr(ok(42), 'expected error') // throws Error\n */\nexport function expectErr<T, E>(result: Result<T, E>, message: string): E {\n if (isOk(result)) {\n throw new Error(`${message}: ${String(result)}`);\n }\n return result.error;\n}\n\n/**\n * Returns other if result is Ok, otherwise returns the Err.\n * @param result - First Result\n * @param other - Second Result\n * @returns other if result is Ok, result (Err) otherwise\n * @example\n * and(ok(1), ok(2)) // Ok(2)\n * and(err('e'), ok(2)) // Err('e')\n */\nexport function and<T, U, E>(result: Result<T, E>, other: Result<U, E>): Result<U, E> {\n return isOk(result) ? other : result;\n}\n\n/**\n * Returns result if Ok, otherwise returns other.\n * @param result - First Result\n * @param other - Fallback Result\n * @returns result if Ok, other otherwise\n * @example\n * or(ok(1), ok(2)) // Ok(1)\n * or(err('e'), ok(2)) // Ok(2)\n */\nexport function or<T, E, F>(result: Result<T, E>, other: Result<T, F>): Result<T, F> {\n return isOk(result) ? result : other;\n}\n\n/**\n * Returns result if Ok, otherwise computes a fallback from the error.\n * @param result - First Result\n * @param fn - Function to compute fallback\n * @returns result if Ok, fn(error) otherwise\n * @example\n * orElse(ok(1), e => ok(0)) // Ok(1)\n * orElse(err('e'), e => ok(0)) // Ok(0)\n */\nexport function orElse<T, E, F>(result: Result<T, E>, fn: (error: E) => Result<T, F>): Result<T, F> {\n return isOk(result) ? result : fn(result.error);\n}\n\n/**\n * Converts a Result to an Option, discarding the error.\n * @param result - The Result to convert\n * @returns Some(value) if Ok, None if Err\n * @example\n * toOption(ok(42)) // Some(42)\n * toOption(err('failed')) // None\n */\nexport function toOption<T, E>(result: Result<T, E>): Option<T> {\n return isOk(result) ? optionOf(result) : NONE;\n}\n\n/**\n * Converts a Result's error to an Option.\n * @param result - The Result to convert\n * @returns Some(error) if Err, None if Ok\n * @example\n * toErrorOption(err('failed')) // Some('failed')\n * toErrorOption(ok(42)) // None\n */\nexport function toErrorOption<T, E>(result: Result<T, E>): Option<E> {\n return isErr(result) ? optionOf((result as Err<E>).error) : NONE;\n}\n\n/**\n * Combines two Results into a Result of a tuple.\n * @param left - First Result\n * @param right - Second Result\n * @returns Ok([a, b]) if both Ok, first Err otherwise\n * @example\n * zip(ok(1), ok('a')) // Ok([1, 'a'])\n * zip(ok(1), err('e')) // Err('e')\n */\nexport function zip<T, U, E>(left: Result<T, E>, right: Result<U, E>): Result<[T, U], E> {\n if (isErr(left)) return left as Err<E>;\n if (isErr(right)) return right as Err<E>;\n return [left as Ok<T>, right as Ok<U>] as Ok<[T, U]>;\n}\n\n/**\n * Combines two Results using a function.\n * @param left - First Result\n * @param right - Second Result\n * @param fn - Combining function\n * @returns Ok(fn(a, b)) if both Ok, first Err otherwise\n * @example\n * zipWith(ok(2), ok(3), (a, b) => a + b) // Ok(5)\n */\nexport function zipWith<T, U, V, E>(left: Result<T, E>, right: Result<U, E>, fn: (left: T, right: U) => V): Result<V, E> {\n if (isErr(left)) return left as Err<E>;\n if (isErr(right)) return right as Err<E>;\n return fn(left as Ok<T>, right as Ok<U>) as Ok<V>;\n}\n\n/**\n * Flattens a nested Result.\n * @param result - Result containing a Result\n * @returns The inner Result\n * @example\n * flatten(ok(ok(42))) // Ok(42)\n * flatten(ok(err('e'))) // Err('e')\n * flatten(err('outer')) // Err('outer')\n */\nexport function flatten<T, E>(result: Result<Result<T, E>, E>): Result<T, E> {\n return isErr(result) ? (result as Err<E>) : (result as Result<T, E>);\n}\n\n/**\n * Pattern matches on a Result, handling both Ok and Err cases.\n * @param result - The Result to match\n * @param onOk - Handler for Ok case\n * @param onErr - Handler for Err case\n * @returns Result of the matching handler\n * @example\n * match(ok(42), x => x * 2, e => 0) // 84\n * match(err('e'), x => x * 2, e => 0) // 0\n */\nexport function match<T, E, U>(result: Result<T, E>, onOk: (value: T) => U, onErr: (error: E) => U): U {\n return isOk(result) ? onOk(result) : onErr(result.error);\n}\n\n/**\n * Separates an array of Results into Ok values and Err values.\n * @param results - Array of Results\n * @returns Tuple of [Ok values, Err values]\n * @example\n * partition([ok(1), err('a'), ok(2)]) // [[1, 2], ['a']]\n */\nexport function partition<T, E>(results: Result<T, E>[]): [T[], E[]] {\n const oks: T[] = [];\n const errs: E[] = [];\n\n for (const result of results) {\n if (isOk(result)) {\n oks.push(result);\n } else {\n errs.push(result.error);\n }\n }\n\n return [oks, errs];\n}\n\n/**\n * Collects an array of Results into a Result of an array. Fails on first Err.\n * @param results - Array of Results\n * @returns Ok(values) if all Ok, first Err otherwise\n * @example\n * collect([ok(1), ok(2)]) // Ok([1, 2])\n * collect([ok(1), err('e')]) // Err('e')\n */\nexport function collect<T, E>(results: Result<T, E>[]): Result<T[], E> {\n const values: T[] = [];\n\n for (const result of results) {\n if (isErr(result)) {\n return result as Err<E>;\n }\n values.push(result as Ok<T>);\n }\n\n return values as Ok<T[]>;\n}\n\n/**\n * Collects all Results, returning all errors if any exist.\n * @param results - Array of Results\n * @returns Ok(values) if all Ok, Err(allErrors) otherwise\n * @example\n * collectAll([ok(1), ok(2)]) // Ok([1, 2])\n * collectAll([ok(1), err('a'), err('b')]) // Err(['a', 'b'])\n */\nexport function collectAll<T, E>(results: Result<T, E>[]): Result<T[], E[]> {\n const [oks, errs] = partition(results);\n return errs.length > 0 ? ERR(errs) : (oks as Ok<T[]>);\n}\n\n/**\n * Alias for collect with widened types. Collects Results into a Result of array.\n * @param results - Array of Results\n * @returns Ok(values) if all Ok, first Err otherwise\n */\nexport function all<T, E>(results: Result<T, E>[]): Result<Widen<T>[], WidenNever<E>> {\n return collect(results) as Result<Widen<T>[], WidenNever<E>>;\n}\n\n/**\n * Returns the first Ok, or all errors if none succeed.\n * @param results - Array of Results\n * @returns First Ok found, or Err(allErrors) if all fail\n * @example\n * any([err('a'), ok(1), err('b')]) // Ok(1)\n * any([err('a'), err('b')]) // Err(['a', 'b'])\n */\nexport function any<T, E>(results: Result<T, E>[]): Result<Widen<T>, WidenNever<E>[]> {\n const len = results.length;\n const errors = new Array<WidenNever<E>>(len);\n for (let i = 0; i < len; i++) {\n const result = results[i];\n if (isOk(result)) return result as Ok<Widen<T>>;\n errors[i] = (result as Err<WidenNever<E>>).error;\n }\n return ERR(errors);\n}\n\n/**\n * Transposes a Result of Option to an Option of Result.\n * @param result - Result containing an Option\n * @returns Some(Ok(value)) if Ok(Some), None if Ok(None), Some(Err) if Err\n * @example\n * transpose(ok(some(42))) // Some(Ok(42))\n * transpose(ok(none)) // None\n * transpose(err('e')) // Some(Err('e'))\n */\nexport function transpose<T, E>(result: Result<Option<T>, E>): Option<Result<T, E>> {\n if (isErr(result)) {\n return ERR((result as Err<E>).error) as Option<Result<T, E>>;\n }\n const opt = result as Option<T>;\n return isNone(opt) ? NONE : (opt as unknown as Ok<T> as Option<Result<T, E>>);\n}\n\n/**\n * Checks if Ok and the value satisfies a predicate.\n * @param result - The Result to check\n * @param predicate - Test function\n * @returns true if Ok and predicate returns true\n * @example\n * isOkAnd(ok(4), x => x > 2) // true\n * isOkAnd(ok(1), x => x > 2) // false\n * isOkAnd(err('e'), x => x > 2) // false\n */\nexport function isOkAnd<T, E>(result: Result<T, E>, predicate: (value: T) => boolean): boolean {\n return isOk(result) && predicate(result);\n}\n\n/**\n * Checks if Err and the error satisfies a predicate.\n * @param result - The Result to check\n * @param predicate - Test function\n * @returns true if Err and predicate returns true\n * @example\n * isErrAnd(err('fatal'), e => e.includes('fatal')) // true\n * isErrAnd(ok(42), e => true) // false\n */\nexport function isErrAnd<T, E>(result: Result<T, E>, predicate: (error: E) => boolean): boolean {\n return isErr(result) && predicate((result as Err<E>).error);\n}\n\n/**\n * Maps an async function over an Ok value.\n * @param result - The Result to map\n * @param fn - Async transform function\n * @param onRejected - Optional rejection handler\n * @returns Promise of mapped Result\n * @example\n * await mapAsync(ok(2), async x => x * 2) // Ok(4)\n */\nexport async function mapAsync<T, U, E = unknown>(\n result: Result<T, E>,\n fn: (value: T) => Promise<U>,\n onRejected?: (error: unknown) => E,\n): Promise<Result<U, E>> {\n if (isErr(result)) return result as Err<E>;\n return fromPromise(fn(result as Ok<T>), onRejected);\n}\n\n/**\n * Chains an async Result-returning function.\n * @param result - The Result to chain\n * @param fn - Async function returning a Result\n * @returns Promise of the chained Result\n * @example\n * await andThenAsync(ok(2), async x => ok(x * 2)) // Ok(4)\n */\nexport async function andThenAsync<T, U, E>(result: Result<T, E>, fn: (value: T) => Promise<Result<U, E>>): Promise<Result<U, E>> {\n if (isErr(result)) return result as Err<E>;\n return fn(result as Ok<T>);\n}\n\n/**\n * Pattern matches with async handlers.\n * @param result - The Result to match\n * @param onOk - Async handler for Ok\n * @param onErr - Async handler for Err\n * @returns Promise of the handler result\n */\nexport async function matchAsync<T, E, U>(result: Result<T, E>, onOk: (value: T) => Promise<U>, onErr: (error: E) => Promise<U>): Promise<U> {\n return isOk(result) ? onOk(result) : onErr(result.error);\n}\n\n/**\n * Partitions an async iterable of Results.\n * @param results - Iterable of Promise Results\n * @returns Promise of [Ok values, Err values]\n * @example\n * await partitionAsync([Promise.resolve(ok(1)), Promise.resolve(err('a'))])\n * // [[1], ['a']]\n */\nexport async function partitionAsync<T, E>(results: Iterable<Promise<Result<T, E>>>): Promise<[Widen<T>[], WidenNever<E>[]]> {\n const oks: Widen<T>[] = [];\n const errs: WidenNever<E>[] = [];\n\n for (const promise of results) {\n const result = await promise;\n if (isOk(result)) {\n oks.push(result as Ok<Widen<T>>);\n } else {\n errs.push((result as Err<WidenNever<E>>).error);\n }\n }\n\n return [oks, errs];\n}\n"],"names":["all","and","andThen","andThenAsync","any","assertErr","assertOk","bimap","collect","collectAll","expect","expectErr","flatMap","flatten","fromPromise","isErr","isErrAnd","isOk","isOkAnd","isSomeErr","map","mapAsync","mapErr","mapOr","mapOrElse","match","matchAsync","of","ofAsync","or","orElse","partition","partitionAsync","tap","tapErr","toErrorOption","toOption","transpose","tryAsync","tryCatch","unwrap","unwrapErr","unwrapOr","unwrapOrElse","unwrapOrReturn","zip","zipWith","fn","onError","error","ERR","promise","onRejected","result","onErr","message","Error","String","isSome","okFn","errFn","defaultValue","defaultFn","other","optionOf","NONE","left","right","onOk","results","oks","errs","push","values","length","len","errors","Array","i","opt","isNone","predicate"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../src/result.ts"],"sourcesContent":["import { err as ERR, isOk, isErr, isSome, isNone, NONE, optionOf, isThenable } from './types.js';\nimport type { Ok, Err, Result, Option, Widen, WidenNever, MaybePromise } from './types.js';\n\nexport type { Ok, Err, Result };\nexport { isOk, isErr };\n\n/**\n * Executes a function and captures the result or error.\n * @param fn - Function to execute\n * @param onError - Optional error transformer\n * @returns Ok(result) if successful, Err(error) if thrown\n * @example\n * tryCatch(() => JSON.parse('{\"a\":1}')) // Ok({a: 1})\n * tryCatch(() => JSON.parse('invalid')) // Err(SyntaxError)\n * tryCatch(() => { throw 'oops' }, e => e) // Err('oops')\n */\nexport function tryCatch<T>(fn: () => T): Result<T, unknown>;\nexport function tryCatch<T, E>(fn: () => T, onError: (error: unknown) => E): Result<T, E>;\nexport function tryCatch<T, E = unknown>(fn: () => T, onError?: (error: unknown) => E): Result<T, E> {\n try {\n return fn() as Ok<T>;\n } catch (error) {\n return ERR(onError ? onError(error) : (error as E));\n }\n}\n\n/**\n * Alias for tryCatch. Executes a function and captures the result or error.\n * @param fn - Function to execute\n * @returns Ok(result) if successful, Err(error) if thrown\n */\nexport function of<T>(fn: () => T): Result<T, unknown> {\n return tryCatch(fn);\n}\n\n/**\n * Executes a function that may return sync or async, preserving sync execution when possible.\n * @param fn - Function that may return T or Promise<T>\n * @param onError - Optional error transformer\n * @returns Result<T, E> if sync, Promise<Result<T, E>> if async\n * @example\n * tryCatchMaybePromise(() => 42) // Ok(42) - sync\n * tryCatchMaybePromise(() => Promise.resolve(42)) // Promise<Ok(42)> - async\n * tryCatchMaybePromise(() => { throw 'err' }) // Err('err') - sync\n */\nexport function tryCatchMaybePromise<T>(fn: () => MaybePromise<T>): Result<T, unknown> | Promise<Result<T, unknown>>;\nexport function tryCatchMaybePromise<T, E>(fn: () => MaybePromise<T>, onError: (error: unknown) => E): Result<T, E> | Promise<Result<T, E>>;\nexport function tryCatchMaybePromise<T, E = unknown>(fn: () => MaybePromise<T>, onError?: (error: unknown) => E): Result<T, E> | Promise<Result<T, E>> {\n try {\n const result = fn();\n if (isThenable(result)) {\n return Promise.resolve(result).then(\n (value) => value as Ok<T>,\n (error) => ERR(onError ? onError(error) : (error as E)),\n );\n }\n return result as Ok<T>;\n } catch (error) {\n return ERR(onError ? onError(error) : (error as E));\n }\n}\n\n/**\n * Unwraps an Ok value or returns a computed value for Err.\n * @param result - The Result to unwrap\n * @param onErr - Function called with error if Err\n * @returns The Ok value or result of onErr(error)\n * @example\n * unwrapOrReturn(ok(42), e => 0) // 42\n * unwrapOrReturn(err('fail'), e => 0) // 0\n */\nexport function unwrapOrReturn<T, E, const R>(result: Result<T, E>, onErr: (error: E) => R): T | R {\n return isOk(result) ? result : onErr(result.error);\n}\n\n/**\n * Asserts that a Result is Ok, throwing if Err.\n * @param result - The Result to assert\n * @param message - Custom error message\n * @throws Error if result is Err\n * @example\n * assertOk(ok(42)) // passes\n * assertOk(err('failed')) // throws Error\n */\nexport function assertOk<T, E>(result: Result<T, E>, message?: string): asserts result is Ok<T> {\n if (isErr(result)) {\n throw new Error(message ?? `Expected Ok result. Received error: ${String(result.error)}`);\n }\n}\n\n/**\n * Asserts that a Result is Err, throwing if Ok.\n * @param result - The Result to assert\n * @param message - Custom error message\n * @throws Error if result is Ok\n * @example\n * assertErr(err('failed')) // passes\n * assertErr(ok(42)) // throws Error\n */\nexport function assertErr<T, E>(result: Result<T, E>, message?: string): asserts result is Err<E> {\n if (isOk(result)) {\n throw new Error(message ?? 'Expected Err result.');\n }\n}\n\n/**\n * Checks if result is Err with a non-null error value.\n * @param result - The Result to check\n * @returns true if Err with Some error value\n */\nexport function isSomeErr<T, E>(result: Result<T, E>): boolean {\n return isErr(result) && isSome(result.error);\n}\n\n/**\n * Transforms the Ok value, leaving Err unchanged.\n * @param result - The Result to map\n * @param fn - Transform function\n * @returns Ok(fn(value)) if Ok, Err unchanged\n * @example\n * map(ok(2), x => x * 2) // Ok(4)\n * map(err('e'), x => x * 2) // Err('e')\n */\nexport function map<T, U, E>(result: Err<E>, fn: (value: T) => U): Err<E>;\nexport function map<T, U>(result: Ok<T>, fn: (value: T) => U): Ok<U>;\nexport function map<T, U, E>(result: Result<T, E>, fn: (value: T) => U): Result<U, E>;\nexport function map<T, U, E>(result: Result<T, E>, fn: (value: T) => U): Result<U, E> {\n if (isErr(result)) return result;\n return fn(result) as Ok<U>;\n}\n\n/**\n * Transforms the Err value, leaving Ok unchanged.\n * @param result - The Result to map\n * @param fn - Error transform function\n * @returns Err(fn(error)) if Err, Ok unchanged\n * @example\n * mapErr(err('e'), e => e.toUpperCase()) // Err('E')\n * mapErr(ok(42), e => e.toUpperCase()) // Ok(42)\n */\nexport function mapErr<T, E, F>(result: Ok<T>, fn: (error: E) => F): Ok<T>;\nexport function mapErr<E, F>(result: Err<E>, fn: (error: E) => F): Err<F>;\nexport function mapErr<T, E, F>(result: Result<T, E>, fn: (error: E) => F): Result<T, F>;\nexport function mapErr<T, E, F>(result: Result<T, E>, fn: (error: E) => F): Result<T, F> {\n if (isOk(result)) return result;\n return ERR(fn(result.error));\n}\n\n/**\n * Chains Result-returning functions. Returns Err if the input is Err.\n * @param result - The Result to chain\n * @param fn - Function returning a Result\n * @returns The result of fn(value) if Ok, Err unchanged\n * @example\n * flatMap(ok(2), x => ok(x * 2)) // Ok(4)\n * flatMap(ok(2), x => err('fail')) // Err('fail')\n * flatMap(err('e'), x => ok(x * 2)) // Err('e')\n */\nexport function flatMap<T, U, E>(result: Err<E>, fn: (value: T) => Result<U, E>): Err<E>;\nexport function flatMap<T, U, E>(result: Result<T, E>, fn: (value: T) => Result<U, E>): Result<U, E>;\nexport function flatMap<T, U, E>(result: Result<T, E>, fn: (value: T) => Result<U, E>): Result<U, E> {\n if (isErr(result)) return result;\n return fn(result);\n}\n\n/**\n * Alias for flatMap. Chains Result-returning functions.\n * @param result - The Result to chain\n * @param fn - Function returning a Result\n * @returns The result of fn(value) if Ok, Err unchanged\n */\nexport function andThen<T, U, E>(result: Err<E>, fn: (value: T) => Result<U, E>): Err<E>;\nexport function andThen<T, U, E>(result: Result<T, E>, fn: (value: T) => Result<U, E>): Result<U, E>;\nexport function andThen<T, U, E>(result: Result<T, E>, fn: (value: T) => Result<U, E>): Result<U, E> {\n return isErr(result) ? result : fn(result);\n}\n\n/**\n * Executes a side effect if Ok, then returns the original Result.\n * @param result - The Result to tap\n * @param fn - Side effect function\n * @returns The original Result unchanged\n * @example\n * tap(ok(42), x => console.log(x)) // logs 42, returns Ok(42)\n */\nexport function tap<T, E>(result: Err<E>, fn: (value: T) => void): Err<E>;\nexport function tap<T>(result: Ok<T>, fn: (value: T) => void): Ok<T>;\nexport function tap<T, E>(result: Result<T, E>, fn: (value: T) => void): Result<T, E>;\nexport function tap<T, E>(result: Result<T, E>, fn: (value: T) => void): Result<T, E> {\n if (isOk(result)) {\n fn(result);\n }\n return result;\n}\n\n/**\n * Executes a side effect if Err, then returns the original Result.\n * @param result - The Result to tap\n * @param fn - Side effect function for error\n * @returns The original Result unchanged\n * @example\n * tapErr(err('fail'), e => console.log(e)) // logs 'fail', returns Err('fail')\n */\nexport function tapErr<T, E>(result: Ok<T>, fn: (error: E) => void): Ok<T>;\nexport function tapErr<E>(result: Err<E>, fn: (error: E) => void): Err<E>;\nexport function tapErr<T, E>(result: Result<T, E>, fn: (error: E) => void): Result<T, E>;\nexport function tapErr<T, E>(result: Result<T, E>, fn: (error: E) => void): Result<T, E> {\n if (isErr(result)) {\n fn(result.error);\n }\n return result;\n}\n\n/**\n * Maps both Ok and Err values simultaneously.\n * @param result - The Result to map\n * @param okFn - Transform for Ok value\n * @param errFn - Transform for Err value\n * @returns Ok(okFn(value)) if Ok, Err(errFn(error)) if Err\n * @example\n * bimap(ok(2), x => x * 2, e => e.toUpperCase()) // Ok(4)\n * bimap(err('e'), x => x * 2, e => e.toUpperCase()) // Err('E')\n */\nexport function bimap<T, U, E, F>(result: Ok<T>, okFn: (value: T) => U, errFn: (error: E) => F): Ok<U>;\nexport function bimap<T, U, E, F>(result: Err<E>, okFn: (value: T) => U, errFn: (error: E) => F): Err<F>;\nexport function bimap<T, U, E, F>(result: Result<T, E>, okFn: (value: T) => U, errFn: (error: E) => F): Result<U, F>;\nexport function bimap<T, U, E, F>(result: Result<T, E>, okFn: (value: T) => U, errFn: (error: E) => F): Result<U, F> {\n return isOk(result) ? (okFn(result) as Ok<U>) : ERR(errFn(result.error));\n}\n\n/**\n * Extracts the Ok value, throws Err if not Ok.\n * Use with safeTry for Rust-like ? operator ergonomics.\n * @param result - The Result to unwrap\n * @returns The contained Ok value\n * @throws The Err object itself\n * @example\n * unwrap(ok(42)) // 42\n * unwrap(err('failed')) // throws Err\n * safeTry(() => {\n * const a = unwrap(getValue());\n * return a + 1;\n * });\n */\nexport function unwrap<T, E>(result: Result<T, E>): T {\n if (isErr(result)) throw result.error;\n return result;\n}\n\n/**\n * Extracts the Err value, throws if Ok.\n * @param result - The Result to unwrap\n * @returns The contained error\n * @throws Error if result is Ok\n * @example\n * unwrapErr(err('failed')) // 'failed'\n * unwrapErr(ok(42)) // throws Error\n */\nexport function unwrapErr<T, E>(result: Result<T, E>): E {\n if (isOk(result)) {\n throw new Error(`Called unwrapErr on Ok: ${String(result)}`);\n }\n return result.error;\n}\n\n/**\n * Extracts the Ok value, or returns a default.\n * @param result - The Result to unwrap\n * @param defaultValue - Value if Err\n * @returns The Ok value or defaultValue\n * @example\n * unwrapOr(ok(42), 0) // 42\n * unwrapOr(err('failed'), 0) // 0\n */\nexport function unwrapOr<T, E>(result: Result<T, E>, defaultValue: T): T {\n return isOk(result) ? result : defaultValue;\n}\n\n/**\n * Extracts the Ok value, or computes a default from the error.\n * @param result - The Result to unwrap\n * @param fn - Function to compute default from error\n * @returns The Ok value or fn(error)\n * @example\n * unwrapOrElse(ok(42), e => 0) // 42\n * unwrapOrElse(err('failed'), e => 0) // 0\n */\nexport function unwrapOrElse<T, E>(result: Result<T, E>, fn: (error: E) => T): T {\n return isOk(result) ? result : fn(result.error);\n}\n\n/**\n * Maps the Ok value and returns it, or returns a default.\n * @param result - The Result to map\n * @param defaultValue - Value if Err\n * @param fn - Transform function\n * @returns fn(value) if Ok, defaultValue otherwise\n * @example\n * mapOr(ok(2), 0, x => x * 2) // 4\n * mapOr(err('e'), 0, x => x * 2) // 0\n */\nexport function mapOr<T, E, U>(result: Result<T, E>, defaultValue: U, fn: (value: T) => U): U {\n return isOk(result) ? fn(result) : defaultValue;\n}\n\n/**\n * Maps the Ok value and returns it, or computes a default.\n * @param result - The Result to map\n * @param defaultFn - Function to compute default\n * @param fn - Transform function\n * @returns fn(value) if Ok, defaultFn() otherwise\n * @example\n * mapOrElse(ok(2), () => 0, x => x * 2) // 4\n * mapOrElse(err('e'), () => 0, x => x * 2) // 0\n */\nexport function mapOrElse<T, E, U>(result: Result<T, E>, defaultFn: () => U, fn: (value: T) => U): U {\n return isOk(result) ? fn(result) : defaultFn();\n}\n\n/**\n * Extracts the Ok value, throws with custom message if Err.\n * @param result - The Result to unwrap\n * @param message - Error message prefix if Err\n * @returns The Ok value\n * @throws Error with message if Err\n * @example\n * expect(ok(42), 'missing value') // 42\n * expect(err('fail'), 'missing value') // throws Error('missing value: fail')\n */\nexport function expect<T, E>(result: Result<T, E>, message: string): T {\n if (isErr(result)) {\n throw new Error(`${message}: ${String(result.error)}`);\n }\n return result;\n}\n\n/**\n * Extracts the Err value, throws with custom message if Ok.\n * @param result - The Result to unwrap\n * @param message - Error message prefix if Ok\n * @returns The error value\n * @throws Error with message if Ok\n * @example\n * expectErr(err('fail'), 'expected error') // 'fail'\n * expectErr(ok(42), 'expected error') // throws Error\n */\nexport function expectErr<T, E>(result: Result<T, E>, message: string): E {\n if (isOk(result)) {\n throw new Error(`${message}: ${String(result)}`);\n }\n return result.error;\n}\n\n/**\n * Returns other if result is Ok, otherwise returns the Err.\n * @param result - First Result\n * @param other - Second Result\n * @returns other if result is Ok, result (Err) otherwise\n * @example\n * and(ok(1), ok(2)) // Ok(2)\n * and(err('e'), ok(2)) // Err('e')\n */\nexport function and<T, U, E>(result: Result<T, E>, other: Result<U, E>): Result<U, E> {\n return isOk(result) ? other : result;\n}\n\n/**\n * Returns result if Ok, otherwise returns other.\n * @param result - First Result\n * @param other - Fallback Result\n * @returns result if Ok, other otherwise\n * @example\n * or(ok(1), ok(2)) // Ok(1)\n * or(err('e'), ok(2)) // Ok(2)\n */\nexport function or<T, E, F>(result: Result<T, E>, other: Result<T, F>): Result<T, F> {\n return isOk(result) ? result : other;\n}\n\n/**\n * Returns result if Ok, otherwise computes a fallback from the error.\n * @param result - First Result\n * @param fn - Function to compute fallback\n * @returns result if Ok, fn(error) otherwise\n * @example\n * orElse(ok(1), e => ok(0)) // Ok(1)\n * orElse(err('e'), e => ok(0)) // Ok(0)\n */\nexport function orElse<T, E, F>(result: Result<T, E>, fn: (error: E) => Result<T, F>): Result<T, F> {\n return isOk(result) ? result : fn(result.error);\n}\n\n/**\n * Converts a Result to an Option, discarding the error.\n * @param result - The Result to convert\n * @returns Some(value) if Ok, None if Err\n * @example\n * toOption(ok(42)) // Some(42)\n * toOption(err('failed')) // None\n */\nexport function toOption<T, E>(result: Result<T, E>): Option<T> {\n return isOk(result) ? optionOf(result) : NONE;\n}\n\n/**\n * Converts a Result's error to an Option.\n * @param result - The Result to convert\n * @returns Some(error) if Err, None if Ok\n * @example\n * toErrorOption(err('failed')) // Some('failed')\n * toErrorOption(ok(42)) // None\n */\nexport function toErrorOption<T, E>(result: Result<T, E>): Option<E> {\n return isErr(result) ? optionOf(result.error) : NONE;\n}\n\n/**\n * Combines two Results into a Result of a tuple.\n * @param left - First Result\n * @param right - Second Result\n * @returns Ok([a, b]) if both Ok, first Err otherwise\n * @example\n * zip(ok(1), ok('a')) // Ok([1, 'a'])\n * zip(ok(1), err('e')) // Err('e')\n */\nexport function zip<T, U, E>(left: Result<T, E>, right: Result<U, E>): Result<[T, U], E> {\n if (isErr(left)) return left;\n if (isErr(right)) return right;\n return [left, right] as Ok<[T, U]>;\n}\n\n/**\n * Combines two Results using a function.\n * @param left - First Result\n * @param right - Second Result\n * @param fn - Combining function\n * @returns Ok(fn(a, b)) if both Ok, first Err otherwise\n * @example\n * zipWith(ok(2), ok(3), (a, b) => a + b) // Ok(5)\n */\nexport function zipWith<T, U, V, E>(left: Result<T, E>, right: Result<U, E>, fn: (left: T, right: U) => V): Result<V, E> {\n if (isErr(left)) return left;\n if (isErr(right)) return right;\n return fn(left, right) as Ok<V>;\n}\n\n/**\n * Flattens a nested Result.\n * @param result - Result containing a Result\n * @returns The inner Result\n * @example\n * flatten(ok(ok(42))) // Ok(42)\n * flatten(ok(err('e'))) // Err('e')\n * flatten(err('outer')) // Err('outer')\n */\nexport function flatten<T, E>(result: Result<Result<T, E>, E>): Result<T, E> {\n return isErr(result) ? (result as Err<E>) : (result as Result<T, E>);\n}\n\n/**\n * Pattern matches on a Result, handling both Ok and Err cases.\n * @param result - The Result to match\n * @param onOk - Handler for Ok case\n * @param onErr - Handler for Err case\n * @returns Result of the matching handler\n * @example\n * match(ok(42), x => x * 2, e => 0) // 84\n * match(err('e'), x => x * 2, e => 0) // 0\n */\nexport function match<T, E, U>(result: Result<T, E>, onOk: (value: T) => U, onErr: (error: E) => U): U {\n return isOk(result) ? onOk(result) : onErr(result.error);\n}\n\n/**\n * Separates an array of Results into Ok values and Err values.\n * @param results - Array of Results\n * @returns Tuple of [Ok values, Err values]\n * @example\n * partition([ok(1), err('a'), ok(2)]) // [[1, 2], ['a']]\n */\nexport function partition<T, E>(results: Result<T, E>[]): [T[], E[]] {\n const oks: T[] = [];\n const errs: E[] = [];\n\n for (const result of results) {\n if (isOk(result)) {\n oks.push(result);\n } else {\n errs.push(result.error);\n }\n }\n\n return [oks, errs];\n}\n\n/**\n * Extracts all Ok values from an iterable of Results.\n * @param results - Iterable of Results\n * @returns Array of Ok values\n * @example\n * filterOk([ok(1), err('a'), ok(2)]) // [1, 2]\n */\nexport function filterOk<T, E>(results: Iterable<Result<T, E>>): T[] {\n const oks: T[] = [];\n for (const result of results) {\n if (isOk(result)) oks.push(result);\n }\n return oks;\n}\n\n/**\n * Extracts all Err values from an iterable of Results.\n * @param results - Iterable of Results\n * @returns Array of error values\n * @example\n * filterErr([ok(1), err('a'), ok(2)]) // ['a']\n */\nexport function filterErr<T, E>(results: Iterable<Result<T, E>>): E[] {\n const errs: E[] = [];\n for (const result of results) {\n if (isErr(result)) errs.push(result.error);\n }\n return errs;\n}\n\n/**\n * Collects an array of Results into a Result of an array. Fails on first Err.\n * @param results - Array of Results\n * @returns Ok(values) if all Ok, first Err otherwise\n * @example\n * collect([ok(1), ok(2)]) // Ok([1, 2])\n * collect([ok(1), err('e')]) // Err('e')\n */\nexport function collect<T, E>(results: Result<T, E>[]): Result<T[], E> {\n const values: T[] = [];\n\n for (const result of results) {\n if (isErr(result)) return result;\n values.push(result);\n }\n\n return values as Ok<T[]>;\n}\n\n/**\n * Collects all Results, returning all errors if any exist.\n * @param results - Array of Results\n * @returns Ok(values) if all Ok, Err(allErrors) otherwise\n * @example\n * collectAll([ok(1), ok(2)]) // Ok([1, 2])\n * collectAll([ok(1), err('a'), err('b')]) // Err(['a', 'b'])\n */\nexport function collectAll<T, E>(results: Result<T, E>[]): Result<T[], E[]> {\n const [oks, errs] = partition(results);\n return errs.length > 0 ? ERR(errs) : (oks as Ok<T[]>);\n}\n\n/**\n * Alias for collect with widened types. Collects Results into a Result of array.\n * @param results - Array of Results\n * @returns Ok(values) if all Ok, first Err otherwise\n */\nexport function all<T, E>(results: Result<T, E>[]): Result<readonly Widen<T>[], WidenNever<E>> {\n return collect(results) as Result<readonly Widen<T>[], WidenNever<E>>;\n}\n\n/**\n * Returns the first Ok, or all errors if none succeed.\n * @param results - Array of Results\n * @returns First Ok found, or Err(allErrors) if all fail\n * @example\n * any([err('a'), ok(1), err('b')]) // Ok(1)\n * any([err('a'), err('b')]) // Err(['a', 'b'])\n */\nexport function any<T, E>(results: Result<T, E>[]): Result<Widen<T>, WidenNever<E>[]> {\n const errors: WidenNever<E>[] = [];\n for (let i = 0; i < results.length; i++) {\n const result = results[i];\n if (isOk(result)) return result as Ok<Widen<T>>;\n errors.push((result as Err<WidenNever<E>>).error);\n }\n return ERR(errors);\n}\n\n/**\n * Transposes a Result of Option to an Option of Result.\n * @param result - Result containing an Option\n * @returns Some(Ok(value)) if Ok(Some), None if Ok(None), Some(Err) if Err\n * @example\n * transpose(ok(some(42))) // Some(Ok(42))\n * transpose(ok(none)) // None\n * transpose(err('e')) // Some(Err('e'))\n */\nexport function transpose<T, E>(result: Result<Option<T>, E>): Option<Result<T, E>> {\n if (isErr(result)) {\n return ERR(result.error) as Option<Result<T, E>>;\n }\n const opt = result as Option<T>;\n return isNone(opt) ? NONE : (opt as unknown as Ok<T> as Option<Result<T, E>>);\n}\n\n/**\n * Checks if Ok and the value satisfies a predicate.\n * @param result - The Result to check\n * @param predicate - Test function\n * @returns true if Ok and predicate returns true\n * @example\n * isOkAnd(ok(4), x => x > 2) // true\n * isOkAnd(ok(1), x => x > 2) // false\n * isOkAnd(err('e'), x => x > 2) // false\n */\nexport function isOkAnd<T, E>(result: Result<T, E>, predicate: (value: T) => boolean): boolean {\n return isOk(result) && predicate(result);\n}\n\n/**\n * Checks if Err and the error satisfies a predicate.\n * @param result - The Result to check\n * @param predicate - Test function\n * @returns true if Err and predicate returns true\n * @example\n * isErrAnd(err('fatal'), e => e.includes('fatal')) // true\n * isErrAnd(ok(42), e => true) // false\n */\nexport function isErrAnd<T, E>(result: Result<T, E>, predicate: (error: E) => boolean): boolean {\n return isErr(result) && predicate(result.error);\n}\n\nexport function settledToResult<T, E>(result: PromiseSettledResult<Result<T, E>>): Result<T, E> {\n if (result.status === 'fulfilled') return result.value;\n return ERR(result.reason);\n}\n\n/**\n * Partitions an async iterable of Results.\n * @param results - Iterable of Promise Results\n * @returns Promise of [Ok values, Err values]\n * @example\n * await partitionAsync([Promise.resolve(ok(1)), Promise.resolve(err('a'))])\n * // [[1], ['a']]\n */\nexport async function partitionAsync<T, E>(promises: Iterable<Promise<Result<T, E>>>): Promise<[Widen<T>[], WidenNever<E>[]]> {\n const settled = await Promise.allSettled(promises);\n return partition(settled.map(settledToResult)) as [Widen<T>[], WidenNever<E>[]];\n}\n\n/**\n * Settles an array of MaybePromise values into Results.\n * Returns synchronously if all inputs are sync, avoiding Promise overhead.\n * @param values - Array of values that may or may not be Promises\n * @returns Array of Results (sync) or Promise of Results (if any async)\n * @example\n * settleMaybePromise([1, 2, 3]) // [Ok(1), Ok(2), Ok(3)] - sync\n * settleMaybePromise([1, Promise.resolve(2)]) // Promise<[Ok(1), Ok(2)]>\n * settleMaybePromise([Promise.reject('e')]) // Promise<[Err('e')]>\n */\nexport function settleMaybePromise<T, E = unknown>(values: MaybePromise<T>[]): Result<T, E>[] | Promise<Result<T, E>[]> {\n const len = values.length;\n const results = new Array<Result<T, E>>(len);\n let pendingIndices: number[] | undefined;\n let pendingPromises: Promise<T>[] | undefined;\n\n for (let i = 0; i < len; i++) {\n const v = values[i];\n if (isThenable(v)) {\n (pendingIndices ??= []).push(i);\n (pendingPromises ??= []).push(Promise.resolve(v));\n } else {\n results[i] = v as Ok<T>;\n }\n }\n\n if (!pendingPromises) return results;\n\n return Promise.allSettled(pendingPromises).then((settled) => {\n for (let i = 0; i < settled.length; i++) {\n const s = settled[i];\n results[pendingIndices![i]] = s.status === 'fulfilled' ? (s.value as Ok<T>) : ERR(s.reason as E);\n }\n return results;\n });\n}\n\nexport async function partitionMaybePromiseAsync<T, E>(\n values: MaybePromise<Result<T, E>>[],\n oks: Widen<T>[],\n errs: WidenNever<E>[],\n startIndex: number = 0,\n): Promise<[Widen<T>[], WidenNever<E>[]]> {\n const suffixLength = values.length - startIndex;\n const pending = new Array<Promise<Result<T, E>>>(suffixLength);\n\n for (let i = 0; i < suffixLength; i++) {\n const value = values[startIndex + i];\n pending[i] = Promise.resolve(value).then(\n (result) => result as Result<T, E>,\n (error) => ERR(error as E),\n );\n }\n\n const resolved = await Promise.all(pending);\n for (let i = 0; i < resolved.length; i++) {\n const result = resolved[i];\n if (isOk(result)) {\n oks.push(result as Widen<T>);\n } else {\n errs.push((result as Err<WidenNever<E>>).error);\n }\n }\n return [oks, errs] as [Widen<T>[], WidenNever<E>[]];\n}\n\n/**\n * Partitions MaybePromise Results into Ok and Err values.\n * Returns synchronously if all inputs are sync, avoiding Promise overhead.\n * @param values - Array of MaybePromise Results\n * @returns [Ok values, Err values] (sync) or Promise of same (if any async)\n * @example\n * partitionMaybePromise([ok(1), err('a')]) // [[1], ['a']] - sync\n * partitionMaybePromise([ok(1), Promise.resolve(err('a'))]) // Promise<[[1], ['a']]>\n */\nexport function partitionMaybePromise<T, E>(values: MaybePromise<Result<T, E>>[]): [Widen<T>[], WidenNever<E>[]] | Promise<[Widen<T>[], WidenNever<E>[]]> {\n const len = values.length;\n const oks: Widen<T>[] = [];\n const errs: WidenNever<E>[] = [];\n\n for (let i = 0; i < len; i++) {\n const value = values[i];\n if (isThenable(value)) {\n return partitionMaybePromiseAsync(values, oks, errs, i);\n }\n if (isOk(value)) {\n oks.push(value as Widen<T>);\n } else {\n errs.push((value as Err<WidenNever<E>>).error);\n }\n }\n\n return [oks, errs];\n}\n\n/**\n * Executes a function, catching thrown Err values.\n * Use with unwrap for Rust-like ? operator ergonomics.\n * @param fn - Function that may throw Err via unwrap\n * @returns Ok(return value) or the caught Err\n * @example\n * const result = safeTry(() => {\n * const a = unwrap(parseNumber('10'));\n * const b = unwrap(parseNumber('5'));\n * return a + b;\n * }); // Ok(15) or Err(...)\n */\nexport function safeTry<T>(fn: () => T): Result<T, unknown> {\n try {\n return fn() as Ok<T>;\n } catch (e) {\n return ERR(e);\n }\n}\n\n/**\n * Async version of safeTry.\n * @param fn - Async function that may throw Err via unwrap\n * @returns Promise of Ok(return value) or the caught Err\n * @example\n * const result = await safeTryAsync(async () => {\n * const user = unwrap(await fetchUser(id));\n * const posts = unwrap(await fetchPosts(user.id));\n * return { user, posts };\n * });\n */\nexport async function safeTryAsync<T>(fn: () => Promise<T>): Promise<Result<T, unknown>> {\n try {\n return (await fn()) as Ok<T>;\n } catch (e) {\n return ERR(e);\n }\n}\n"],"names":["all","and","andThen","any","assertErr","assertOk","bimap","collect","collectAll","expect","expectErr","filterErr","filterOk","flatMap","flatten","isErr","isErrAnd","isOk","isOkAnd","isSomeErr","map","mapErr","mapOr","mapOrElse","match","of","or","orElse","partition","partitionAsync","partitionMaybePromise","partitionMaybePromiseAsync","safeTry","safeTryAsync","settleMaybePromise","settledToResult","tap","tapErr","toErrorOption","toOption","transpose","tryCatch","tryCatchMaybePromise","unwrap","unwrapErr","unwrapOr","unwrapOrElse","unwrapOrReturn","zip","zipWith","fn","onError","error","ERR","result","isThenable","Promise","resolve","then","value","onErr","message","Error","String","isSome","okFn","errFn","defaultValue","defaultFn","other","optionOf","NONE","left","right","onOk","results","oks","errs","push","values","length","errors","i","opt","isNone","predicate","status","reason","promises","settled","allSettled","len","Array","pendingIndices","pendingPromises","v","s","startIndex","suffixLength","pending","resolved","e"],"mappings":"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"}
|