File: memcmp.c

package info (click to toggle)
ghdl 0.29%2Bgcc4.3.4%2Bdfsg-1
  • links: PTS
  • area: main
  • in suites: squeeze
  • size: 127,928 kB
  • ctags: 84,078
  • sloc: ansic: 1,016,442; ada: 102,633; makefile: 51,566; asm: 27,741; sh: 14,879; cpp: 4,767; f90: 3,583; ml: 2,485; yacc: 1,102; perl: 1,092; exp: 745; awk: 639; lex: 461; fortran: 394; pascal: 87; lisp: 59
file content (34 lines) | stat: -rw-r--r-- 872 bytes parent folder | download | duplicates (15)
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
/* 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>
#include <stddef.h>

int
memcmp (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;
}