diff options
author | Graham Leggett <minfrin@apache.org> | 2021-10-25 10:31:32 +0000 |
---|---|---|
committer | Graham Leggett <minfrin@apache.org> | 2021-10-25 10:31:32 +0000 |
commit | ee5f1d069bce4b8176b027a6eafcd2a959de9e6e (patch) | |
tree | 2496c988a306f92b2a6c51cff5f0f3cef4cf62d5 /buckets | |
parent | aa80a8cefca8ed257a3f191bd220695ae1c43cc6 (diff) | |
download | apr-ee5f1d069bce4b8176b027a6eafcd2a959de9e6e.tar.gz |
apr_brigade_split_boundary: Provide a memmem implementation on platforms that
do not have one.
git-svn-id: https://svn.apache.org/repos/asf/apr/apr/trunk@1894551 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'buckets')
-rw-r--r-- | buckets/apr_brigade.c | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/buckets/apr_brigade.c b/buckets/apr_brigade.c index 42823dc91..e5a642e44 100644 --- a/buckets/apr_brigade.c +++ b/buckets/apr_brigade.c @@ -387,6 +387,36 @@ APR_DECLARE(apr_status_t) apr_brigade_split_line(apr_bucket_brigade *bbOut, return APR_SUCCESS; } +#if !APR_HAVE_MEMMEM +static const void * +memmem(const void *hay, size_t hay_len, const void *needle, size_t needle_len) +{ + + if (hay_len < needle_len || !needle_len || !hay_len) { + return NULL; + } + else { + + apr_size_t len = hay_len - needle_len + 1; + const void *end = hay + hay_len; + const void *begin = hay; + + while ((hay = memchr(hay, *(char *)needle, len))) { + len = end - hay - needle_len + 1; + + if (memcmp(hay, needle, needle_len) == 0 ) { + break; + } + + --len; + ++hay; + } + + return hay; + } +} +#endif + APR_DECLARE(apr_status_t) apr_brigade_split_boundary(apr_bucket_brigade *bbOut, apr_bucket_brigade *bbIn, apr_read_type_e block, |