[go: up one dir, main page]

File: byte_diff.c

package info (click to toggle)
fnord 1.9-1
  • links: PTS
  • area: main
  • in suites: sarge
  • size: 328 kB
  • ctags: 167
  • sloc: ansic: 1,889; makefile: 99; sh: 62; perl: 36
file content (21 lines) | stat: -rw-r--r-- 767 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#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, unsigned int len, const void* b) {
  register const char* s=a;
  register const char* t=b;
  register const char* u=t+len;
  register int j;
  j=0;
  for (;;) {
    if (t==u) break; if ((j=(*s-*t))) break; ++s; ++t;
    if (t==u) break; if ((j=(*s-*t))) break; ++s; ++t;
    if (t==u) break; if ((j=(*s-*t))) break; ++s; ++t;
    if (t==u) break; if ((j=(*s-*t))) break; ++s; ++t;
  }
  return j;
}