X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;ds=sidebyside;f=src%2Fbasic%2Fstrv.c;h=825fdcbdfe10474c9f2036c88b3da8ec6e7fdb72;hb=166f4e4fb53a82900ff9ae080e0ff37d35d4dacd;hp=d4a1b80d073c4a3fac5e8c83359ee9a7dbe171b6;hpb=d2338db3145922b1dfcb3b458e5bce2568a9347a;p=elogind.git
diff --git a/src/basic/strv.c b/src/basic/strv.c
index d4a1b80d0..825fdcbdf 100644
--- a/src/basic/strv.c
+++ b/src/basic/strv.c
@@ -19,13 +19,16 @@
along with systemd; If not, see .
***/
-#include
+#include
#include
+#include
#include
-#include
-#include "util.h"
+#include "alloc-util.h"
+#include "escape.h"
+#include "string-util.h"
#include "strv.h"
+#include "util.h"
char *strv_find(char **l, const char *name) {
char **i;
@@ -86,6 +89,15 @@ char **strv_free(char **l) {
return NULL;
}
+char **strv_free_erase(char **l) {
+ char **i;
+
+ STRV_FOREACH(i, l)
+ string_erase(*i);
+
+ return strv_free(l);
+}
+
char **strv_copy(char * const *l) {
char **r, **k;
@@ -232,8 +244,7 @@ rollback:
return -ENOMEM;
}
-/// UNNEEDED by elogind
-#if 0
+#if 0 /// UNNEEDED by elogind
int strv_extend_strv_concat(char ***a, char **b, const char *suffix) {
int r;
char **s;
@@ -287,8 +298,7 @@ char **strv_split(const char *s, const char *separator) {
return r;
}
-/// UNNEEDED by elogind
-#if 0
+#if 0 /// UNNEEDED by elogind
char **strv_split_newlines(const char *s) {
char **l;
unsigned n;
@@ -385,8 +395,7 @@ char *strv_join(char **l, const char *separator) {
return r;
}
-/// UNNEEDED by elogind
-#if 0
+#if 0 /// UNNEEDED by elogind
char *strv_join_quoted(char **l) {
char *buf = NULL;
char **s;
@@ -518,8 +527,7 @@ int strv_consume(char ***l, char *value) {
return r;
}
-/// UNNEEDED by elogind
-#if 0
+#if 0 /// UNNEEDED by elogind
int strv_consume_pair(char ***l, char *a, char *b) {
int r;
@@ -568,8 +576,7 @@ char **strv_uniq(char **l) {
return l;
}
-/// UNNEEDED by elogind
-#if 0
+#if 0 /// UNNEEDED by elogind
bool strv_is_uniq(char **l) {
char **i;
@@ -664,6 +671,7 @@ char **strv_split_nulstr(const char *s) {
return r;
}
+#if 0 /// UNNEEDED by elogind
int strv_make_nulstr(char **l, char **p, size_t *q) {
size_t n_allocated = 0, n = 0;
_cleanup_free_ char *m = NULL;
@@ -699,8 +707,6 @@ int strv_make_nulstr(char **l, char **p, size_t *q) {
return 0;
}
-/// UNNEEDED by elogind
-#if 0
bool strv_overlap(char **a, char **b) {
char **i;
@@ -710,6 +716,7 @@ bool strv_overlap(char **a, char **b) {
return false;
}
+#endif // 0
static int str_compare(const void *_a, const void *_b) {
const char **a = (const char**) _a, **b = (const char**) _b;
@@ -726,6 +733,7 @@ char **strv_sort(char **l) {
return l;
}
+#if 0 /// UNNEEDED by elogind
bool strv_equal(char **a, char **b) {
if (strv_isempty(a))
@@ -800,7 +808,6 @@ char **strv_shell_escape(char **l, const char *bad) {
return l;
}
-#endif // 0
bool strv_fnmatch(char* const* patterns, const char *s, int flags) {
char* const* p;
@@ -874,3 +881,4 @@ rollback:
nl[k] = NULL;
return -ENOMEM;
}
+#endif // 0