You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
|
#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. */
|
|
|
|
int byte_diff(const void* a, size_t len, const void* b) {
|
|
|
|
register const unsigned char* s=a;
|
|
|
|
register const unsigned char* t=b;
|
|
|
|
register const unsigned char* u=t+len;
|
|
|
|
register int j;
|
|
|
|
j=0;
|
|
|
|
for (;;) {
|
|
|
|
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;
|
|
|
|
}
|
|
|
|
return j;
|
|
|
|
}
|