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 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111
|
/*
* Copyright (c) 1997, 98, 2000, 01
* Motoyuki Kasahara
*
* This programs is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2, or (at your option)
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
/*
* This program requires the following Autoconf macros:
* AC_C_CONST
* AC_TYPE_SIZE_T
*/
#ifdef HAVE_CONFIG_H
#include "config.h"
#else
/* Define to empty if the keyword `const' does not work. */
/* #define const */
/* Define if `size_t' is not defined. */
/* #define size_t unsigned */
#endif /* not HAVE_CONFIG_H */
#include <sys/types.h>
/*
* Compare strings.
* Cases in the strings are insensitive.
*/
int
strcasecmp(string1, string2)
const char *string1;
const char *string2;
{
const unsigned char *string1_p = (const unsigned char *)string1;
const unsigned char *string2_p = (const unsigned char *)string2;
int c1, c2;
while (*string1_p != '\0') {
if ('a' <= *string1_p && *string1_p <= 'z')
c1 = *string1_p - ('a' - 'A');
else
c1 = *string1_p;
if ('a' <= *string2_p && *string2_p <= 'z')
c2 = *string2_p - ('a' - 'A');
else
c2 = *string2_p;
if (c1 != c2)
return c1 - c2;
string1_p++;
string2_p++;
}
return -(*string2_p);
}
/*
* Compare strings within `n' characters.
* Cases in the strings are insensitive.
*/
int
strncasecmp(string1, string2, n)
const char *string1;
const char *string2;
size_t n;
{
const unsigned char *string1_p = (const unsigned char *)string1;
const unsigned char *string2_p = (const unsigned char *)string2;
size_t i = n;
int c1, c2;
if (i <= 0)
return 0;
while (*string1_p != '\0') {
if ('a' <= *string1_p && *string1_p <= 'z')
c1 = *string1_p - ('a' - 'A');
else
c1 = *string1_p;
if ('a' <= *string2_p && *string2_p <= 'z')
c2 = *string2_p - ('a' - 'A');
else
c2 = *string2_p;
if (c1 != c2)
return c1 - c2;
string1_p++;
string2_p++;
i--;
if (i <= 0)
return 0;
}
return -(*string2_p);
}
|