1
1
mirror of https://github.com/systemd/systemd-stable.git synced 2025-01-11 05:17:44 +03:00

hashmap: always set key output argument of internal_hashmap_first_key_and_value()

internal_hashmap_first_key_and_value() returns the first value, or %NULL
if the hashmap is empty.

However, hashmaps may contain %NULL values. That means, a caller getting
%NULL doesn't know whether the hashmap is empty or whether the first
value is %NULL.

For example, a caller may be tempted to do something like:

    if ((val = hashmap_steal_first_key_and_value (h, (void **) key))) {
         // process first entry.
    }

But this is only correct if the caller made sure that the hash is either
not empty or contains no NULL values.

Anyway, since a %NULL return value can signal an empty hash or a %NULL
value, it seems error prone to leave the key output argument
uninitialized in situations that the caller cannot clearly distinguish
(without making additional assumptions).
This commit is contained in:
Thomas Haller 2019-02-04 09:36:17 +01:00
parent ca3237150e
commit 51c682df38

View File

@ -1516,8 +1516,11 @@ void *internal_hashmap_first_key_and_value(HashmapBase *h, bool remove, void **r
unsigned idx; unsigned idx;
idx = find_first_entry(h); idx = find_first_entry(h);
if (idx == IDX_NIL) if (idx == IDX_NIL) {
if (ret_key)
*ret_key = NULL;
return NULL; return NULL;
}
e = bucket_at(h, idx); e = bucket_at(h, idx);
key = (void*) e->key; key = (void*) e->key;