shithub: femtolisp

ref: 518cfe8d0c1a6eb4f90cdb68861fe0cd3a2e0d74
dir: /htable.h/

View raw version
#pragma once

#define HT_N_INLINE 32

typedef struct {
	void **table;
	uint32_t size;
	// this is to skip over non-items in for-each
	// FIXME(sigrid): in a multithreaded environment this isn't enough
	uint32_t i;
	void *_space[HT_N_INLINE];
}fl_aligned(8) htable_t;

// define this to be an invalid key/value
#define HT_NOTFOUND ((void*)1)

// initialize and free
htable_t *htable_new(htable_t *h, size_t size);
void htable_free(htable_t *h);

// clear and (possibly) change size
void htable_reset(htable_t *h, size_t sz);