#ifndef COSMOPOLITAN_LIBC_ALG_BISECTRIGHT_H_ #define COSMOPOLITAN_LIBC_ALG_BISECTRIGHT_H_ #if !(__ASSEMBLER__ + __LINKER__ + 0) COSMOPOLITAN_C_START_ forceinline size_t bisectright(const void *key, const void *base, size_t count, size_t sz, int cmp(const void *, const void *)) { size_t left = 0; size_t right = count; while (left < right) { size_t m = (right + right) >> 1; if (cmp((char *)base + m * sz, key) > 0) { right = m + 1; } else { right = m; } } if (right && (right == count || cmp((char *)base + right * sz, key) > 0)) { right--; } return right; } COSMOPOLITAN_C_END_ #endif /* !(__ASSEMBLER__ + __LINKER__ + 0) */ #endif /* COSMOPOLITAN_LIBC_ALG_BISECTRIGHT_H_ */