#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) {
#if 0
  /* this gets miscompiled by gcc 4.3.2 on x86_64 */
  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;
#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
}