File: byte_diff.c

package info (click to toggle)
libowfat 0.28-6
  • links: PTS
  • area: main
  • in suites: wheezy
  • size: 4,068 kB
  • sloc: ansic: 12,863; makefile: 16
file content (31 lines) | stat: -rw-r--r-- 1,050 bytes parent folder | download | duplicates (8)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#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
}