2002-09-01 Roland McGrath <roland@redhat.com>
[kopensolaris-gnu/glibc.git] / locale / lc-ctype.c
1 /* Define current locale data for LC_CTYPE category.
2    Copyright (C) 1995-1999, 2000, 2002 Free Software Foundation, Inc.
3    This file is part of the GNU C Library.
4
5    The GNU C Library is free software; you can redistribute it and/or
6    modify it under the terms of the GNU Lesser General Public
7    License as published by the Free Software Foundation; either
8    version 2.1 of the License, or (at your option) any later version.
9
10    The GNU C Library is distributed in the hope that it will be useful,
11    but WITHOUT ANY WARRANTY; without even the implied warranty of
12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13    Lesser General Public License for more details.
14
15    You should have received a copy of the GNU Lesser General Public
16    License along with the GNU C Library; if not, write to the Free
17    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
18    02111-1307 USA.  */
19
20 #include "localeinfo.h"
21 #include <ctype.h>
22 #include <endian.h>
23 #include <stdint.h>
24
25 _NL_CURRENT_DEFINE (LC_CTYPE);
26
27 /* We are called after loading LC_CTYPE data to load it into
28    the variables used by the ctype.h macros.
29
30    There are three arrays of short ints which need to be indexable
31    from -128 to 255 inclusive.  Stored in the locale data file are
32    a copy of each for each byte order.  */
33
34 void
35 _nl_postload_ctype (void)
36 {
37 #include <shlib-compat.h>
38 #if SHLIB_COMPAT (libc, GLIBC_2_0, GLIBC_2_3)
39
40 #define paste(a,b) paste1(a,b)
41 #define paste1(a,b) a##b
42
43 #define current(type,x,offset) \
44   ((const type *) _NL_CURRENT (LC_CTYPE, paste(_NL_CTYPE_,x)) + offset)
45
46 /* These are defined in ctype-info.c.
47    The declarations here must match those in localeinfo.h.
48
49    These point into arrays of 384, so they can be indexed by any `unsigned
50    char' value [0,255]; by EOF (-1); or by any `signed char' value
51    [-128,-1).  ISO C requires that the ctype functions work for `unsigned
52    char' values and for EOF; we also support negative `signed char' values
53    for broken old programs.  The case conversion arrays are of `int's
54    rather than `unsigned char's because tolower (EOF) must be EOF, which
55    doesn't fit into an `unsigned char'.  But today more important is that
56    the arrays are also used for multi-byte character sets.  */
57   extern __const unsigned short int *__ctype_old_b; /* Characteristics.  */
58   extern __const __int32_t *__ctype_old_tolower; /* Case conversions.  */
59   extern __const __int32_t *__ctype_old_toupper; /* Case conversions.  */
60
61   extern const uint32_t *__ctype32_old_b;
62   extern const uint32_t *__ctype32_old_toupper;
63   extern const uint32_t *__ctype32_old_tolower;
64
65   __ctype_old_b = current (uint16_t, CLASS, 128);
66   __ctype_old_toupper = current (uint32_t, TOUPPER, 128);
67   __ctype_old_tolower = current (uint32_t, TOLOWER, 128);
68   __ctype32_old_b = current (uint32_t, CLASS32, 0);
69   __ctype32_old_toupper = current (uint32_t, TOUPPER32, 0);
70   __ctype32_old_tolower = current (uint32_t, TOLOWER32, 0);
71 #endif
72 }