diff options
author | axtlos <axtlos@disroot.org> | 2024-09-27 21:31:47 +0200 |
---|---|---|
committer | axtlos <axtlos@disroot.org> | 2024-09-27 21:31:47 +0200 |
commit | b2182396df5d99ff5c26161aaffa5ced879742c5 (patch) | |
tree | c848fc157ab55c63b49b063d212c1671fa41afae /src | |
parent | 7aa261f8d57cb53cc334f6bf1920a6f8517ff054 (diff) | |
download | extlib-b2182396df5d99ff5c26161aaffa5ced879742c5.tar.gz extlib-b2182396df5d99ff5c26161aaffa5ced879742c5.tar.bz2 |
Fix join_str on musl and add manpage
Diffstat (limited to '')
-rw-r--r-- | src/extlib.h | 2 | ||||
-rw-r--r-- | src/extstring.c | 17 |
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; |