diff options
author | Derrick Stolee <derrickstolee@github.com> | 2022-09-27 15:57:01 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2022-09-27 18:32:26 +0200 |
commit | d151f0cce7fca1fc156a9ea1dc98c59e1be512c9 (patch) | |
tree | 2c238bf0c5686833843318f3fcc781b264aaf066 /string-list.h | |
parent | gc: replace config subprocesses with API calls (diff) | |
download | git-d151f0cce7fca1fc156a9ea1dc98c59e1be512c9.tar.xz git-d151f0cce7fca1fc156a9ea1dc98c59e1be512c9.zip |
string-list: document iterator behavior on NULL input
The for_each_string_list_item() macro takes a string_list and
automatically constructs a for loop to iterate over its contents. This
macro will segfault if the list is non-NULL.
We cannot change the macro to be careful around NULL values because
there are many callers that use the address of a local variable, which
will never be NULL and will cause compile errors with -Werror=address.
For now, leave a documentation comment to try to avoid mistakes in the
future where a caller does not check for a NULL list.
Signed-off-by: Derrick Stolee <derrickstolee@github.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to '')
-rw-r--r-- | string-list.h | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/string-list.h b/string-list.h index d5a744e143..c7b0d5d000 100644 --- a/string-list.h +++ b/string-list.h @@ -141,7 +141,12 @@ void string_list_clear_func(struct string_list *list, string_list_clear_func_t c int for_each_string_list(struct string_list *list, string_list_each_func_t func, void *cb_data); -/** Iterate over each item, as a macro. */ +/** + * Iterate over each item, as a macro. + * + * Be sure that 'list' is non-NULL. The macro cannot perform NULL + * checks due to -Werror=address errors. + */ #define for_each_string_list_item(item,list) \ for (item = (list)->items; \ item && item < (list)->items + (list)->nr; \ |