aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/extlib.h2
-rw-r--r--src/extstring.c17
2 files changed, 11 insertions, 8 deletions
diff --git a/src/extlib.h b/src/extlib.h
index c36b919..03bb53b 100644
--- a/src/extlib.h
+++ b/src/extlib.h
@@ -66,7 +66,7 @@ char *trim (char *s, int *rem_front, int *rem_back);
char *replace_str (char *s, char *old, char *replace);
/// Join an array of strings into one string
-char *join_str (char **s, size_t len, char delim);
+char *join_str (char **s, size_t len, char *delim);
/// Limit a value to a maximum
float max (float v, float max_v);
diff --git a/src/extstring.c b/src/extstring.c
index 2fea204..b69b1f7 100644
--- a/src/extstring.c
+++ b/src/extstring.c
@@ -103,18 +103,21 @@ replace_str (char *s, char *old, char *replace)
};
char *
-join_str (char **s, size_t len, char delim)
+join_str (char **s, size_t len, char *delim)
{
char *ret = strdup (s[0]);
- size_t ret_len = sizeof (char) * len + strlen (ret);
+ size_t ret_len = strlen (delim) * len + strlen (ret) + 1;
+ size_t old_ret_len = ret_len;
for (int i = 1; i < len; i++)
{
- char *ret_tmp = realloc (ret, ret_len + strlen (s[i]) + 1);
- ret_len += strlen (s[i]) + 1;
- if (ret_tmp != NULL)
- ret = ret_tmp;
- sprintf (ret, "%s%c%s", ret, delim, s[i]);
+ char *ret_tmp = malloc (ret_len + strlen (s[i])); // i should use realloc here but that breaks on musl so malloc it is :3
+ ret_len += strlen (s[i]) + 1;
+ if (ret_tmp != NULL) {
+ sprintf (ret_tmp, "%s%s%s", ret, delim, s[i]);
+ free_secure ((void **) &ret, strlen (ret));
+ ret = ret_tmp;
+ }
}
return ret;