diff options
author | Vincent Ambo <Vincent Ambo> | 2020-01-11T23·36+0000 |
---|---|---|
committer | Vincent Ambo <Vincent Ambo> | 2020-01-11T23·40+0000 |
commit | 7ef0d62730840ded097b524104cc0a0904591a63 (patch) | |
tree | a670f96103667aeca4789a95d94ca0dff550c4ce /third_party/git/oidmap.c | |
parent | 6a2a3007077818e24a3d56fc492ada9206a10cf0 (diff) | |
parent | 1b593e1ea4d2af0f6444d9a7788d5d99abd6fde5 (diff) |
merge(third_party/git): Merge squashed git subtree at v2.23.0 r/373
Merge commit '1b593e1ea4d2af0f6444d9a7788d5d99abd6fde5' as 'third_party/git'
Diffstat (limited to 'third_party/git/oidmap.c')
-rw-r--r-- | third_party/git/oidmap.c | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/third_party/git/oidmap.c b/third_party/git/oidmap.c new file mode 100644 index 000000000000..6d6e840d0376 --- /dev/null +++ b/third_party/git/oidmap.c @@ -0,0 +1,55 @@ +#include "cache.h" +#include "oidmap.h" + +static int oidmap_neq(const void *hashmap_cmp_fn_data, + const void *entry, const void *entry_or_key, + const void *keydata) +{ + const struct oidmap_entry *entry_ = entry; + if (keydata) + return !oideq(&entry_->oid, (const struct object_id *) keydata); + return !oideq(&entry_->oid, + &((const struct oidmap_entry *) entry_or_key)->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; + hashmap_free(&map->map, free_entries); +} + +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); +} |