aboutsummaryrefslogtreecommitdiff
path: root/src/extstring.c
diff options
context:
space:
mode:
authoraxtlos <axtlos@disroot.org>2024-09-27 21:31:47 +0200
committeraxtlos <axtlos@disroot.org>2024-09-27 21:31:47 +0200
commitb2182396df5d99ff5c26161aaffa5ced879742c5 (patch)
treec848fc157ab55c63b49b063d212c1671fa41afae /src/extstring.c
parent7aa261f8d57cb53cc334f6bf1920a6f8517ff054 (diff)
downloadextlib-b2182396df5d99ff5c26161aaffa5ced879742c5.tar.gz
extlib-b2182396df5d99ff5c26161aaffa5ced879742c5.tar.bz2
Fix join_str on musl and add manpage
Diffstat (limited to '')
-rw-r--r--src/extstring.c17
1 files changed, 10 insertions, 7 deletions
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;