From dc48005c286d3bd25c0e881174cc72a3ab511fd7 Mon Sep 17 00:00:00 2001 From: Corinna Vinschen Date: Wed, 11 Mar 2009 12:57:53 +0000 Subject: * libc/include/wchar.h (wcscasecmp, wcsncasecmp): Declare. * libc/string/Makefile.am: Add wcscasecmp.c, wcsncasecmp.c * libc/stdio/Makefile.in: Regenerate. * libc/string/strings.tex: Add new documentation references. * libc/string/wcscasecmp.c: New file. * libc/string/wcsncasecmp.c: New file. --- newlib/libc/string/wcscasecmp.c | 56 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 newlib/libc/string/wcscasecmp.c (limited to 'newlib/libc/string/wcscasecmp.c') diff --git a/newlib/libc/string/wcscasecmp.c b/newlib/libc/string/wcscasecmp.c new file mode 100644 index 000000000..f9f169f8b --- /dev/null +++ b/newlib/libc/string/wcscasecmp.c @@ -0,0 +1,56 @@ +/* +FUNCTION + <>---case-insensitive wide character string compare + +INDEX + wcscasecmp + +ANSI_SYNOPSIS + #include + int wcscasecmp(const wchar_t *<[a]>, const wchar_t *<[b]>); + +TRAD_SYNOPSIS + #include + int wcscasecmp(<[a]>, <[b]>) + wchar_t *<[a]>; + wchar_t *<[b]>; + +DESCRIPTION + <> compares the wide character string at <[a]> to + the wide character string at <[b]> in a case-insensitive manner. + +RETURNS + + If <<*<[a]>>> sorts lexicographically after <<*<[b]>>> (after + both are converted to uppercase), <> 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 +POSIX-1.2008 + +<> requires no supporting OS subroutines. It uses +tolower() from elsewhere in this library. + +QUICKREF + wcscasecmp +*/ + +#include +#include + +int +_DEFUN (wcscasecmp, (s1, s2), + _CONST wchar_t *s1 _AND + _CONST wchar_t *s2) +{ + while (*s1 != '\0' && towlower(*s1) == towlower(*s2)) + { + s1++; + s2++; + } + + return towlower(*s1) - towlower(*s2); +} -- cgit v1.2.3