return (int) n;
}
-char* strv_join_full(char * const *l, const char *separator, const char *prefix, bool unescape_separators) {
+char* strv_join_full(char * const *l, const char *separator, const char *prefix, bool escape_separator) {
char *r, *e;
size_t n, k, m;
k = strlen(separator);
m = strlen_ptr(prefix);
- if (unescape_separators) /* If there separator is multi-char, we won't know how to escape it. */
+ if (escape_separator) /* If the separator was multi-char, we wouldn't know how to escape it. */
assert(k == 1);
n = 0;
if (s != l)
n += k;
- bool needs_escaping = unescape_separators && strchr(*s, separator[0]);
+ bool needs_escaping = escape_separator && strchr(*s, *separator);
n += m + strlen(*s) * (1 + needs_escaping);
}
if (prefix)
e = stpcpy(e, prefix);
- bool needs_escaping = unescape_separators && strchr(*s, separator[0]);
+ bool needs_escaping = escape_separator && strchr(*s, *separator);
if (needs_escaping)
for (size_t i = 0; (*s)[i]; i++) {
- if ((*s)[i] == separator[0])
+ if ((*s)[i] == *separator)
*(e++) = '\\';
*(e++) = (*s)[i];
}
* string in the vector is an empty string. */
int strv_split_colon_pairs(char ***t, const char *s);
-char* strv_join_full(char * const *l, const char *separator, const char *prefix, bool escape_separtor);
+char* strv_join_full(char * const *l, const char *separator, const char *prefix, bool escape_separator);
static inline char *strv_join(char * const *l, const char *separator) {
return strv_join_full(l, separator, NULL, false);
}