diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-09 13:34:27 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-09 13:34:27 +0000 |
commit | 4dbdc42d9e7c3968ff7f690d00680419c9b8cb0f (patch) | |
tree | 47c1d492e9c956c1cd2b74dbd3b9d8b0db44dc4e /oidmap.c | |
parent | Initial commit. (diff) | |
download | git-4dbdc42d9e7c3968ff7f690d00680419c9b8cb0f.tar.xz git-4dbdc42d9e7c3968ff7f690d00680419c9b8cb0f.zip |
Adding upstream version 1:2.43.0.upstream/1%2.43.0
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'oidmap.c')
-rw-r--r-- | oidmap.c | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/oidmap.c b/oidmap.c new file mode 100644 index 0000000..8b1bc4d --- /dev/null +++ b/oidmap.c @@ -0,0 +1,62 @@ +#include "git-compat-util.h" +#include "hash.h" +#include "oidmap.h" + +static int oidmap_neq(const void *hashmap_cmp_fn_data UNUSED, + const struct hashmap_entry *e1, + const struct hashmap_entry *e2, + const void *keydata) +{ + const struct oidmap_entry *a, *b; + + a = container_of(e1, const struct oidmap_entry, internal_entry); + b = container_of(e2, const struct oidmap_entry, internal_entry); + + if (keydata) + return !oideq(&a->oid, (const struct object_id *) keydata); + return !oideq(&a->oid, &b->oid); +} + +void oidmap_init(struct oidmap *map, size_t initial_size) +{ + hashmap_init(&map->map, oidmap_neq, NULL, initial_size); +} + +void oidmap_free(struct oidmap *map, int free_entries) +{ + if (!map) + return; + + /* TODO: make oidmap itself not depend on struct layouts */ + hashmap_clear_(&map->map, free_entries ? 0 : -1); +} + +void *oidmap_get(const struct oidmap *map, const struct object_id *key) +{ + if (!map->map.cmpfn) + return NULL; + + return hashmap_get_from_hash(&map->map, oidhash(key), key); +} + +void *oidmap_remove(struct oidmap *map, const struct object_id *key) +{ + struct hashmap_entry entry; + + if (!map->map.cmpfn) + oidmap_init(map, 0); + + hashmap_entry_init(&entry, oidhash(key)); + return hashmap_remove(&map->map, &entry, key); +} + +void *oidmap_put(struct oidmap *map, void *entry) +{ + struct oidmap_entry *to_put = entry; + + if (!map->map.cmpfn) + oidmap_init(map, 0); + + hashmap_entry_init(&to_put->internal_entry, oidhash(&to_put->oid)); + return hashmap_put(&map->map, &to_put->internal_entry); +} |