From: David Levine Date: Mon, 25 Feb 2013 03:55:28 +0000 (-0600) Subject: Added find_str() and rfind_str() to sbr/utils.c X-Git-Url: https://diplodocus.org/git/nmh/commitdiff_plain/f4248b3c0da14fc8874007a080357400af84974e?ds=sidebyside;hp=eceaf7315dcf1e04a5195d3da52c5c9836fdce25 Added find_str() and rfind_str() to sbr/utils.c --- diff --git a/h/utils.h b/h/utils.h index 25bbeee9..7a096a18 100644 --- a/h/utils.h +++ b/h/utils.h @@ -19,3 +19,5 @@ struct msgs_array { void app_msgarg(struct msgs_array *, char *); int open_form(char **, char *); +char *find_str (const char [], size_t, const char *); +char *rfind_str (const char [], size_t, const char *); diff --git a/sbr/utils.c b/sbr/utils.c index 5bfc649e..87fedd58 100644 --- a/sbr/utils.c +++ b/sbr/utils.c @@ -241,3 +241,41 @@ open_form(char **form, char *def) } return in; } + + +/* + * Finds first occurrence of str in buf. buf is not a C string but a + * byte array of length buflen. str is a null-terminated C string. + * find_str() does not modify buf but passes back a non-const char * + * pointer so that the caller can modify it. + */ +char * +find_str (const char buf[], size_t buflen, const char *str) { + const size_t len = strlen (str); + size_t i; + + for (i = 0; i + len <= buflen; ++i, ++buf) { + if (! memcmp (buf, str, len)) return (char *) buf; + } + + return NULL; +} + + +/* + * Finds last occurrence of str in buf. buf is not a C string but a + * byte array of length buflen. str is a null-terminated C string. + * find_str() does not modify buf but passes back a non-const char * + * pointer so that the caller can modify it. + */ +char * +rfind_str (const char buf[], size_t buflen, const char *str) { + const size_t len = strlen (str); + size_t i; + + for (i = 0, buf += buflen - len; i + len <= buflen; ++i, --buf) { + if (! memcmp (buf, str, len)) return (char *) buf; + } + + return NULL; +}