diff options
author | ache <ache@FreeBSD.org> | 1995-11-03 08:59:02 +0000 |
---|---|---|
committer | ache <ache@FreeBSD.org> | 1995-11-03 08:59:02 +0000 |
commit | 94bfe4fc2daad94a8db6f6357509d07c43ba23e7 (patch) | |
tree | a19d0b48f043559abd58365a4b3393bbc6da9c5c /lib/libc/locale/tolower.c | |
parent | 5f00167641d57332e1952cd7ec49cfc0aa9444d9 (diff) | |
download | FreeBSD-src-94bfe4fc2daad94a8db6f6357509d07c43ba23e7.zip FreeBSD-src-94bfe4fc2daad94a8db6f6357509d07c43ba23e7.tar.gz |
Move more stuff out to XPG4
Handle negative chars inside runetype/tolower/toupper
Diffstat (limited to 'lib/libc/locale/tolower.c')
-rw-r--r-- | lib/libc/locale/tolower.c | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/lib/libc/locale/tolower.c b/lib/libc/locale/tolower.c index f1d6fe0..e72a52c 100644 --- a/lib/libc/locale/tolower.c +++ b/lib/libc/locale/tolower.c @@ -41,18 +41,28 @@ _BSD_RUNE_T_ ___tolower(c) _BSD_RUNE_T_ c; { +#ifdef XPG4 int x; _RuneRange *rr = &_CurrentRuneLocale->maplower_ext; _RuneEntry *re = rr->ranges; +#endif if (c == EOF) return(EOF); + if (c < 0) { + if (c >= -128) /* signed char */ + return(_CurrentRuneLocale->maplower[(unsigned char)c]); + else + return(c); + } +#ifdef XPG4 for (x = 0; x < rr->nranges; ++x, ++re) { if (c < re->min) return(c); if (c <= re->max) return(re->map + c - re->min); } +#endif return(c); } |