chiark
/
gitweb
/
~ianmdlvl
/
elogind.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
basic: include only what we use
[elogind.git]
/
src
/
basic
/
strv.c
diff --git
a/src/basic/strv.c
b/src/basic/strv.c
index d4a1b80d073c4a3fac5e8c83359ee9a7dbe171b6..966cab75d5e79085d260af69ea66aedc0254add9 100644
(file)
--- a/
src/basic/strv.c
+++ b/
src/basic/strv.c
@@
-19,13
+19,19
@@
along with systemd; If not, see <http://www.gnu.org/licenses/>.
***/
along with systemd; If not, see <http://www.gnu.org/licenses/>.
***/
-#include <stdlib.h>
+#include <errno.h>
+#include <fnmatch.h>
#include <stdarg.h>
#include <stdarg.h>
+#include <stdio.h>
+#include <stdlib.h>
#include <string.h>
#include <string.h>
-#include <errno.h>
-#include "util.h"
+#include "alloc-util.h"
+#include "escape.h"
+#include "extract-word.h"
+#include "string-util.h"
#include "strv.h"
#include "strv.h"
+#include "util.h"
char *strv_find(char **l, const char *name) {
char **i;
char *strv_find(char **l, const char *name) {
char **i;
@@
-86,6
+92,15
@@
char **strv_free(char **l) {
return NULL;
}
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;
char **strv_copy(char * const *l) {
char **r, **k;
@@
-188,6
+203,7
@@
char **strv_new(const char *x, ...) {
return r;
}
return r;
}
+#if 0 /// UNNEEDED by elogind
int strv_extend_strv(char ***a, char **b, bool filter_duplicates) {
char **s, **t;
size_t p, q, i = 0, j;
int strv_extend_strv(char ***a, char **b, bool filter_duplicates) {
char **s, **t;
size_t p, q, i = 0, j;
@@
-232,8
+248,6
@@
rollback:
return -ENOMEM;
}
return -ENOMEM;
}
-/// UNNEEDED by elogind
-#if 0
int strv_extend_strv_concat(char ***a, char **b, const char *suffix) {
int r;
char **s;
int strv_extend_strv_concat(char ***a, char **b, const char *suffix) {
int r;
char **s;
@@
-287,8
+301,7
@@
char **strv_split(const char *s, const char *separator) {
return r;
}
return r;
}
-/// UNNEEDED by elogind
-#if 0
+#if 0 /// UNNEEDED by elogind
char **strv_split_newlines(const char *s) {
char **l;
unsigned n;
char **strv_split_newlines(const char *s) {
char **l;
unsigned n;
@@
-385,8
+398,7
@@
char *strv_join(char **l, const char *separator) {
return r;
}
return r;
}
-/// UNNEEDED by elogind
-#if 0
+#if 0 /// UNNEEDED by elogind
char *strv_join_quoted(char **l) {
char *buf = NULL;
char **s;
char *strv_join_quoted(char **l) {
char *buf = NULL;
char **s;
@@
-518,8
+530,7
@@
int strv_consume(char ***l, char *value) {
return r;
}
return r;
}
-/// UNNEEDED by elogind
-#if 0
+#if 0 /// UNNEEDED by elogind
int strv_consume_pair(char ***l, char *a, char *b) {
int r;
int strv_consume_pair(char ***l, char *a, char *b) {
int r;
@@
-568,8
+579,7
@@
char **strv_uniq(char **l) {
return l;
}
return l;
}
-/// UNNEEDED by elogind
-#if 0
+#if 0 /// UNNEEDED by elogind
bool strv_is_uniq(char **l) {
char **i;
bool strv_is_uniq(char **l) {
char **i;
@@
-664,6
+674,7
@@
char **strv_split_nulstr(const char *s) {
return r;
}
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;
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
+710,6
@@
int strv_make_nulstr(char **l, char **p, size_t *q) {
return 0;
}
return 0;
}
-/// UNNEEDED by elogind
-#if 0
bool strv_overlap(char **a, char **b) {
char **i;
bool strv_overlap(char **a, char **b) {
char **i;
@@
-710,6
+719,7
@@
bool strv_overlap(char **a, char **b) {
return false;
}
return false;
}
+#endif // 0
static int str_compare(const void *_a, const void *_b) {
const char **a = (const char**) _a, **b = (const char**) _b;
static int str_compare(const void *_a, const void *_b) {
const char **a = (const char**) _a, **b = (const char**) _b;
@@
-726,6
+736,7
@@
char **strv_sort(char **l) {
return l;
}
return l;
}
+#if 0 /// UNNEEDED by elogind
bool strv_equal(char **a, char **b) {
if (strv_isempty(a))
bool strv_equal(char **a, char **b) {
if (strv_isempty(a))
@@
-800,7
+811,6
@@
char **strv_shell_escape(char **l, const char *bad) {
return l;
}
return l;
}
-#endif // 0
bool strv_fnmatch(char* const* patterns, const char *s, int flags) {
char* const* p;
bool strv_fnmatch(char* const* patterns, const char *s, int flags) {
char* const* p;
@@
-874,3
+884,4
@@
rollback:
nl[k] = NULL;
return -ENOMEM;
}
nl[k] = NULL;
return -ENOMEM;
}
+#endif // 0