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

361 lines
7.3 KiB
JavaScript
Raw Normal View History

'use strict';
var Belt_internalAVLset = require("./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;
exports.empty = empty;
exports.fromArray = fromArray;
exports.fromSortedArrayUnsafe = fromSortedArrayUnsafe;
exports.isEmpty = isEmpty;
exports.has = has;
exports.add = add;
exports.mergeMany = mergeMany;
exports.remove = remove;
exports.removeMany = removeMany;
exports.union = union;
exports.intersect = intersect;
exports.diff = diff;
exports.subset = subset;
exports.cmp = cmp;
exports.eq = eq;
exports.forEachU = forEachU;
exports.forEach = forEach;
exports.reduceU = reduceU;
exports.reduce = reduce;
exports.everyU = everyU;
exports.every = every;
exports.someU = someU;
exports.some = some;
exports.keepU = keepU;
exports.keep = keep;
exports.partitionU = partitionU;
exports.partition = partition;
exports.size = size;
exports.toList = toList;
exports.toArray = toArray;
exports.minimum = minimum;
exports.minUndefined = minUndefined;
exports.maximum = maximum;
exports.maxUndefined = maxUndefined;
exports.get = get;
exports.getUndefined = getUndefined;
exports.getExn = getExn;
exports.split = split;
exports.checkInvariantInternal = checkInvariantInternal;
/* No side effect */