2020-11-25 16:19:00 +00:00
|
|
|
#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;
|
|
|
|
};
|
|
|
|
|
Import C++ Standard Template Library
You can now use the hardest fastest and most dangerous language there is
with Cosmopolitan. So far about 75% of LLVM libcxx has been added. A few
breaking changes needed to be made to help this go smoothly.
- Rename nothrow to dontthrow
- Rename nodiscard to dontdiscard
- Add some libm functions, e.g. lgamma, nan, etc.
- Change intmax_t from int128 to int64 like everything else
- Introduce %jjd formatting directive for int128_t
- Introduce strtoi128(), strtou128(), etc.
- Rename bsrmax() to bsr128()
Some of the templates that should be working currently are std::vector,
std::string, std::map, std::set, std::deque, etc.
2022-03-22 12:51:41 +00:00
|
|
|
bool critbit0_contains(struct critbit0 *, const char *) dontthrow nosideeffect
|
2020-11-25 16:19:00 +00:00
|
|
|
paramsnonnull();
|
2022-07-22 11:19:01 +00:00
|
|
|
int critbit0_insert(struct critbit0 *, const char *) paramsnonnull();
|
Import C++ Standard Template Library
You can now use the hardest fastest and most dangerous language there is
with Cosmopolitan. So far about 75% of LLVM libcxx has been added. A few
breaking changes needed to be made to help this go smoothly.
- Rename nothrow to dontthrow
- Rename nodiscard to dontdiscard
- Add some libm functions, e.g. lgamma, nan, etc.
- Change intmax_t from int128 to int64 like everything else
- Introduce %jjd formatting directive for int128_t
- Introduce strtoi128(), strtou128(), etc.
- Rename bsrmax() to bsr128()
Some of the templates that should be working currently are std::vector,
std::string, std::map, std::set, std::deque, etc.
2022-03-22 12:51:41 +00:00
|
|
|
bool critbit0_delete(struct critbit0 *, const char *) dontthrow paramsnonnull();
|
|
|
|
void critbit0_clear(struct critbit0 *) dontthrow paramsnonnull();
|
2020-11-25 16:19:00 +00:00
|
|
|
char *critbit0_get(struct critbit0 *, const char *);
|
|
|
|
intptr_t critbit0_allprefixed(struct critbit0 *, const char *,
|
|
|
|
intptr_t (*)(const char *, void *), void *)
|
Import C++ Standard Template Library
You can now use the hardest fastest and most dangerous language there is
with Cosmopolitan. So far about 75% of LLVM libcxx has been added. A few
breaking changes needed to be made to help this go smoothly.
- Rename nothrow to dontthrow
- Rename nodiscard to dontdiscard
- Add some libm functions, e.g. lgamma, nan, etc.
- Change intmax_t from int128 to int64 like everything else
- Introduce %jjd formatting directive for int128_t
- Introduce strtoi128(), strtou128(), etc.
- Rename bsrmax() to bsr128()
Some of the templates that should be working currently are std::vector,
std::string, std::map, std::set, std::deque, etc.
2022-03-22 12:51:41 +00:00
|
|
|
paramsnonnull((1, 2, 3)) dontthrow;
|
2022-07-22 11:19:01 +00:00
|
|
|
int critbit0_emplace(struct critbit0 *, char *, size_t) paramsnonnull();
|
2020-11-25 16:19:00 +00:00
|
|
|
|
|
|
|
COSMOPOLITAN_C_END_
|
|
|
|
#endif /* !(__ASSEMBLER__ + __LINKER__ + 0) */
|
|
|
|
#endif /* COSMOPOLITAN_LIBC_ALG_CRITBIT0_H_ */
|