mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-02-01 03:53:33 +00:00
ea0b5d9d1c
A new rollup tool now exists for flattening out the headers in a way that works better for our purposes than cpp. A lot of the API clutter has been removed. APIs that aren't a sure thing in terms of general recommendation are now marked internal. There's now a smoke test for the amalgamation archive and gigantic header file. So we can now guarantee you can use this project on the easiest difficulty setting without the gigantic repository. A website is being created, which is currently a work in progress: https://justine.storage.googleapis.com/cosmopolitan/index.html
27 lines
1.5 KiB
C
27 lines
1.5 KiB
C
#ifndef COSMOPOLITAN_LIBC_ALG_CRITBIT0_H_
|
|
#define COSMOPOLITAN_LIBC_ALG_CRITBIT0_H_
|
|
#if !(__ASSEMBLER__ + __LINKER__ + 0)
|
|
COSMOPOLITAN_C_START_
|
|
/*───────────────────────────────────────────────────────────────────────────│─╗
|
|
│ cosmopolitan § data structures » critical bit tree (for c strings) ─╬─│┼
|
|
╚────────────────────────────────────────────────────────────────────────────│*/
|
|
|
|
struct critbit0 {
|
|
void *root;
|
|
size_t count;
|
|
};
|
|
|
|
bool critbit0_contains(struct critbit0 *, const char *) nothrow nosideeffect
|
|
paramsnonnull();
|
|
bool critbit0_insert(struct critbit0 *, const char *) paramsnonnull();
|
|
bool critbit0_delete(struct critbit0 *, const char *) nothrow paramsnonnull();
|
|
void critbit0_clear(struct critbit0 *) nothrow paramsnonnull();
|
|
char *critbit0_get(struct critbit0 *, const char *);
|
|
intptr_t critbit0_allprefixed(struct critbit0 *, const char *,
|
|
intptr_t (*)(const char *, void *), void *)
|
|
paramsnonnull((1, 2, 3)) nothrow;
|
|
bool critbit0_emplace(struct critbit0 *, char *, size_t) paramsnonnull();
|
|
|
|
COSMOPOLITAN_C_END_
|
|
#endif /* !(__ASSEMBLER__ + __LINKER__ + 0) */
|
|
#endif /* COSMOPOLITAN_LIBC_ALG_CRITBIT0_H_ */
|