hashmap_remove takes "const struct hashmap_entry *"
This is less error-prone than "const void *" as the compiler now detects invalid types being passed. Signed-off-by: Eric Wong <e@80x24.org> Reviewed-by: Derrick Stolee <stolee@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
b6c5241606
commit
28ee794128
2
blame.c
2
blame.c
@ -473,7 +473,7 @@ static void fingerprint_subtract(struct fingerprint *a, struct fingerprint *b)
|
||||
while ((entry_b = hashmap_iter_next(&iter))) {
|
||||
if ((entry_a = hashmap_get(&a->map, &entry_b->entry, NULL))) {
|
||||
if (entry_a->count <= entry_b->count)
|
||||
hashmap_remove(&a->map, entry_b, NULL);
|
||||
hashmap_remove(&a->map, &entry_b->entry, NULL);
|
||||
else
|
||||
entry_a->count -= entry_b->count;
|
||||
}
|
||||
|
@ -218,7 +218,8 @@ void hashmap_add(struct hashmap *map, struct hashmap_entry *entry)
|
||||
}
|
||||
}
|
||||
|
||||
void *hashmap_remove(struct hashmap *map, const void *key, const void *keydata)
|
||||
void *hashmap_remove(struct hashmap *map, const struct hashmap_entry *key,
|
||||
const void *keydata)
|
||||
{
|
||||
struct hashmap_entry *old;
|
||||
struct hashmap_entry **e = find_entry_ptr(map, key, keydata);
|
||||
|
@ -349,7 +349,7 @@ void *hashmap_put(struct hashmap *map, void *entry);
|
||||
*
|
||||
* Argument explanation is the same as in `hashmap_get`.
|
||||
*/
|
||||
void *hashmap_remove(struct hashmap *map, const void *key,
|
||||
void *hashmap_remove(struct hashmap *map, const struct hashmap_entry *key,
|
||||
const void *keydata);
|
||||
|
||||
/*
|
||||
|
@ -2001,7 +2001,7 @@ static void remove_hashmap_entries(struct hashmap *dir_renames,
|
||||
|
||||
for (i = 0; i < items_to_remove->nr; i++) {
|
||||
entry = items_to_remove->items[i].util;
|
||||
hashmap_remove(dir_renames, entry, NULL);
|
||||
hashmap_remove(dir_renames, &entry->ent, NULL);
|
||||
}
|
||||
string_list_clear(items_to_remove, 0);
|
||||
}
|
||||
|
@ -95,7 +95,7 @@ static void remove_dir_entry(struct index_state *istate, struct cache_entry *ce)
|
||||
struct dir_entry *dir = hash_dir_entry(istate, ce, ce_namelen(ce));
|
||||
while (dir && !(--dir->nr)) {
|
||||
struct dir_entry *parent = dir->parent;
|
||||
hashmap_remove(&istate->dir_hash, dir, NULL);
|
||||
hashmap_remove(&istate->dir_hash, &dir->ent, NULL);
|
||||
free(dir);
|
||||
dir = parent;
|
||||
}
|
||||
@ -625,7 +625,7 @@ void remove_name_hash(struct index_state *istate, struct cache_entry *ce)
|
||||
if (!istate->name_hash_initialized || !(ce->ce_flags & CE_HASHED))
|
||||
return;
|
||||
ce->ce_flags &= ~CE_HASHED;
|
||||
hashmap_remove(&istate->name_hash, ce, ce);
|
||||
hashmap_remove(&istate->name_hash, &ce->ent, ce);
|
||||
|
||||
if (ignore_case)
|
||||
remove_dir_entry(istate, ce);
|
||||
|
@ -1423,7 +1423,7 @@ static int in_delta_base_cache(struct packed_git *p, off_t base_offset)
|
||||
*/
|
||||
static void detach_delta_base_cache_entry(struct delta_base_cache_entry *ent)
|
||||
{
|
||||
hashmap_remove(&delta_base_cache, ent, &ent->key);
|
||||
hashmap_remove(&delta_base_cache, &ent->ent, &ent->key);
|
||||
list_del(&ent->lru);
|
||||
delta_base_cached -= ent->size;
|
||||
free(ent);
|
||||
|
@ -229,7 +229,7 @@ static void find_exact_matches(struct string_list *a, struct string_list *b)
|
||||
util->patch = b->items[i].string;
|
||||
util->diff = util->patch + util->diff_offset;
|
||||
hashmap_entry_init(&util->e, strhash(util->diff));
|
||||
other = hashmap_remove(&map, util, NULL);
|
||||
other = hashmap_remove(&map, &util->e, NULL);
|
||||
if (other) {
|
||||
if (other->matching >= 0)
|
||||
BUG("already assigned!");
|
||||
|
@ -58,7 +58,7 @@ void subprocess_stop(struct hashmap *hashmap, struct subprocess_entry *entry)
|
||||
kill(entry->process.pid, SIGTERM);
|
||||
finish_command(&entry->process);
|
||||
|
||||
hashmap_remove(hashmap, entry, NULL);
|
||||
hashmap_remove(hashmap, &entry->ent, NULL);
|
||||
}
|
||||
|
||||
static void subprocess_exit_handler(struct child_process *process)
|
||||
|
@ -137,7 +137,7 @@ static void cache_remove_path(struct submodule_cache *cache,
|
||||
struct submodule_entry *removed;
|
||||
hashmap_entry_init(&e.ent, hash);
|
||||
e.config = submodule;
|
||||
removed = hashmap_remove(&cache->for_path, &e, NULL);
|
||||
removed = hashmap_remove(&cache->for_path, &e.ent, NULL);
|
||||
free(removed);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user