Files
mars-libowfat/byte/byte_rchr.c
2025-01-20 16:43:48 +00:00

17 lines
582 B
C

#include <libowfat/byte.h>
/* byte_rchr returns the largest integer i between 0 and len-1 inclusive
* such that one[i] equals needle, or len if not found. */
size_t byte_rchr(const void* haystack,size_t len,char needle) {
register char c=needle;
register const char* s=haystack;
register const char* t=s+len;
for (;;) {
--t; if (s>t) break; if (*t==c) return (size_t)(t-s);
--t; if (s>t) break; if (*t==c) return (size_t)(t-s);
--t; if (s>t) break; if (*t==c) return (size_t)(t-s);
--t; if (s>t) break; if (*t==c) return (size_t)(t-s);
}
return len;
}