2001-02-02 17:54:47 +00:00
|
|
|
#include "byte.h"
|
|
|
|
|
|
|
|
/* byte_chr returns the smallest integer i between 0 and len-1
|
2005-12-28 16:48:17 +00:00
|
|
|
* inclusive such that one[i] equals needle, or len if not found. */
|
2006-11-07 17:56:05 +00:00
|
|
|
size_t byte_chr(const void* haystack, size_t len, char needle) {
|
2001-02-02 17:54:47 +00:00
|
|
|
register char c=needle;
|
|
|
|
register const char* s=haystack;
|
|
|
|
register const char* t=s+len;
|
|
|
|
for (;;) {
|
2016-04-27 14:07:49 +00:00
|
|
|
if (s==t || *s==c) break;
|
|
|
|
++s;
|
|
|
|
if (s==t || *s==c) break;
|
|
|
|
++s;
|
|
|
|
if (s==t || *s==c) break;
|
|
|
|
++s;
|
|
|
|
if (s==t || *s==c) break;
|
|
|
|
++s;
|
2001-02-02 17:54:47 +00:00
|
|
|
}
|
2014-03-14 00:24:25 +00:00
|
|
|
return (size_t)(s-(const char*)haystack);
|
2001-02-02 17:54:47 +00:00
|
|
|
}
|