From c1b7d9d93dc8e88693162c0d984a114371919fdd Mon Sep 17 00:00:00 2001 From: Corinna Vinschen Date: Sun, 24 Jul 2016 20:00:34 +0200 Subject: Implement per-locale string functions strcasecmp_l, strcoll_l, strncasecmp_l, strxfrm_l, wcscasecmp_l, wcscoll_l, wcstrncasecmp_l, wcstrxfrm_l, strftime_l. Add missing CHEWOUT_FILES from previous patch. TODO: strfmon_l. Signed-off by: Corinna Vinschen --- newlib/libc/string/strcasecmp_l.c | 54 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 newlib/libc/string/strcasecmp_l.c (limited to 'newlib/libc/string/strcasecmp_l.c') diff --git a/newlib/libc/string/strcasecmp_l.c b/newlib/libc/string/strcasecmp_l.c new file mode 100644 index 000000000..f87039d91 --- /dev/null +++ b/newlib/libc/string/strcasecmp_l.c @@ -0,0 +1,54 @@ +/* +FUNCTION + <>---case-insensitive character string compare + +INDEX + strcasecmp_l + +ANSI_SYNOPSIS + #include + int strcasecmp_l(const char *<[a]>, const char *<[b]>, + locale_t <[locale]>); + +DESCRIPTION + <> compares the string at <[a]> to + the string at <[b]> in a case-insensitive manner. + + if <[locale]> is LC_GLOBAL_LOCALE or not a valid locale object, the + behaviour is undefined. + +RETURNS + + If <<*<[a]>>> sorts lexicographically after <<*<[b]>>> (after + both are converted to lowercase), <> returns a + number greater than zero. If the two strings match, + <> returns zero. If <<*<[a]>>> sorts + lexicographically before <<*<[b]>>>, <> returns a + number less than zero. + +PORTABILITY +<> is POSIX-1.2008. + +<> requires no supporting OS subroutines. It uses +tolower_l() from elsewhere in this library. + +QUICKREF + strcasecmp_l +*/ + +#include +#include + +int +strcasecmp_l (const char *s1, const char *s2, struct __locale_t *locale) +{ + int d = 0; + for ( ; ; ) + { + const int c1 = tolower_l (*s1++, locale); + const int c2 = tolower_l (*s2++, locale); + if (((d = c1 - c2) != 0) || (c2 == '\0')) + break; + } + return d; +} -- cgit v1.2.3