xref: /aosp_15_r20/external/musl/src/search/lsearch.c (revision c9945492fdd68bbe62686c5b452b4dc1be3f8453)
1*c9945492SAndroid Build Coastguard Worker #include <search.h>
2*c9945492SAndroid Build Coastguard Worker #include <string.h>
3*c9945492SAndroid Build Coastguard Worker 
lsearch(const void * key,void * base,size_t * nelp,size_t width,int (* compar)(const void *,const void *))4*c9945492SAndroid Build Coastguard Worker void *lsearch(const void *key, void *base, size_t *nelp, size_t width,
5*c9945492SAndroid Build Coastguard Worker 	int (*compar)(const void *, const void *))
6*c9945492SAndroid Build Coastguard Worker {
7*c9945492SAndroid Build Coastguard Worker 	char (*p)[width] = base;
8*c9945492SAndroid Build Coastguard Worker 	size_t n = *nelp;
9*c9945492SAndroid Build Coastguard Worker 	size_t i;
10*c9945492SAndroid Build Coastguard Worker 
11*c9945492SAndroid Build Coastguard Worker 	for (i = 0; i < n; i++)
12*c9945492SAndroid Build Coastguard Worker 		if (compar(key, p[i]) == 0)
13*c9945492SAndroid Build Coastguard Worker 			return p[i];
14*c9945492SAndroid Build Coastguard Worker 	*nelp = n+1;
15*c9945492SAndroid Build Coastguard Worker 	return memcpy(p[n], key, width);
16*c9945492SAndroid Build Coastguard Worker }
17*c9945492SAndroid Build Coastguard Worker 
lfind(const void * key,const void * base,size_t * nelp,size_t width,int (* compar)(const void *,const void *))18*c9945492SAndroid Build Coastguard Worker void *lfind(const void *key, const void *base, size_t *nelp,
19*c9945492SAndroid Build Coastguard Worker 	size_t width, int (*compar)(const void *, const void *))
20*c9945492SAndroid Build Coastguard Worker {
21*c9945492SAndroid Build Coastguard Worker 	char (*p)[width] = (void *)base;
22*c9945492SAndroid Build Coastguard Worker 	size_t n = *nelp;
23*c9945492SAndroid Build Coastguard Worker 	size_t i;
24*c9945492SAndroid Build Coastguard Worker 
25*c9945492SAndroid Build Coastguard Worker 	for (i = 0; i < n; i++)
26*c9945492SAndroid Build Coastguard Worker 		if (compar(key, p[i]) == 0)
27*c9945492SAndroid Build Coastguard Worker 			return p[i];
28*c9945492SAndroid Build Coastguard Worker 	return 0;
29*c9945492SAndroid Build Coastguard Worker }
30*c9945492SAndroid Build Coastguard Worker 
31*c9945492SAndroid Build Coastguard Worker 
32