libds
is a library providing simple datastructures. It is designed to be portable (to the point only
requiring memory allocation and ffreestanding environment).
ds/random.h
- random number generatords/array.h
- resizable array listds/btree.h
- ballanced tree (red/black tree)ds/hmap.h
- hashmapds/queue.h
- (FIFO) queueds/funcops.h
- standard function interfaces used by previous data structures (along with some defined concrete functions)
libds
requires these headers to be present at build environment:
<stdbool.h>
<stddef.h>
<stdint.h>
libds
also requires these extern functions:
extern void* malloc(size_t n)
extern void* calloc(size_t num, size_t n)
extern void* realloc(void* a, size_t n)
extern void free(void* a)
extern int strcmp(const char* a, const char* b)
extern void* memset(void* c, int v, size_t s)
To build libds, simply invoke make all
in the root directory. You will need to provide suitable SYSROOT
argument or a PREFIX
argument. INCLUDE
argument can be overwritten to change where headers will be copied to (they will always be in INCLUDE
/ds
directory).