diff options
author | Nick Mathewson <nickm@torproject.org> | 2018-06-27 15:28:55 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2018-06-27 15:28:55 -0400 |
commit | 9e592d1decf1b16128a716220de68322b51d6315 (patch) | |
tree | 064af78114c528fe06441067d9648e1dc5191c42 /src/lib/string | |
parent | 4d81f5211b3c714edae6370bccc6873033c0092d (diff) | |
download | tor-9e592d1decf1b16128a716220de68322b51d6315.tar.gz tor-9e592d1decf1b16128a716220de68322b51d6315.zip |
Move tor_strtok_r to libtor-string
Diffstat (limited to 'src/lib/string')
-rw-r--r-- | src/lib/string/compat_string.c | 53 | ||||
-rw-r--r-- | src/lib/string/compat_string.h | 7 |
2 files changed, 60 insertions, 0 deletions
diff --git a/src/lib/string/compat_string.c b/src/lib/string/compat_string.c index 6df1bc4a1d..3f8a4d515d 100644 --- a/src/lib/string/compat_string.c +++ b/src/lib/string/compat_string.c @@ -4,6 +4,7 @@ /* See LICENSE for licensing information */ #include "lib/string/compat_string.h" +#include "lib/err/torerr.h" /* Inline the strl functions if the platform doesn't have them. */ #ifndef HAVE_STRLCPY @@ -12,3 +13,55 @@ #ifndef HAVE_STRLCAT #include "strlcat.c" #endif + +#include <stdlib.h> + +/** Helper for tor_strtok_r_impl: Advances cp past all characters in + * <b>sep</b>, and returns its new value. */ +static char * +strtok_helper(char *cp, const char *sep) +{ + if (sep[1]) { + while (*cp && strchr(sep, *cp)) + ++cp; + } else { + while (*cp && *cp == *sep) + ++cp; + } + return cp; +} + +/** Implementation of strtok_r for platforms whose coders haven't figured out + * how to write one. Hey, retrograde libc developers! You can use this code + * here for free! */ +char * +tor_strtok_r_impl(char *str, const char *sep, char **lasts) +{ + char *cp, *start; + raw_assert(*sep); + if (str) { + str = strtok_helper(str, sep); + if (!*str) + return NULL; + start = cp = *lasts = str; + } else if (!*lasts || !**lasts) { + return NULL; + } else { + start = cp = *lasts; + } + + if (sep[1]) { + while (*cp && !strchr(sep, *cp)) + ++cp; + } else { + cp = strchr(cp, *sep); + } + + if (!cp || !*cp) { + *lasts = NULL; + } else { + *cp++ = '\0'; + *lasts = strtok_helper(cp, sep); + } + return start; +} diff --git a/src/lib/string/compat_string.h b/src/lib/string/compat_string.h index 212d08b7ae..24cd0f8b11 100644 --- a/src/lib/string/compat_string.h +++ b/src/lib/string/compat_string.h @@ -36,4 +36,11 @@ size_t strlcat(char *dst, const char *src, size_t siz) ATTR_NONNULL((1,2)); size_t strlcpy(char *dst, const char *src, size_t siz) ATTR_NONNULL((1,2)); #endif +char *tor_strtok_r_impl(char *str, const char *sep, char **lasts); +#ifdef HAVE_STRTOK_R +#define tor_strtok_r(str, sep, lasts) strtok_r(str, sep, lasts) +#else +#define tor_strtok_r(str, sep, lasts) tor_strtok_r_impl(str, sep, lasts) +#endif + #endif |