'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 */