diff options
Diffstat (limited to 'libbb/strrstr.c')
-rw-r--r-- | libbb/strrstr.c | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/libbb/strrstr.c b/libbb/strrstr.c new file mode 100644 index 0000000..a803dd9 --- /dev/null +++ b/libbb/strrstr.c @@ -0,0 +1,71 @@ +/* vi: set sw=4 ts=4: */ +/* + * Utility routines. + * + * Copyright (C) 2008 Bernhard Reutner-Fischer + * + * Licensed under GPLv2 or later, see file License in this tarball for details. + */ + +#ifdef __DO_STRRSTR_TEST +#include <stdlib.h> +#include <string.h> +#include <stdio.h> +#else +#include "libbb.h" +#endif + +/* + * The strrstr() function finds the last occurrence of the substring needle + * in the string haystack. The terminating nul characters are not compared. + */ +char* FAST_FUNC strrstr(const char *haystack, const char *needle) +{ + char *r = NULL; + + if (!needle[0]) + return (char*)haystack + strlen(haystack); + while (1) { + char *p = strstr(haystack, needle); + if (!p) + return r; + r = p; + haystack = p + 1; + } +} + +#ifdef __DO_STRRSTR_TEST +int main(int argc, char **argv) +{ + static const struct { + const char *h, *n; + int pos; + } test_array[] = { + /* 0123456789 */ + { "baaabaaab", "aaa", 5 }, + { "baaabaaaab", "aaa", 6 }, + { "baaabaab", "aaa", 1 }, + { "aaa", "aaa", 0 }, + { "aaa", "a", 2 }, + { "aaa", "bbb", -1 }, + { "a", "aaa", -1 }, + { "aaa", "", 3 }, + { "", "aaa", -1 }, + { "", "", 0 }, + }; + + int i; + + i = 0; + while (i < sizeof(test_array) / sizeof(test_array[0])) { + const char *r = strrstr(test_array[i].h, test_array[i].n); + printf("'%s' vs. '%s': '%s' - ", test_array[i].h, test_array[i].n, r); + if (r == NULL) + r = test_array[i].h - 1; + printf("%s\n", r == test_array[i].h + test_array[i].pos ? "PASSED" : "FAILED"); + i++; + } + + return 0; +} +#endif |