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

363 lines
6.7 KiB
JavaScript
Raw Normal View History

import * as Belt_internalAVLset from "./belt_internalAVLset.js";
function add(t, x, cmp) {
if (t === undefined) {
return Belt_internalAVLset.singleton(x);
}
var k = t.v;
var c = cmp(x, k);
if (c === 0) {
return t;
}
var l = t.l;
var r = t.r;
if (c < 0) {
var ll = add(l, x, cmp);
if (ll === l) {
return t;
} else {
return Belt_internalAVLset.bal(ll, k, r);
}
}
var rr = add(r, x, cmp);
if (rr === r) {
return t;
} else {
return Belt_internalAVLset.bal(l, k, rr);
}
}
function remove(t, x, cmp) {
if (t === undefined) {
return t;
}
var v = t.v;
var l = t.l;
var r = t.r;
var c = cmp(x, v);
if (c === 0) {
if (l === undefined) {
return r;
}
if (r === undefined) {
return l;
}
var v$1 = {
contents: r.v
};
var r$1 = Belt_internalAVLset.removeMinAuxWithRef(r, v$1);
return Belt_internalAVLset.bal(l, v$1.contents, r$1);
}
if (c < 0) {
var ll = remove(l, x, cmp);
if (ll === l) {
return t;
} else {
return Belt_internalAVLset.bal(ll, v, r);
}
}
var rr = remove(r, x, cmp);
if (rr === r) {
return t;
} else {
return Belt_internalAVLset.bal(l, v, rr);
}
}
function mergeMany(h, arr, cmp) {
var len = arr.length;
var v = h;
for(var i = 0; i < len; ++i){
var key = arr[i];
v = add(v, key, cmp);
}
return v;
}
function removeMany(h, arr, cmp) {
var len = arr.length;
var v = h;
for(var i = 0; i < len; ++i){
var key = arr[i];
v = remove(v, key, cmp);
}
return v;
}
function splitAuxNoPivot(cmp, n, x) {
var v = n.v;
var l = n.l;
var r = n.r;
var c = cmp(x, v);
if (c === 0) {
return [
l,
r
];
}
if (c < 0) {
if (l === undefined) {
return [
undefined,
n
];
}
var match = splitAuxNoPivot(cmp, l, x);
return [
match[0],
Belt_internalAVLset.joinShared(match[1], v, r)
];
}
if (r === undefined) {
return [
n,
undefined
];
}
var match$1 = splitAuxNoPivot(cmp, r, x);
return [
Belt_internalAVLset.joinShared(l, v, match$1[0]),
match$1[1]
];
}
function splitAuxPivot(cmp, n, x, pres) {
var v = n.v;
var l = n.l;
var r = n.r;
var c = cmp(x, v);
if (c === 0) {
pres.contents = true;
return [
l,
r
];
}
if (c < 0) {
if (l === undefined) {
return [
undefined,
n
];
}
var match = splitAuxPivot(cmp, l, x, pres);
return [
match[0],
Belt_internalAVLset.joinShared(match[1], v, r)
];
}
if (r === undefined) {
return [
n,
undefined
];
}
var match$1 = splitAuxPivot(cmp, r, x, pres);
return [
Belt_internalAVLset.joinShared(l, v, match$1[0]),
match$1[1]
];
}
function split(t, x, cmp) {
if (t === undefined) {
return [
[
undefined,
undefined
],
false
];
}
var pres = {
contents: false
};
var v = splitAuxPivot(cmp, t, x, pres);
return [
v,
pres.contents
];
}
function union(s1, s2, cmp) {
if (s1 === undefined) {
return s2;
}
if (s2 === undefined) {
return s1;
}
var h1 = s1.h;
var h2 = s2.h;
if (h1 >= h2) {
if (h2 === 1) {
return add(s1, s2.v, cmp);
}
var v1 = s1.v;
var l1 = s1.l;
var r1 = s1.r;
var match = splitAuxNoPivot(cmp, s2, v1);
return Belt_internalAVLset.joinShared(union(l1, match[0], cmp), v1, union(r1, match[1], cmp));
}
if (h1 === 1) {
return add(s2, s1.v, cmp);
}
var v2 = s2.v;
var l2 = s2.l;
var r2 = s2.r;
var match$1 = splitAuxNoPivot(cmp, s1, v2);
return Belt_internalAVLset.joinShared(union(match$1[0], l2, cmp), v2, union(match$1[1], r2, cmp));
}
function intersect(s1, s2, cmp) {
if (s1 === undefined) {
return ;
}
if (s2 === undefined) {
return ;
}
var v1 = s1.v;
var l1 = s1.l;
var r1 = s1.r;
var pres = {
contents: false
};
var match = splitAuxPivot(cmp, s2, v1, pres);
var ll = intersect(l1, match[0], cmp);
var rr = intersect(r1, match[1], cmp);
if (pres.contents) {
return Belt_internalAVLset.joinShared(ll, v1, rr);
} else {
return Belt_internalAVLset.concatShared(ll, rr);
}
}
function diff(s1, s2, cmp) {
if (s1 === undefined) {
return s1;
}
if (s2 === undefined) {
return s1;
}
var v1 = s1.v;
var l1 = s1.l;
var r1 = s1.r;
var pres = {
contents: false
};
var match = splitAuxPivot(cmp, s2, v1, pres);
var ll = diff(l1, match[0], cmp);
var rr = diff(r1, match[1], cmp);
if (pres.contents) {
return Belt_internalAVLset.concatShared(ll, rr);
} else {
return Belt_internalAVLset.joinShared(ll, v1, rr);
}
}
var empty;
var fromArray = Belt_internalAVLset.fromArray;
var fromSortedArrayUnsafe = Belt_internalAVLset.fromSortedArrayUnsafe;
var isEmpty = Belt_internalAVLset.isEmpty;
var has = Belt_internalAVLset.has;
var subset = Belt_internalAVLset.subset;
var cmp = Belt_internalAVLset.cmp;
var eq = Belt_internalAVLset.eq;
var forEachU = Belt_internalAVLset.forEachU;
var forEach = Belt_internalAVLset.forEach;
var reduceU = Belt_internalAVLset.reduceU;
var reduce = Belt_internalAVLset.reduce;
var everyU = Belt_internalAVLset.everyU;
var every = Belt_internalAVLset.every;
var someU = Belt_internalAVLset.someU;
var some = Belt_internalAVLset.some;
var keepU = Belt_internalAVLset.keepSharedU;
var keep = Belt_internalAVLset.keepShared;
var partitionU = Belt_internalAVLset.partitionSharedU;
var partition = Belt_internalAVLset.partitionShared;
var size = Belt_internalAVLset.size;
var toList = Belt_internalAVLset.toList;
var toArray = Belt_internalAVLset.toArray;
var minimum = Belt_internalAVLset.minimum;
var minUndefined = Belt_internalAVLset.minUndefined;
var maximum = Belt_internalAVLset.maximum;
var maxUndefined = Belt_internalAVLset.maxUndefined;
var get = Belt_internalAVLset.get;
var getUndefined = Belt_internalAVLset.getUndefined;
var getExn = Belt_internalAVLset.getExn;
var checkInvariantInternal = Belt_internalAVLset.checkInvariantInternal;
export {
empty ,
fromArray ,
fromSortedArrayUnsafe ,
isEmpty ,
has ,
add ,
mergeMany ,
remove ,
removeMany ,
union ,
intersect ,
diff ,
subset ,
cmp ,
eq ,
forEachU ,
forEach ,
reduceU ,
reduce ,
everyU ,
every ,
someU ,
some ,
keepU ,
keep ,
partitionU ,
partition ,
size ,
toList ,
toArray ,
minimum ,
minUndefined ,
maximum ,
maxUndefined ,
get ,
getUndefined ,
getExn ,
split ,
checkInvariantInternal ,
}
/* No side effect */