mirror of
https://github.com/git/git.git
synced 2024-11-23 09:56:28 +08:00
strmap: split create_entry() out of strmap_put()
This will facilitate adding entries to a strmap subtype in ways that differ slightly from that of strmap_put(). Signed-off-by: Elijah Newren <newren@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
4fa1d501f7
commit
6abd22065c
37
strmap.c
37
strmap.c
@ -70,27 +70,36 @@ void strmap_partial_clear(struct strmap *map, int free_values)
|
||||
hashmap_partial_clear(&map->map);
|
||||
}
|
||||
|
||||
static struct strmap_entry *create_entry(struct strmap *map,
|
||||
const char *str,
|
||||
void *data)
|
||||
{
|
||||
struct strmap_entry *entry;
|
||||
const char *key = str;
|
||||
|
||||
entry = xmalloc(sizeof(*entry));
|
||||
hashmap_entry_init(&entry->ent, strhash(str));
|
||||
|
||||
if (map->strdup_strings)
|
||||
key = xstrdup(str);
|
||||
entry->key = key;
|
||||
entry->value = data;
|
||||
return entry;
|
||||
}
|
||||
|
||||
void *strmap_put(struct strmap *map, const char *str, void *data)
|
||||
{
|
||||
struct strmap_entry *entry = find_strmap_entry(map, str);
|
||||
void *old = NULL;
|
||||
|
||||
if (entry) {
|
||||
old = entry->value;
|
||||
void *old = entry->value;
|
||||
entry->value = data;
|
||||
} else {
|
||||
const char *key = str;
|
||||
|
||||
entry = xmalloc(sizeof(*entry));
|
||||
hashmap_entry_init(&entry->ent, strhash(str));
|
||||
|
||||
if (map->strdup_strings)
|
||||
key = xstrdup(str);
|
||||
entry->key = key;
|
||||
entry->value = data;
|
||||
hashmap_add(&map->map, &entry->ent);
|
||||
return old;
|
||||
}
|
||||
return old;
|
||||
|
||||
entry = create_entry(map, str, data);
|
||||
hashmap_add(&map->map, &entry->ent);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
struct strmap_entry *strmap_get_entry(struct strmap *map, const char *str)
|
||||
|
Loading…
Reference in New Issue
Block a user