import * as Curry from "./curry.js"; import * as Caml_option from "./caml_option.js"; import * as Belt_internalMapInt from "./belt_internalMapInt.js"; import * as Belt_internalAVLtree from "./belt_internalAVLtree.js"; function set(t, newK, newD) { if (t === undefined) { return Belt_internalAVLtree.singleton(newK, newD); } var k = t.k; if (newK === k) { return Belt_internalAVLtree.updateValue(t, newD); } var v = t.v; if (newK < k) { return Belt_internalAVLtree.bal(set(t.l, newK, newD), k, v, t.r); } else { return Belt_internalAVLtree.bal(t.l, k, v, set(t.r, newK, newD)); } } function updateU(t, x, f) { if (t !== undefined) { var k = t.k; if (x === k) { var data = f(Caml_option.some(t.v)); if (data !== undefined) { return Belt_internalAVLtree.updateValue(t, Caml_option.valFromOption(data)); } var l = t.l; var r = t.r; if (l === undefined) { return r; } if (r === undefined) { return l; } var kr = { contents: r.k }; var vr = { contents: r.v }; var r$1 = Belt_internalAVLtree.removeMinAuxWithRef(r, kr, vr); return Belt_internalAVLtree.bal(l, kr.contents, vr.contents, r$1); } var v = t.v; var l$1 = t.l; var r$2 = t.r; if (x < k) { var ll = updateU(l$1, x, f); if (l$1 === ll) { return t; } else { return Belt_internalAVLtree.bal(ll, k, v, r$2); } } var rr = updateU(r$2, x, f); if (r$2 === rr) { return t; } else { return Belt_internalAVLtree.bal(l$1, k, v, rr); } } var data$1 = f(undefined); if (data$1 !== undefined) { return Belt_internalAVLtree.singleton(x, Caml_option.valFromOption(data$1)); } else { return t; } } function update(t, x, f) { return updateU(t, x, Curry.__1(f)); } function removeAux(n, x) { var v = n.k; var l = n.l; var r = n.r; if (x === v) { if (l === undefined) { return r; } if (r === undefined) { return l; } var kr = { contents: r.k }; var vr = { contents: r.v }; var r$1 = Belt_internalAVLtree.removeMinAuxWithRef(r, kr, vr); return Belt_internalAVLtree.bal(l, kr.contents, vr.contents, r$1); } if (x < v) { if (l === undefined) { return n; } var ll = removeAux(l, x); if (ll === l) { return n; } else { return Belt_internalAVLtree.bal(ll, v, n.v, r); } } if (r === undefined) { return n; } var rr = removeAux(r, x); return Belt_internalAVLtree.bal(l, v, n.v, rr); } function remove(n, x) { if (n !== undefined) { return removeAux(n, x); } } function removeMany(t, keys) { var len = keys.length; if (t !== undefined) { var _t = t; var _i = 0; while(true) { var i = _i; var t$1 = _t; if (i >= len) { return t$1; } var ele = keys[i]; var u = removeAux(t$1, ele); if (u === undefined) { return u; } _i = i + 1 | 0; _t = u; continue ; }; } } function mergeMany(h, arr) { var len = arr.length; var v = h; for(var i = 0; i < len; ++i){ var match = arr[i]; v = set(v, match[0], match[1]); } return v; } var empty; var isEmpty = Belt_internalAVLtree.isEmpty; var has = Belt_internalMapInt.has; var cmpU = Belt_internalMapInt.cmpU; var cmp = Belt_internalMapInt.cmp; var eqU = Belt_internalMapInt.eqU; var eq = Belt_internalMapInt.eq; var findFirstByU = Belt_internalAVLtree.findFirstByU; var findFirstBy = Belt_internalAVLtree.findFirstBy; var forEachU = Belt_internalAVLtree.forEachU; var forEach = Belt_internalAVLtree.forEach; var reduceU = Belt_internalAVLtree.reduceU; var reduce = Belt_internalAVLtree.reduce; var everyU = Belt_internalAVLtree.everyU; var every = Belt_internalAVLtree.every; var someU = Belt_internalAVLtree.someU; var some = Belt_internalAVLtree.some; var size = Belt_internalAVLtree.size; var toList = Belt_internalAVLtree.toList; var toArray = Belt_internalAVLtree.toArray; var fromArray = Belt_internalMapInt.fromArray; var keysToArray = Belt_internalAVLtree.keysToArray; var valuesToArray = Belt_internalAVLtree.valuesToArray; var minKey = Belt_internalAVLtree.minKey; var minKeyUndefined = Belt_internalAVLtree.minKeyUndefined; var maxKey = Belt_internalAVLtree.maxKey; var maxKeyUndefined = Belt_internalAVLtree.maxKeyUndefined; var minimum = Belt_internalAVLtree.minimum; var minUndefined = Belt_internalAVLtree.minUndefined; var maximum = Belt_internalAVLtree.maximum; var maxUndefined = Belt_internalAVLtree.maxUndefined; var get = Belt_internalMapInt.get; var getUndefined = Belt_internalMapInt.getUndefined; var getWithDefault = Belt_internalMapInt.getWithDefault; var getExn = Belt_internalMapInt.getExn; var checkInvariantInternal = Belt_internalAVLtree.checkInvariantInternal; var mergeU = Belt_internalMapInt.mergeU; var merge = Belt_internalMapInt.merge; var keepU = Belt_internalAVLtree.keepSharedU; var keep = Belt_internalAVLtree.keepShared; var partitionU = Belt_internalAVLtree.partitionSharedU; var partition = Belt_internalAVLtree.partitionShared; var split = Belt_internalMapInt.split; var mapU = Belt_internalAVLtree.mapU; var map = Belt_internalAVLtree.map; var mapWithKeyU = Belt_internalAVLtree.mapWithKeyU; var mapWithKey = Belt_internalAVLtree.mapWithKey; export { empty , isEmpty , has , cmpU , cmp , eqU , eq , findFirstByU , findFirstBy , forEachU , forEach , reduceU , reduce , everyU , every , someU , some , size , toList , toArray , fromArray , keysToArray , valuesToArray , minKey , minKeyUndefined , maxKey , maxKeyUndefined , minimum , minUndefined , maximum , maxUndefined , get , getUndefined , getWithDefault , getExn , checkInvariantInternal , remove , removeMany , set , updateU , update , mergeU , merge , mergeMany , keepU , keep , partitionU , partition , split , mapU , map , mapWithKeyU , mapWithKey , } /* No side effect */