-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathutil.ts
68 lines (59 loc) · 1.45 KB
/
util.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
export type Result<T, E = Error> = { ok: true; val: T } | { ok: false; err: E };
export function makeStrError<T>(err: string): Result<T> {
return { ok: false, err: new Error(err) };
}
export function makeError<T>(err: any): Result<T> {
return { ok: false, err };
}
export function makeOk<T>(val: T): Result<T> {
return { ok: true, val };
}
/**
* Throws error if the result is not ok
* @param r result to unwrap
* @returns ok value of the result
*/
export function unwrap<T>(r: Result<T>): T {
if (!r.ok) {
throw r.err;
}
return r.val;
}
// Do not use in production. Works only for val of type null
/**
* Logs the error
* @param r result to unwrap
*/
export function unwrapLog<T>(r: Result<T>) {
if (!r.ok) {
console.log(r.err);
}
}
/**
* unwraps the result and throws an error with a custom message
* @param r result to unwrap
* @param msg custom message to throw
* @returns ok value of the result
*/
export function expect<T>(r: Result<T>, msg: string): T {
if (!r.ok) {
throw new Error(`Error '${r.err}' expected: ${msg}`);
}
return r.val;
}
/**
* Allows to handle errors and values in callbacks
* @param r result to unwrap
* @param success callback to call if the result is ok
* @param handle callback to call if the result is error
*/
export function handle<T>(
r: Result<T>,
success: (val: T) => void,
handle: (err: Error) => void
): void {
if (!r.ok) {
return handle(r.err);
}
return success(r.val);
}