diff options
author | Ævar Arnfjörð Bjarmason <avarab@gmail.com> | 2021-07-01 12:51:28 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2021-07-01 21:32:22 +0200 |
commit | 770fedaf9fb156bd8c18da41770eac0cb63fba63 (patch) | |
tree | 7187ab68ef185ddc2f5351764e9dafa4ee6e2f2e /string-list.h | |
parent | dir.[ch]: replace dir_init() with DIR_INIT (diff) | |
download | git-770fedaf9fb156bd8c18da41770eac0cb63fba63.tar.xz git-770fedaf9fb156bd8c18da41770eac0cb63fba63.zip |
string-list.[ch]: add a string_list_init_{nodup,dup}()
In order to use the new "memcpy() a 'blank' struct on the stack"
pattern for string_list_init(), and to make the macro initialization
consistent with the function initialization introduce two new
string_list_init_{nodup,dup}() functions. These are like the old
string_list_init() when called with a false and true second argument,
respectively.
I think this not only makes things more consistent, but also easier to
read. I often had to lookup what the ", 0)" or ", 1)" in these
invocations meant, now it's right there in the function name, and
corresponds to the macros.
A subsequent commit will convert existing API users to this pattern,
but as this is a very common API let's leave a compatibility function
in place for later removal. This intermediate state also proves that
the compatibility function works.
Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to '')
-rw-r--r-- | string-list.h | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/string-list.h b/string-list.h index 521b9c0748..0d6b469239 100644 --- a/string-list.h +++ b/string-list.h @@ -97,8 +97,15 @@ struct string_list { /* General functions which work with both sorted and unsorted lists. */ /** - * Initialize the members of the string_list, set `strdup_strings` - * member according to the value of the second parameter. + * Initialize the members of a string_list pointer in the same way as + * the corresponding `STRING_LIST_INIT_NODUP` and + * `STRING_LIST_INIT_DUP` macros. + */ +void string_list_init_nodup(struct string_list *list); +void string_list_init_dup(struct string_list *list); + +/** + * TODO remove: For compatibility with any in-flight older API users */ void string_list_init(struct string_list *list, int strdup_strings); |