time-to-botec/squiggle/node_modules/@rescript/std/lib/js/mapLabels.js

950 lines
21 KiB
JavaScript
Raw Normal View History

'use strict';
var Curry = require("./curry.js");
var Caml_option = require("./caml_option.js");
function Make(Ord) {
var height = function (param) {
if (param) {
return param.h;
} else {
return 0;
}
};
var create = function (l, x, d, r) {
var hl = height(l);
var hr = height(r);
return /* Node */{
l: l,
v: x,
d: d,
r: r,
h: hl >= hr ? hl + 1 | 0 : hr + 1 | 0
};
};
var singleton = function (x, d) {
return /* Node */{
l: /* Empty */0,
v: x,
d: d,
r: /* Empty */0,
h: 1
};
};
var bal = function (l, x, d, r) {
var hl = l ? l.h : 0;
var hr = r ? r.h : 0;
if (hl > (hr + 2 | 0)) {
if (l) {
var lr = l.r;
var ld = l.d;
var lv = l.v;
var ll = l.l;
if (height(ll) >= height(lr)) {
return create(ll, lv, ld, create(lr, x, d, r));
}
if (lr) {
return create(create(ll, lv, ld, lr.l), lr.v, lr.d, create(lr.r, x, d, r));
}
throw {
RE_EXN_ID: "Invalid_argument",
_1: "Map.bal",
Error: new Error()
};
}
throw {
RE_EXN_ID: "Invalid_argument",
_1: "Map.bal",
Error: new Error()
};
}
if (hr <= (hl + 2 | 0)) {
return /* Node */{
l: l,
v: x,
d: d,
r: r,
h: hl >= hr ? hl + 1 | 0 : hr + 1 | 0
};
}
if (r) {
var rr = r.r;
var rd = r.d;
var rv = r.v;
var rl = r.l;
if (height(rr) >= height(rl)) {
return create(create(l, x, d, rl), rv, rd, rr);
}
if (rl) {
return create(create(l, x, d, rl.l), rl.v, rl.d, create(rl.r, rv, rd, rr));
}
throw {
RE_EXN_ID: "Invalid_argument",
_1: "Map.bal",
Error: new Error()
};
}
throw {
RE_EXN_ID: "Invalid_argument",
_1: "Map.bal",
Error: new Error()
};
};
var is_empty = function (param) {
if (param) {
return false;
} else {
return true;
}
};
var add = function (x, data, m) {
if (!m) {
return /* Node */{
l: /* Empty */0,
v: x,
d: data,
r: /* Empty */0,
h: 1
};
}
var r = m.r;
var d = m.d;
var v = m.v;
var l = m.l;
var c = Curry._2(Ord.compare, x, v);
if (c === 0) {
if (d === data) {
return m;
} else {
return /* Node */{
l: l,
v: x,
d: data,
r: r,
h: m.h
};
}
}
if (c < 0) {
var ll = add(x, data, l);
if (l === ll) {
return m;
} else {
return bal(ll, v, d, r);
}
}
var rr = add(x, data, r);
if (r === rr) {
return m;
} else {
return bal(l, v, d, rr);
}
};
var find = function (x, _param) {
while(true) {
var param = _param;
if (param) {
var c = Curry._2(Ord.compare, x, param.v);
if (c === 0) {
return param.d;
}
_param = c < 0 ? param.l : param.r;
continue ;
}
throw {
RE_EXN_ID: "Not_found",
Error: new Error()
};
};
};
var find_first_aux = function (_v0, _d0, f, _param) {
while(true) {
var param = _param;
var d0 = _d0;
var v0 = _v0;
if (!param) {
return [
v0,
d0
];
}
var v = param.v;
if (Curry._1(f, v)) {
_param = param.l;
_d0 = param.d;
_v0 = v;
continue ;
}
_param = param.r;
continue ;
};
};
var find_first = function (f, _param) {
while(true) {
var param = _param;
if (param) {
var v = param.v;
if (Curry._1(f, v)) {
return find_first_aux(v, param.d, f, param.l);
}
_param = param.r;
continue ;
}
throw {
RE_EXN_ID: "Not_found",
Error: new Error()
};
};
};
var find_first_opt_aux = function (_v0, _d0, f, _param) {
while(true) {
var param = _param;
var d0 = _d0;
var v0 = _v0;
if (!param) {
return [
v0,
d0
];
}
var v = param.v;
if (Curry._1(f, v)) {
_param = param.l;
_d0 = param.d;
_v0 = v;
continue ;
}
_param = param.r;
continue ;
};
};
var find_first_opt = function (f, _param) {
while(true) {
var param = _param;
if (!param) {
return ;
}
var v = param.v;
if (Curry._1(f, v)) {
return find_first_opt_aux(v, param.d, f, param.l);
}
_param = param.r;
continue ;
};
};
var find_last_aux = function (_v0, _d0, f, _param) {
while(true) {
var param = _param;
var d0 = _d0;
var v0 = _v0;
if (!param) {
return [
v0,
d0
];
}
var v = param.v;
if (Curry._1(f, v)) {
_param = param.r;
_d0 = param.d;
_v0 = v;
continue ;
}
_param = param.l;
continue ;
};
};
var find_last = function (f, _param) {
while(true) {
var param = _param;
if (param) {
var v = param.v;
if (Curry._1(f, v)) {
return find_last_aux(v, param.d, f, param.r);
}
_param = param.l;
continue ;
}
throw {
RE_EXN_ID: "Not_found",
Error: new Error()
};
};
};
var find_last_opt_aux = function (_v0, _d0, f, _param) {
while(true) {
var param = _param;
var d0 = _d0;
var v0 = _v0;
if (!param) {
return [
v0,
d0
];
}
var v = param.v;
if (Curry._1(f, v)) {
_param = param.r;
_d0 = param.d;
_v0 = v;
continue ;
}
_param = param.l;
continue ;
};
};
var find_last_opt = function (f, _param) {
while(true) {
var param = _param;
if (!param) {
return ;
}
var v = param.v;
if (Curry._1(f, v)) {
return find_last_opt_aux(v, param.d, f, param.r);
}
_param = param.l;
continue ;
};
};
var find_opt = function (x, _param) {
while(true) {
var param = _param;
if (!param) {
return ;
}
var c = Curry._2(Ord.compare, x, param.v);
if (c === 0) {
return Caml_option.some(param.d);
}
_param = c < 0 ? param.l : param.r;
continue ;
};
};
var mem = function (x, _param) {
while(true) {
var param = _param;
if (!param) {
return false;
}
var c = Curry._2(Ord.compare, x, param.v);
if (c === 0) {
return true;
}
_param = c < 0 ? param.l : param.r;
continue ;
};
};
var min_binding = function (_param) {
while(true) {
var param = _param;
if (param) {
var l = param.l;
if (!l) {
return [
param.v,
param.d
];
}
_param = l;
continue ;
}
throw {
RE_EXN_ID: "Not_found",
Error: new Error()
};
};
};
var min_binding_opt = function (_param) {
while(true) {
var param = _param;
if (!param) {
return ;
}
var l = param.l;
if (!l) {
return [
param.v,
param.d
];
}
_param = l;
continue ;
};
};
var max_binding = function (_param) {
while(true) {
var param = _param;
if (param) {
var r = param.r;
if (!r) {
return [
param.v,
param.d
];
}
_param = r;
continue ;
}
throw {
RE_EXN_ID: "Not_found",
Error: new Error()
};
};
};
var max_binding_opt = function (_param) {
while(true) {
var param = _param;
if (!param) {
return ;
}
var r = param.r;
if (!r) {
return [
param.v,
param.d
];
}
_param = r;
continue ;
};
};
var remove_min_binding = function (param) {
if (param) {
var l = param.l;
if (l) {
return bal(remove_min_binding(l), param.v, param.d, param.r);
} else {
return param.r;
}
}
throw {
RE_EXN_ID: "Invalid_argument",
_1: "Map.remove_min_elt",
Error: new Error()
};
};
var merge = function (t1, t2) {
if (!t1) {
return t2;
}
if (!t2) {
return t1;
}
var match = min_binding(t2);
return bal(t1, match[0], match[1], remove_min_binding(t2));
};
var remove = function (x, m) {
if (!m) {
return /* Empty */0;
}
var r = m.r;
var d = m.d;
var v = m.v;
var l = m.l;
var c = Curry._2(Ord.compare, x, v);
if (c === 0) {
return merge(l, r);
}
if (c < 0) {
var ll = remove(x, l);
if (l === ll) {
return m;
} else {
return bal(ll, v, d, r);
}
}
var rr = remove(x, r);
if (r === rr) {
return m;
} else {
return bal(l, v, d, rr);
}
};
var update = function (x, f, m) {
if (m) {
var r = m.r;
var d = m.d;
var v = m.v;
var l = m.l;
var c = Curry._2(Ord.compare, x, v);
if (c === 0) {
var data = Curry._1(f, Caml_option.some(d));
if (data === undefined) {
return merge(l, r);
}
var data$1 = Caml_option.valFromOption(data);
if (d === data$1) {
return m;
} else {
return /* Node */{
l: l,
v: x,
d: data$1,
r: r,
h: m.h
};
}
}
if (c < 0) {
var ll = update(x, f, l);
if (l === ll) {
return m;
} else {
return bal(ll, v, d, r);
}
}
var rr = update(x, f, r);
if (r === rr) {
return m;
} else {
return bal(l, v, d, rr);
}
}
var data$2 = Curry._1(f, undefined);
if (data$2 !== undefined) {
return /* Node */{
l: /* Empty */0,
v: x,
d: Caml_option.valFromOption(data$2),
r: /* Empty */0,
h: 1
};
} else {
return /* Empty */0;
}
};
var iter = function (f, _param) {
while(true) {
var param = _param;
if (!param) {
return ;
}
iter(f, param.l);
Curry._2(f, param.v, param.d);
_param = param.r;
continue ;
};
};
var map = function (f, param) {
if (!param) {
return /* Empty */0;
}
var l$p = map(f, param.l);
var d$p = Curry._1(f, param.d);
var r$p = map(f, param.r);
return /* Node */{
l: l$p,
v: param.v,
d: d$p,
r: r$p,
h: param.h
};
};
var mapi = function (f, param) {
if (!param) {
return /* Empty */0;
}
var v = param.v;
var l$p = mapi(f, param.l);
var d$p = Curry._2(f, v, param.d);
var r$p = mapi(f, param.r);
return /* Node */{
l: l$p,
v: v,
d: d$p,
r: r$p,
h: param.h
};
};
var fold = function (f, _m, _accu) {
while(true) {
var accu = _accu;
var m = _m;
if (!m) {
return accu;
}
_accu = Curry._3(f, m.v, m.d, fold(f, m.l, accu));
_m = m.r;
continue ;
};
};
var for_all = function (p, _param) {
while(true) {
var param = _param;
if (!param) {
return true;
}
if (!Curry._2(p, param.v, param.d)) {
return false;
}
if (!for_all(p, param.l)) {
return false;
}
_param = param.r;
continue ;
};
};
var exists = function (p, _param) {
while(true) {
var param = _param;
if (!param) {
return false;
}
if (Curry._2(p, param.v, param.d)) {
return true;
}
if (exists(p, param.l)) {
return true;
}
_param = param.r;
continue ;
};
};
var add_min_binding = function (k, x, param) {
if (param) {
return bal(add_min_binding(k, x, param.l), param.v, param.d, param.r);
} else {
return singleton(k, x);
}
};
var add_max_binding = function (k, x, param) {
if (param) {
return bal(param.l, param.v, param.d, add_max_binding(k, x, param.r));
} else {
return singleton(k, x);
}
};
var join = function (l, v, d, r) {
if (!l) {
return add_min_binding(v, d, r);
}
if (!r) {
return add_max_binding(v, d, l);
}
var rh = r.h;
var lh = l.h;
if (lh > (rh + 2 | 0)) {
return bal(l.l, l.v, l.d, join(l.r, v, d, r));
} else if (rh > (lh + 2 | 0)) {
return bal(join(l, v, d, r.l), r.v, r.d, r.r);
} else {
return create(l, v, d, r);
}
};
var concat = function (t1, t2) {
if (!t1) {
return t2;
}
if (!t2) {
return t1;
}
var match = min_binding(t2);
return join(t1, match[0], match[1], remove_min_binding(t2));
};
var concat_or_join = function (t1, v, d, t2) {
if (d !== undefined) {
return join(t1, v, Caml_option.valFromOption(d), t2);
} else {
return concat(t1, t2);
}
};
var split = function (x, param) {
if (!param) {
return [
/* Empty */0,
undefined,
/* Empty */0
];
}
var r = param.r;
var d = param.d;
var v = param.v;
var l = param.l;
var c = Curry._2(Ord.compare, x, v);
if (c === 0) {
return [
l,
Caml_option.some(d),
r
];
}
if (c < 0) {
var match = split(x, l);
return [
match[0],
match[1],
join(match[2], v, d, r)
];
}
var match$1 = split(x, r);
return [
join(l, v, d, match$1[0]),
match$1[1],
match$1[2]
];
};
var merge$1 = function (f, s1, s2) {
if (s1) {
var v1 = s1.v;
if (s1.h >= height(s2)) {
var match = split(v1, s2);
return concat_or_join(merge$1(f, s1.l, match[0]), v1, Curry._3(f, v1, Caml_option.some(s1.d), match[1]), merge$1(f, s1.r, match[2]));
}
} else if (!s2) {
return /* Empty */0;
}
if (s2) {
var v2 = s2.v;
var match$1 = split(v2, s1);
return concat_or_join(merge$1(f, match$1[0], s2.l), v2, Curry._3(f, v2, match$1[1], Caml_option.some(s2.d)), merge$1(f, match$1[2], s2.r));
}
throw {
RE_EXN_ID: "Assert_failure",
_1: [
"mapLabels.ml",
393,
10
],
Error: new Error()
};
};
var union = function (f, s1, s2) {
if (!s1) {
return s2;
}
if (!s2) {
return s1;
}
var d2 = s2.d;
var v2 = s2.v;
var d1 = s1.d;
var v1 = s1.v;
if (s1.h >= s2.h) {
var match = split(v1, s2);
var d2$1 = match[1];
var l = union(f, s1.l, match[0]);
var r = union(f, s1.r, match[2]);
if (d2$1 !== undefined) {
return concat_or_join(l, v1, Curry._3(f, v1, d1, Caml_option.valFromOption(d2$1)), r);
} else {
return join(l, v1, d1, r);
}
}
var match$1 = split(v2, s1);
var d1$1 = match$1[1];
var l$1 = union(f, match$1[0], s2.l);
var r$1 = union(f, match$1[2], s2.r);
if (d1$1 !== undefined) {
return concat_or_join(l$1, v2, Curry._3(f, v2, Caml_option.valFromOption(d1$1), d2), r$1);
} else {
return join(l$1, v2, d2, r$1);
}
};
var filter = function (p, m) {
if (!m) {
return /* Empty */0;
}
var r = m.r;
var d = m.d;
var v = m.v;
var l = m.l;
var l$p = filter(p, l);
var pvd = Curry._2(p, v, d);
var r$p = filter(p, r);
if (pvd) {
if (l === l$p && r === r$p) {
return m;
} else {
return join(l$p, v, d, r$p);
}
} else {
return concat(l$p, r$p);
}
};
var partition = function (p, param) {
if (!param) {
return [
/* Empty */0,
/* Empty */0
];
}
var d = param.d;
var v = param.v;
var match = partition(p, param.l);
var lf = match[1];
var lt = match[0];
var pvd = Curry._2(p, v, d);
var match$1 = partition(p, param.r);
var rf = match$1[1];
var rt = match$1[0];
if (pvd) {
return [
join(lt, v, d, rt),
concat(lf, rf)
];
} else {
return [
concat(lt, rt),
join(lf, v, d, rf)
];
}
};
var cons_enum = function (_m, _e) {
while(true) {
var e = _e;
var m = _m;
if (!m) {
return e;
}
_e = /* More */{
_0: m.v,
_1: m.d,
_2: m.r,
_3: e
};
_m = m.l;
continue ;
};
};
var compare = function (cmp, m1, m2) {
var _e1 = cons_enum(m1, /* End */0);
var _e2 = cons_enum(m2, /* End */0);
while(true) {
var e2 = _e2;
var e1 = _e1;
if (!e1) {
if (e2) {
return -1;
} else {
return 0;
}
}
if (!e2) {
return 1;
}
var c = Curry._2(Ord.compare, e1._0, e2._0);
if (c !== 0) {
return c;
}
var c$1 = Curry._2(cmp, e1._1, e2._1);
if (c$1 !== 0) {
return c$1;
}
_e2 = cons_enum(e2._2, e2._3);
_e1 = cons_enum(e1._2, e1._3);
continue ;
};
};
var equal = function (cmp, m1, m2) {
var _e1 = cons_enum(m1, /* End */0);
var _e2 = cons_enum(m2, /* End */0);
while(true) {
var e2 = _e2;
var e1 = _e1;
if (!e1) {
if (e2) {
return false;
} else {
return true;
}
}
if (!e2) {
return false;
}
if (Curry._2(Ord.compare, e1._0, e2._0) !== 0) {
return false;
}
if (!Curry._2(cmp, e1._1, e2._1)) {
return false;
}
_e2 = cons_enum(e2._2, e2._3);
_e1 = cons_enum(e1._2, e1._3);
continue ;
};
};
var cardinal = function (param) {
if (param) {
return (cardinal(param.l) + 1 | 0) + cardinal(param.r) | 0;
} else {
return 0;
}
};
var bindings_aux = function (_accu, _param) {
while(true) {
var param = _param;
var accu = _accu;
if (!param) {
return accu;
}
_param = param.l;
_accu = {
hd: [
param.v,
param.d
],
tl: bindings_aux(accu, param.r)
};
continue ;
};
};
var bindings = function (s) {
return bindings_aux(/* [] */0, s);
};
return {
height: height,
create: create,
singleton: singleton,
bal: bal,
empty: /* Empty */0,
is_empty: is_empty,
add: add,
find: find,
find_first_aux: find_first_aux,
find_first: find_first,
find_first_opt_aux: find_first_opt_aux,
find_first_opt: find_first_opt,
find_last_aux: find_last_aux,
find_last: find_last,
find_last_opt_aux: find_last_opt_aux,
find_last_opt: find_last_opt,
find_opt: find_opt,
mem: mem,
min_binding: min_binding,
min_binding_opt: min_binding_opt,
max_binding: max_binding,
max_binding_opt: max_binding_opt,
remove_min_binding: remove_min_binding,
remove: remove,
update: update,
iter: iter,
map: map,
mapi: mapi,
fold: fold,
for_all: for_all,
exists: exists,
add_min_binding: add_min_binding,
add_max_binding: add_max_binding,
join: join,
concat: concat,
concat_or_join: concat_or_join,
split: split,
merge: merge$1,
union: union,
filter: filter,
partition: partition,
cons_enum: cons_enum,
compare: compare,
equal: equal,
cardinal: cardinal,
bindings_aux: bindings_aux,
bindings: bindings,
choose: min_binding,
choose_opt: min_binding_opt
};
}
exports.Make = Make;
/* No side effect */