]>
Commit | Line | Data |
---|---|---|
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 | +} |