2023-12-06 16:31:51 -05:00

44 lines
1.4 KiB
C

/*
* SPDX-FileCopyrightText: Stone Tickle <lattis@mochiro.moe>
* SPDX-License-Identifier: GPL-3.0-only
*/
#ifndef MUON_DATA_HASH_H
#define MUON_DATA_HASH_H
#include <stddef.h>
#include <stdint.h>
#include "datastructures/arr.h"
#include "datastructures/iterator.h"
struct hash;
typedef bool ((*hash_keycmp)(const struct hash *h, const void *a, const void *b));
typedef uint64_t ((*hash_func)(const struct hash *h, const void *k));
struct hash {
struct arr meta, e, keys;
size_t cap, len, load, max_load, capm;
hash_keycmp keycmp;
hash_func hash_func;
};
typedef enum iteration_result ((*hash_with_keys_iterator_func)(void *ctx, const void *key, uint64_t val));
void hash_init(struct hash *h, size_t cap, uint32_t keysize);
void hash_init_str(struct hash *h, size_t cap);
void hash_destroy(struct hash *h);
uint64_t *hash_get(const struct hash *h, const void *key);
uint64_t *hash_get_strn(const struct hash *h, const char *str, uint64_t len);
void hash_set(struct hash *h, const void *key, uint64_t val);
void hash_set_strn(struct hash *h, const char *key, uint64_t len, uint64_t val);
void hash_unset(struct hash *h, const void *key);
void hash_unset_strn(struct hash *h, const char *s, uint64_t len);
void hash_clear(struct hash *h);
void hash_for_each(struct hash *h, void *ctx, iterator_func ifnc);
void hash_for_each_with_keys(struct hash *h, void *ctx, hash_with_keys_iterator_func ifnc);
#endif