File: memchr.c

package info (click to toggle)
binutils 2.40-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bookworm-backports
  • size: 364,620 kB
  • sloc: ansic: 1,286,348; asm: 715,071; cpp: 215,388; exp: 74,960; makefile: 69,766; sh: 23,124; yacc: 15,309; lisp: 13,258; perl: 12,204; lex: 1,712; ada: 1,681; pascal: 1,446; cs: 879; java: 443; sed: 195; python: 154; xml: 95; awk: 25
file content (33 lines) | stat: -rw-r--r-- 823 bytes parent folder | download | duplicates (24)
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
/*

@deftypefn Supplemental void* memchr (const void *@var{s}, int @var{c}, @
  size_t @var{n})

This function searches memory starting at @code{*@var{s}} for the
character @var{c}.  The search only ends with the first occurrence of
@var{c}, or after @var{length} characters; in particular, a null
character does not terminate the search.  If the character @var{c} is
found within @var{length} characters of @code{*@var{s}}, a pointer
to the character is returned.  If @var{c} is not found, then @code{NULL} is
returned.

@end deftypefn

*/

#include <ansidecl.h>
#include <stddef.h>

void *
memchr (register const void *src_void, int c, size_t length)
{
  const unsigned char *src = (const unsigned char *)src_void;
  
  while (length-- > 0)
  {
    if (*src == c)
     return (void *)src;
    src++;
  }
  return NULL;
}