oidmap: add size function

Callers which want to know how many items are in an oidmap have to look
at the underlying hashmap struct, leaking an implementation detail.
Let's provide a type-appropriate wrapper and use it.

Note in the call from lookup_replace_object(), the caller was actually
looking at the hashmap's tablesize parameter (the allocated size of the
table) rather than hashmap_get_size(), the number of items in the table.
This probably should have been checking the number of items all along,
but the two are functionally equivalent here since we only add to the
map and never remove anything. Thus if there was any allocation, it was
because there is at least one item.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Jeff King 2025-05-12 14:51:30 -04:00 committed by Junio C Hamano
parent 2744646834
commit 596184786c
3 changed files with 6 additions and 2 deletions

View File

@ -222,7 +222,7 @@ static int commit_graph_compatible(struct repository *r)

if (replace_refs_enabled(r)) {
prepare_replace_object(r);
if (hashmap_get_size(&r->objects->replace_map->map))
if (oidmap_get_size(r->objects->replace_map))
return 0;
}


View File

@ -67,6 +67,10 @@ void *oidmap_put(struct oidmap *map, void *entry);
*/
void *oidmap_remove(struct oidmap *map, const struct object_id *key);

static inline unsigned int oidmap_get_size(struct oidmap *map)
{
return hashmap_get_size(&map->map);
}

struct oidmap_iter {
struct hashmap_iter h_iter;

View File

@ -47,7 +47,7 @@ static inline const struct object_id *lookup_replace_object(struct repository *r
{
if (!replace_refs_enabled(r) ||
(r->objects->replace_map_initialized &&
r->objects->replace_map->map.tablesize == 0))
oidmap_get_size(r->objects->replace_map) == 0))
return oid;
return do_lookup_replace_object(r, oid);
}