-
Notifications
You must be signed in to change notification settings - Fork 465
/
Copy pathcamlinternalLazy.js
79 lines (68 loc) · 1.27 KB
/
camlinternalLazy.js
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
69
70
71
72
73
74
75
76
77
78
79
import * as Caml_exceptions from "./caml_exceptions.js";
function is_val(l) {
return l.LAZY_DONE;
}
let Undefined = /* @__PURE__ */Caml_exceptions.create("CamlinternalLazy.Undefined");
function forward_with_closure(blk, closure) {
let result = closure();
blk.VAL = result;
blk.LAZY_DONE = true;
return result;
}
function raise_undefined() {
throw new Error(Undefined, {
cause: {
RE_EXN_ID: Undefined
}
});
}
function force(lzv) {
if (lzv.LAZY_DONE) {
return lzv.VAL;
} else {
let closure = lzv.VAL;
lzv.VAL = raise_undefined;
try {
return forward_with_closure(lzv, closure);
} catch (e) {
lzv.VAL = (function () {
throw new Error(e.RE_EXN_ID, {
cause: e
});
});
throw new Error(e.RE_EXN_ID, {
cause: e
});
}
}
}
function force_val(lzv) {
if (lzv.LAZY_DONE) {
return lzv.VAL;
} else {
let closure = lzv.VAL;
lzv.VAL = raise_undefined;
return forward_with_closure(lzv, closure);
}
}
function from_fun(closure) {
return {
LAZY_DONE: false,
VAL: closure
};
}
function from_val(value) {
return {
LAZY_DONE: true,
VAL: value
};
}
export {
Undefined,
force,
force_val,
is_val,
from_fun,
from_val,
}
/* No side effect */