diff options
author | Mattias Andrée <maandree@kth.se> | 2023-07-04 19:37:10 +0200 |
---|---|---|
committer | Mattias Andrée <maandree@kth.se> | 2023-07-04 19:37:10 +0200 |
commit | aab65f6d1793d2ded2629437afab007ba3db0bf1 (patch) | |
tree | 5750c8006bc8b280ed63e587d1062356747fc63d /bindex_r.c | |
parent | libsimple_localtime.3: fix formatting (diff) | |
download | libsimple-aab65f6d1793d2ded2629437afab007ba3db0bf1.tar.gz libsimple-aab65f6d1793d2ded2629437afab007ba3db0bf1.tar.bz2 libsimple-aab65f6d1793d2ded2629437afab007ba3db0bf1.tar.xz |
Add bindex and bindex_r
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to 'bindex_r.c')
-rw-r--r-- | bindex_r.c | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/bindex_r.c b/bindex_r.c new file mode 100644 index 0000000..805e74a --- /dev/null +++ b/bindex_r.c @@ -0,0 +1,39 @@ +/* See LICENSE file for copyright and license details. */ +#include "common.h" +#ifndef TEST + + +ssize_t +libsimple_bindex_r(const void *key, const void *base, size_t nel, size_t width, + int (*compar)(const void *, const void *, void *), void *arg) +{ + size_t index = 0, offset = 0; + int cmp; + + while (nel) { + index = offset + nel / 2; + cmp = (*compar)(key, (const char *)base + width * index, arg); + if (cmp < 0) { + nel /= 2; + } else if (cmp > 0) { + offset = index += 1; + nel -= nel / 2 + 1; + } else { + return (ssize_t)index; + } + } + + return ~(ssize_t)index; +} + + +#else +#include "test.h" + +int +main(void) /* TODO add test */ +{ + return 0; +} + +#endif |