]> git.ipfire.org Git - thirdparty/dracut.git/blame - install/strv.h
resume/module-setup.sh: filter out empty resume= options in cmdline()
[thirdparty/dracut.git] / install / strv.h
CommitLineData
2f461da2
HH
1/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2
3#pragma once
4
5/***
6 This file is part of systemd.
7
8 Copyright 2010 Lennart Poettering
9
10 systemd is free software; you can redistribute it and/or modify it
11 under the terms of the GNU Lesser General Public License as published by
12 the Free Software Foundation; either version 2.1 of the License, or
13 (at your option) any later version.
14
15 systemd is distributed in the hope that it will be useful, but
16 WITHOUT ANY WARRANTY; without even the implied warranty of
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 Lesser General Public License for more details.
19
20 You should have received a copy of the GNU Lesser General Public License
21 along with systemd; If not, see <http://www.gnu.org/licenses/>.
22***/
23
24#include <stdarg.h>
25#include <stdbool.h>
26
27#include "util.h"
28
29char *strv_find(char **l, const char *name) _pure_;
30char *strv_find_prefix(char **l, const char *name) _pure_;
31
32void strv_free(char **l);
33DEFINE_TRIVIAL_CLEANUP_FUNC(char**, strv_free);
34#define _cleanup_strv_free_ _cleanup_(strv_freep)
35
36char **strv_copy(char * const *l);
37unsigned strv_length(char * const *l) _pure_;
38
39char **strv_merge(char **a, char **b);
40char **strv_merge_concat(char **a, char **b, const char *suffix);
41char **strv_append(char **l, const char *s);
42int strv_extend(char ***l, const char *value);
43int strv_push(char ***l, char *value);
44
45char **strv_remove(char **l, const char *s);
46char **strv_remove_prefix(char **l, const char *s);
47char **strv_uniq(char **l);
48
49#define strv_contains(l, s) (!!strv_find((l), (s)))
50
51char **strv_new(const char *x, ...) _sentinel_;
52char **strv_new_ap(const char *x, va_list ap);
53
54static inline const char* STRV_IFNOTNULL(const char *x) {
55 return x ? x : (const char *) -1;
56}
57
58static inline bool strv_isempty(char * const *l) {
59 return !l || !*l;
60}
61
62char **strv_split(const char *s, const char *separator);
63char **strv_split_quoted(const char *s);
64char **strv_split_newlines(const char *s);
65
66char *strv_join(char **l, const char *separator);
67
68char **strv_parse_nulstr(const char *s, size_t l);
69char **strv_split_nulstr(const char *s);
70
71bool strv_overlap(char **a, char **b) _pure_;
72
73#define STRV_FOREACH(s, l) \
74 for ((s) = (l); (s) && *(s); (s)++)
75
76#define STRV_FOREACH_BACKWARDS(s, l) \
77 STRV_FOREACH(s, l) \
78 ; \
79 for ((s)--; (l) && ((s) >= (l)); (s)--)
80
81#define STRV_FOREACH_PAIR(x, y, l) \
82 for ((x) = (l), (y) = (x+1); (x) && *(x) && *(y); (x) += 2, (y) = (x + 1))
83
84char **strv_sort(char **l);
85void strv_print(char **l);
86
87#define STRV_MAKE(...) ((char**) ((const char*[]) { __VA_ARGS__, NULL }))
88
89#define STRV_MAKE_EMPTY ((char*[1]) { NULL })
90
91#define strv_from_stdarg_alloca(first) \
92 ({ \
93 char **_l; \
94 \
95 if (!first) \
96 _l = (char**) &first; \
97 else { \
98 unsigned _n; \
99 va_list _ap; \
100 \
101 _n = 1; \
102 va_start(_ap, first); \
103 while (va_arg(_ap, char*)) \
104 _n++; \
105 va_end(_ap); \
106 \
107 _l = newa(char*, _n+1); \
108 _l[_n = 0] = (char*) first; \
109 va_start(_ap, first); \
110 for (;;) { \
111 _l[++_n] = va_arg(_ap, char*); \
112 if (!_l[_n]) \
113 break; \
114 } \
115 va_end(_ap); \
116 } \
117 _l; \
118 })