File: memcmp.c

package info (click to toggle)
gdb 6.3-6
  • links: PTS
  • area: main
  • in suites: sarge
  • size: 96,536 kB
  • ctags: 137,221
  • sloc: ansic: 1,109,876; exp: 69,029; asm: 49,350; makefile: 39,860; sh: 20,981; yacc: 7,516; cpp: 5,210; perl: 4,711; lex: 900; pascal: 438; lisp: 407; sed: 246; awk: 142; objc: 134; java: 47; ada: 15; fortran: 5
file content (41 lines) | stat: -rw-r--r-- 971 bytes parent folder | download | duplicates (25)
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
32
33
34
35
36
37
38
39
40
41
/* memcmp -- compare two memory regions.
   This function is in the public domain.  */

/*

@deftypefn Supplemental int memcmp (const void *@var{x}, const void *@var{y}, size_t @var{count})

Compares the first @var{count} bytes of two areas of memory.  Returns
zero if they are the same, a value less than zero if @var{x} is
lexically less than @var{y}, or a value greater than zero if @var{x}
is lexically greater than @var{y}.  Note that lexical order is determined
as if comparing unsigned char arrays.

@end deftypefn

*/

#include <ansidecl.h>
#ifdef ANSI_PROTOTYPES
#include <stddef.h>
#else
#define size_t unsigned long
#endif

int
memcmp (str1, str2, count)
     const PTR str1;
     const PTR str2;
     size_t count;
{
  register const unsigned char *s1 = (const unsigned char*)str1;
  register const unsigned char *s2 = (const unsigned char*)str2;

  while (count-- > 0)
    {
      if (*s1++ != *s2++)
	  return s1[-1] < s2[-1] ? -1 : 1;
    }
  return 0;
}