forked from luguangmeng/BAIYI
54 lines
2.2 KiB
C
54 lines
2.2 KiB
C
// Copyright 2020 Joshua J Baker. All rights reserved.
|
|
// Use of this source code is governed by an MIT-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
#ifndef HASHMAP_H
|
|
#define HASHMAP_H
|
|
|
|
#include <stdbool.h>
|
|
#include <stddef.h>
|
|
#include <stdint.h>
|
|
|
|
struct hashmap;
|
|
|
|
struct hashmap *hashmap_new(size_t elsize, size_t cap, uint64_t seed0,
|
|
uint64_t seed1,
|
|
uint64_t (*hash)(const void *item, uint64_t seed0, uint64_t seed1),
|
|
int (*compare)(const void *a, const void *b, void *udata),
|
|
void (*elfree)(void *item),
|
|
void *udata);
|
|
|
|
struct hashmap *hashmap_new_with_allocator(void *(*malloc)(size_t),
|
|
void *(*realloc)(void *, size_t), void (*free)(void*), size_t elsize,
|
|
size_t cap, uint64_t seed0, uint64_t seed1,
|
|
uint64_t (*hash)(const void *item, uint64_t seed0, uint64_t seed1),
|
|
int (*compare)(const void *a, const void *b, void *udata),
|
|
void (*elfree)(void *item),
|
|
void *udata);
|
|
|
|
void hashmap_free(struct hashmap *map);
|
|
void hashmap_clear(struct hashmap *map, bool update_cap);
|
|
size_t hashmap_count(struct hashmap *map);
|
|
bool hashmap_oom(struct hashmap *map);
|
|
const void *hashmap_get(struct hashmap *map, const void *item);
|
|
const void *hashmap_set(struct hashmap *map, const void *item);
|
|
const void *hashmap_delete(struct hashmap *map, const void *item);
|
|
const void *hashmap_probe(struct hashmap *map, uint64_t position);
|
|
bool hashmap_scan(struct hashmap *map, bool (*iter)(const void *item, void *udata), void *udata);
|
|
bool hashmap_iter(struct hashmap *map, size_t *i, void **item);
|
|
|
|
uint64_t hashmap_sip(const void *data, size_t len, uint64_t seed0, uint64_t seed1);
|
|
uint64_t hashmap_murmur(const void *data, size_t len, uint64_t seed0, uint64_t seed1);
|
|
uint64_t hashmap_xxhash3(const void *data, size_t len, uint64_t seed0, uint64_t seed1);
|
|
|
|
const void *hashmap_get_with_hash(struct hashmap *map, const void *key, uint64_t hash);
|
|
const void *hashmap_delete_with_hash(struct hashmap *map, const void *key, uint64_t hash);
|
|
const void *hashmap_set_with_hash(struct hashmap *map, const void *item, uint64_t hash);
|
|
void hashmap_set_grow_by_power(struct hashmap *map, size_t power);
|
|
|
|
|
|
// DEPRECATED: use `hashmap_new_with_allocator`
|
|
void hashmap_set_allocator(void *(*malloc)(size_t), void (*free)(void*));
|
|
|
|
#endif
|