forked from GitHub/gf-core
85 lines
1.7 KiB
C
85 lines
1.7 KiB
C
#ifndef GU_MAP_H_
|
|
#define GU_MAP_H_
|
|
|
|
#include <gu/hash.h>
|
|
#include <gu/mem.h>
|
|
#include <gu/exn.h>
|
|
#include <gu/enum.h>
|
|
|
|
typedef struct GuMapItor GuMapItor;
|
|
|
|
struct GuMapItor {
|
|
void (*fn)(GuMapItor* self, const void* key, void* value,
|
|
GuExn *err);
|
|
};
|
|
|
|
typedef struct GuMap GuMap;
|
|
|
|
GuMap*
|
|
gu_make_map(size_t key_size, GuHasher* hasher,
|
|
size_t value_size, const void* default_value,
|
|
GuPool* pool);
|
|
|
|
#define gu_new_map(K, HASHER, V, DV, POOL) \
|
|
(gu_make_map(sizeof(K), (HASHER), sizeof(V), (DV), (POOL)))
|
|
|
|
#define gu_new_set(K, HASHER, POOL) \
|
|
(gu_make_map(sizeof(K), (HASHER), 0, NULL, (POOL)))
|
|
|
|
#define gu_new_addr_map(K, V, DV, POOL) \
|
|
(gu_make_map(sizeof(K), gu_addr_hasher, sizeof(V), (DV), (POOL)))
|
|
|
|
size_t
|
|
gu_map_count(GuMap* map);
|
|
|
|
void*
|
|
gu_map_find_full(GuMap* ht, void* key_inout);
|
|
|
|
const void*
|
|
gu_map_find_default(GuMap* ht, const void* key);
|
|
|
|
#define gu_map_get(MAP, KEYP, V) \
|
|
(*(V*)gu_map_find_default((MAP), (KEYP)))
|
|
|
|
void*
|
|
gu_map_find(GuMap* ht, const void* key);
|
|
|
|
#define gu_map_set(MAP, KEYP, V, VAL) \
|
|
GU_BEGIN \
|
|
V* gu_map_set_p_ = gu_map_find((MAP), (KEYP)); \
|
|
*gu_map_set_p_ = (VAL); \
|
|
GU_END
|
|
|
|
const void*
|
|
gu_map_find_key(GuMap* ht, const void* key);
|
|
|
|
bool
|
|
gu_map_has(GuMap* ht, const void* key);
|
|
|
|
void*
|
|
gu_map_insert(GuMap* ht, const void* key);
|
|
|
|
#define gu_map_put(MAP, KEYP, V, VAL) \
|
|
GU_BEGIN \
|
|
V* gu_map_put_p_ = gu_map_insert((MAP), (KEYP)); \
|
|
*gu_map_put_p_ = (VAL); \
|
|
GU_END
|
|
|
|
void
|
|
gu_map_iter(GuMap* ht, GuMapItor* itor, GuExn* err);
|
|
|
|
typedef struct {
|
|
const void* key;
|
|
void* value;
|
|
} GuMapKeyValue;
|
|
|
|
GuEnum*
|
|
gu_map_enum(GuMap* ht, GuPool* pool);
|
|
|
|
typedef GuMap GuIntMap;
|
|
|
|
#define gu_new_int_map(VAL_T, DEFAULT, POOL) \
|
|
gu_new_map(int, gu_int_hasher, VAL_T, DEFAULT, POOL)
|
|
|
|
#endif // GU_MAP_H_
|