return *x;
}
+char* strextendn(char **x, const char *s, size_t l) {
+ assert(x);
+ assert(s || l == 0);
+
+ if (l > 0)
+ l = strnlen(s, l); /* ignore trailing noise */
+
+ if (l > 0 || !*x) {
+ size_t q;
+ char *m;
+
+ q = strlen_ptr(*x);
+ m = realloc(*x, q + l + 1);
+ if (!m)
+ return NULL;
+
+ *mempcpy_typesafe(m + q, s, l) = 0;
+
+ *x = m;
+ }
+
+ return *x;
+}
+
char* strstrip(char *s) {
if (!s)
return NULL;
return -ENOMEM;
}
-char* strextendn(char **x, const char *s, size_t l) {
- assert(x);
- assert(s || l == 0);
-
- if (l == SIZE_MAX)
- l = strlen_ptr(s);
- else if (l > 0)
- l = strnlen(s, l); /* ignore trailing noise */
-
- if (l > 0 || !*x) {
- size_t q;
- char *m;
-
- q = strlen_ptr(*x);
- m = realloc(*x, q + l + 1);
- if (!m)
- return NULL;
-
- memcpy_safe(m + q, s, l);
- m[q + l] = 0;
-
- *x = m;
- }
-
- return *x;
-}
-
char* strrep(const char *s, unsigned n) {
char *r, *p;
size_t l;
char* first_word(const char *s, const char *word) _pure_;
char* strprepend(char **x, const char *s);
+char* strextendn(char **x, const char *s, size_t l);
#define strjoin(a, ...) strextend_with_separator_internal(NULL, NULL, a, __VA_ARGS__, NULL)
#define strextend_with_separator(x, separator, ...) strextend_with_separator_internal(x, separator, __VA_ARGS__, NULL)
#define strextend(x, ...) strextend_with_separator_internal(x, NULL, __VA_ARGS__, NULL)
-char* strextendn(char **x, const char *s, size_t l);
-
int strextendf_with_separator(char **x, const char *separator, const char *format, ...) _printf_(3,4);
#define strextendf(x, ...) strextendf_with_separator(x, NULL, __VA_ARGS__)