/* FUNCTION <>---case insensitive character string compare INDEX strncasecmp ANSI_SYNOPSIS #include int strncasecmp(const char *<[a]>, const char * <[b]>, size_t <[length]>); TRAD_SYNOPSIS #include int strncasecmp(<[a]>, <[b]>, <[length]>) char *<[a]>; char *<[b]>; size_t <[length]> DESCRIPTION <> compares up to <[length]> characters from the string at <[a]> to the string at <[b]> in a case-insensitive manner. RETURNS If <<*<[a]>>> sorts lexicographically after <<*<[b]>>> (after both are converted to upper case), <> returns a number greater than zero. If the two strings are equivalent, <> returns zero. If <<*<[a]>>> sorts lexicographically before <<*<[b]>>>, <> returns a number less than zero. PORTABILITY <> is in the Berkeley Software Distribution. <> requires no supporting OS subroutines. It uses tolower() from elsewhere in this library. QUICKREF strncasecmp */ #include #include int _DEFUN (strncasecmp, (s1, s2, n), _CONST char *s1 _AND _CONST char *s2 _AND size_t n) { if (n == 0) return 0; while (n-- != 0 && tolower(*s1) == tolower(*s2)) { if (n == 0 || *s1 == '\0' || *s2 == '\0') break; s1++; s2++; } return tolower(*(unsigned char *) s1) - tolower(*(unsigned char *) s2); }