libowfat/byte/byte_diff.c

32 lines
1.0 KiB
C
Raw Normal View History

2001-02-02 17:54:47 +00:00
#include "byte.h"
/* byte_diff returns negative, 0, or positive, depending on whether the
* string one[0], one[1], ..., one[len-1] is lexicographically smaller
* than, equal to, or greater than the string one[0], one[1], ...,
* one[len-1]. When the strings are different, byte_diff does not read
* bytes past the first difference. */
2006-11-07 17:56:05 +00:00
int byte_diff(const void* a, size_t len, const void* b) {
2008-10-13 16:08:52 +00:00
#if 0
/* this gets miscompiled by gcc 4.3.2 on x86_64 */
2004-03-12 23:20:42 +00:00
register const unsigned char* s=a;
register const unsigned char* t=b;
register const unsigned char* u=t+len;
2001-02-02 17:54:47 +00:00
register int j;
j=0;
for (;;) {
2004-03-12 23:20:42 +00:00
if (t==u) break; if ((j=((unsigned int)*s-*t))) break; ++s; ++t;
if (t==u) break; if ((j=((unsigned int)*s-*t))) break; ++s; ++t;
if (t==u) break; if ((j=((unsigned int)*s-*t))) break; ++s; ++t;
if (t==u) break; if ((j=((unsigned int)*s-*t))) break; ++s; ++t;
2001-02-02 17:54:47 +00:00
}
return j;
2008-10-13 16:08:52 +00:00
#else
size_t i;
for (i=0; i<len; ++i) {
int r=((unsigned char*)a)[i] - ((unsigned char*)b)[i];
if (r) return r;
}
return 0;
#endif
2001-02-02 17:54:47 +00:00
}