libowfat/byte/byte_rchr.c

17 lines
547 B
C
Raw Normal View History

2001-02-02 17:54:47 +00:00
#include "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. */
unsigned long byte_rchr(const void* haystack,unsigned long 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 (;;) {
2004-03-09 00:20:10 +00:00
--t; if (s>t) break; if (*t==c) return t-s;
--t; if (s>t) break; if (*t==c) return t-s;
--t; if (s>t) break; if (*t==c) return t-s;
--t; if (s>t) break; if (*t==c) return t-s;
2001-02-02 17:54:47 +00:00
}
return len;
2001-02-02 17:54:47 +00:00
}