From: Ivan Kruglov Date: Mon, 7 Jul 2025 15:06:58 +0000 (-0700) Subject: nsflags: namespace_flags_to_strv() X-Git-Tag: v259-rc1~306^2~5 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=115083886afeb1fb2c140ef961740bc67d42676a;p=thirdparty%2Fsystemd.git nsflags: namespace_flags_to_strv() --- diff --git a/src/shared/nsflags.c b/src/shared/nsflags.c index e14aa098102..b852221c675 100644 --- a/src/shared/nsflags.c +++ b/src/shared/nsflags.c @@ -5,6 +5,7 @@ #include "namespace-util.h" #include "nsflags.h" #include "string-util.h" +#include "strv.h" int namespace_flags_from_string(const char *name, unsigned long *ret) { unsigned long flags = 0; @@ -40,19 +41,41 @@ int namespace_flags_from_string(const char *name, unsigned long *ret) { } int namespace_flags_to_string(unsigned long flags, char **ret) { + _cleanup_strv_free_ char **l = NULL; _cleanup_free_ char *s = NULL; + int r; + + assert(ret); + + r = namespace_flags_to_strv(flags, &l); + if (r < 0) + return r; + + s = strv_join(l, NULL); + if (!s) + return -ENOMEM; + + *ret = TAKE_PTR(s); + return 0; +} + +int namespace_flags_to_strv(unsigned long flags, char ***ret) { + _cleanup_strv_free_ char **s = NULL; unsigned i; + int r; + + assert(ret); for (i = 0; namespace_info[i].proc_name; i++) { if ((flags & namespace_info[i].clone_flag) != namespace_info[i].clone_flag) continue; - if (!strextend_with_separator(&s, " ", namespace_info[i].proc_name)) - return -ENOMEM; + r = strv_extend(&s, namespace_info[i].proc_name); + if (r < 0) + return r; } *ret = TAKE_PTR(s); - return 0; } diff --git a/src/shared/nsflags.h b/src/shared/nsflags.h index 35bcb6a8c99..eae199d73fa 100644 --- a/src/shared/nsflags.h +++ b/src/shared/nsflags.h @@ -23,4 +23,5 @@ int namespace_flags_from_string(const char *name, unsigned long *ret); int namespace_flags_to_string(unsigned long flags, char **ret); +int namespace_flags_to_strv(unsigned long flags, char ***ret); const char* namespace_single_flag_to_string(unsigned long flag) _const_;