Signed-off-by: Milan Broz <mbroz@xxxxxxxxxx> --- include/strutils.h | 4 ++++ lib/strutils.c | 26 ++++++++++++++++++++++++++ 2 files changed, 30 insertions(+) diff --git a/include/strutils.h b/include/strutils.h index 57b13fd..123907f 100644 --- a/include/strutils.h +++ b/include/strutils.h @@ -59,6 +59,10 @@ extern char *size_to_human_string(int options, uint64_t bytes); extern int string_to_idarray(const char *list, int ary[], size_t arysz, int (name2id)(const char *, size_t)); +extern int string_add_to_idarray(const char *list, int ary[], + size_t arysz, int *ary_pos, + int (name2id)(const char *, size_t)); + extern int string_to_bitarray(const char *list, char *ary, int (*name2bit)(const char *, size_t)); diff --git a/lib/strutils.c b/lib/strutils.c index 036ae06..df31682 100644 --- a/lib/strutils.c +++ b/lib/strutils.c @@ -479,6 +479,32 @@ int string_to_idarray(const char *list, int ary[], size_t arysz, } /* + * Parses the array like string_to_idarray but if format is "+aaa,bbb" + * it adds fields to array instead of replacing them. + */ +int string_add_to_idarray(const char *list, int ary[], size_t arysz, + int *ary_pos, int (name2id)(const char *, size_t)) +{ + const char *list_add; + int r; + + if (!list || !*list || !ary_pos || *ary_pos < 0 | *ary_pos > (int)arysz) + return -1; + + if (list[0] == '+') + list_add = &list[1]; + else { + list_add = list; + *ary_pos = 0; + } + + r = string_to_idarray(list_add, &ary[*ary_pos], arysz - *ary_pos, name2id); + if (r > 0) + *ary_pos += r; + return r; +} + +/* * LIST ::= <item> [, <item>] * * The <item> is translated to 'id' by name2id() function and the 'id' is used -- 1.7.10.4 -- To unsubscribe from this list: send the line "unsubscribe util-linux" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html