]> git.saurik.com Git - apple/libc.git/blob - locale/FreeBSD/tolower.c.patch
Libc-391.2.10.tar.gz
[apple/libc.git] / locale / FreeBSD / tolower.c.patch
1 --- tolower.c.orig 2004-11-25 11:38:19.000000000 -0800
2 +++ tolower.c 2005-02-17 16:43:19.000000000 -0800
3 @@ -37,20 +37,32 @@
4 #include <sys/cdefs.h>
5 __FBSDID("$FreeBSD: src/lib/libc/locale/tolower.c,v 1.11 2004/07/29 06:16:19 tjr Exp $");
6
7 +#include "xlocale_private.h"
8 +
9 #include <stdio.h>
10 #include <runetype.h>
11
12 __ct_rune_t
13 -___tolower(c)
14 +___tolower_l(c, loc)
15 __ct_rune_t c;
16 + locale_t loc;
17 {
18 size_t lim;
19 - _RuneRange *rr = &_CurrentRuneLocale->__maplower_ext;
20 + _RuneRange *rr;
21 _RuneEntry *base, *re;
22
23 if (c < 0 || c == EOF)
24 return(c);
25
26 + NORMALIZE_LOCALE(loc);
27 + /*
28 + * the following is not used by tolower(), but can be used by
29 + * tolower_l(). This provides the oppurtunity to optimize tolower()
30 + * when compatibility for Panther and lower is no longer needed
31 + */
32 + if (c < _CACHED_RUNES)
33 + return loc->__lc_ctype->_CurrentRuneLocale.__maplower[c];
34 + rr = &loc->__lc_ctype->_CurrentRuneLocale.__maplower_ext;
35 /* Binary search -- see bsearch.c for explanation. */
36 base = rr->__ranges;
37 for (lim = rr->__nranges; lim != 0; lim >>= 1) {
38 @@ -65,3 +77,10 @@
39
40 return(c);
41 }
42 +
43 +__ct_rune_t
44 +___tolower(c)
45 + __ct_rune_t c;
46 +{
47 + return ___tolower_l(c, __current_locale());
48 +}