diff options
author | Junio C Hamano <gitster@pobox.com> | 2018-03-22 14:24:12 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2018-03-22 14:24:12 -0700 |
commit | 6ef449ea77e1ed83056d62dd5cd8b43caff25cb2 (patch) | |
tree | 502d582899f3da7b358469bf99f591c7d7f68e4e | |
parent | Merge branch 'sg/test-i18ngrep' into maint (diff) | |
parent | oidmap: ensure map is initialized (diff) | |
download | tgif-6ef449ea77e1ed83056d62dd5cd8b43caff25cb2.tar.xz |
Merge branch 'bw/oidmap-autoinit' into maint
Code clean-up.
* bw/oidmap-autoinit:
oidmap: ensure map is initialized
-rw-r--r-- | oidmap.c | 11 |
1 files changed, 11 insertions, 0 deletions
@@ -33,12 +33,19 @@ void oidmap_free(struct oidmap *map, int 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, hash(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, hash(key)); return hashmap_remove(&map->map, &entry, key); } @@ -46,6 +53,10 @@ void *oidmap_remove(struct oidmap *map, const struct object_id *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, hash(&to_put->oid)); return hashmap_put(&map->map, to_put); } |