mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-07-06 03:08:31 +00:00
Make improvements
- wcsstr() is now linearly complex - strstr16() is now linearly complex - strstr() is now vectorized on aarch64 (10x) - strstr() now uses KMP on pathological cases - memmem() is now vectorized on aarch64 (10x) - memmem() now uses KMP on pathological cases - Disable shared_ptr::owner_before until fixed - Make iswlower(), iswupper() consistent with glibc - Remove figure space from iswspace() implementation - Include line and paragraph separator in iswcntrl() - Use Musl wcwidth(), iswalpha(), iswpunct(), towlower(), towupper()
This commit is contained in:
parent
e1528a71e2
commit
7c83f4abc8
67 changed files with 5602 additions and 5165 deletions
20
third_party/musl/bsearch.c
vendored
Normal file
20
third_party/musl/bsearch.c
vendored
Normal file
|
@ -0,0 +1,20 @@
|
|||
#include <stdlib.h>
|
||||
|
||||
void *bsearch(const void *key, const void *base, size_t nel, size_t width, int (*cmp)(const void *, const void *))
|
||||
{
|
||||
void *try;
|
||||
int sign;
|
||||
while (nel > 0) {
|
||||
try = (char *)base + width*(nel/2);
|
||||
sign = cmp(key, try);
|
||||
if (sign < 0) {
|
||||
nel /= 2;
|
||||
} else if (sign > 0) {
|
||||
base = (char *)try + width;
|
||||
nel -= nel/2+1;
|
||||
} else {
|
||||
return try;
|
||||
}
|
||||
}
|
||||
return NULL;
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue