зеркало из https://github.com/microsoft/git.git
string-list: spell all values out that are given to a string_list initializer
STRING_LIST_INIT_{NODUP,DUP} initializers list values only for earlier structure members, relying on the usual convention in C that the omitted members are initailized to 0, i.e. the former is expanded to the latter: struct string_list l = STRING_LIST_INIT_DUP; struct string_list l = { NULL, 0, 0, 1 }; and the last member that is not mentioned (i.e. 'cmp') is initialized to NULL. While there is nothing wrong in this construct, spelling out all the values where the macros are defined will serve also as a documentation, so let's do so. Signed-off-by: Tanay Abhra <tanayabh@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Родитель
e156455ea4
Коммит
acb3d22264
|
@ -200,3 +200,5 @@ Represents the list itself.
|
|||
You should not tamper with it.
|
||||
. Setting the `strdup_strings` member to 1 will strdup() the strings
|
||||
before adding them, see above.
|
||||
. The `compare_strings_fn` member is used to specify a custom compare
|
||||
function, otherwise `strcmp()` is used as the default function.
|
||||
|
|
|
@ -15,8 +15,8 @@ struct string_list {
|
|||
compare_strings_fn cmp; /* NULL uses strcmp() */
|
||||
};
|
||||
|
||||
#define STRING_LIST_INIT_NODUP { NULL, 0, 0, 0 }
|
||||
#define STRING_LIST_INIT_DUP { NULL, 0, 0, 1 }
|
||||
#define STRING_LIST_INIT_NODUP { NULL, 0, 0, 0, NULL }
|
||||
#define STRING_LIST_INIT_DUP { NULL, 0, 0, 1, NULL }
|
||||
|
||||
void print_string_list(const struct string_list *p, const char *text);
|
||||
void string_list_clear(struct string_list *list, int free_util);
|
||||
|
|
Загрузка…
Ссылка в новой задаче