source: trunk/minix/lib/ansi/bsearch.c@ 12

Last change on this file since 12 was 9, checked in by Mattia Monga, 14 years ago

Minix 3.1.2a

File size: 774 bytes
Line 
1/*
2 * (c) copyright 1987 by the Vrije Universiteit, Amsterdam, The Netherlands.
3 * See the copyright notice in the ACK home directory, in the file "Copyright".
4 */
5/* $Header: /cvsup/minix/src/lib/ansi/bsearch.c,v 1.1.1.1 2005/04/21 14:56:04 beng Exp $ */
6
7#include <stdlib.h>
8
9void *
10bsearch(register const void *key, register const void *base,
11 register size_t nmemb, register size_t size,
12 int (*compar)(const void *, const void *))
13{
14 register const void *mid_point;
15 register int cmp;
16
17 while (nmemb > 0) {
18 mid_point = (char *)base + size * (nmemb >> 1);
19 if ((cmp = (*compar)(key, mid_point)) == 0)
20 return (void *)mid_point;
21 if (cmp >= 0) {
22 base = (char *)mid_point + size;
23 nmemb = (nmemb - 1) >> 1;
24 } else
25 nmemb >>= 1;
26 }
27 return (void *)NULL;
28}
Note: See TracBrowser for help on using the repository browser.