astro-ghostcms/.pnpm-store/v3/files/47/6fc4379d6705878b775960f4db5...

19 lines
560 B
Plaintext
Raw Normal View History

2024-02-14 14:10:47 +00:00
// Port of lower_bound from https://en.cppreference.com/w/cpp/algorithm/lower_bound
// Used to compute insertion index to keep queue sorted after insertion
export default function lowerBound(array, value, comparator) {
let first = 0;
let count = array.length;
while (count > 0) {
const step = Math.trunc(count / 2);
let it = first + step;
if (comparator(array[it], value) <= 0) {
first = ++it;
count -= step + 1;
}
else {
count = step;
}
}
return first;
}