1 /* nl_langinfo -- Access to locale-dependent parameters.
2 Copyright (C) 1995, 1996, 1998 Free Software Foundation, Inc.
3 This file is part of the GNU C Library.
5 The GNU C Library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Library General Public License as
7 published by the Free Software Foundation; either version 2 of the
8 License, or (at your option) any later version.
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 Library General Public License for more details.
15 You should have received a copy of the GNU Library General Public
16 License along with the GNU C Library; see the file COPYING.LIB. If not,
17 write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18 Boston, MA 02111-1307, USA. */
23 #include <locale.h> /* Define the LC_* category names. */
27 /* Construct an `nl_item' value for `nl_langinfo' from a locale category
28 (LC_*) and an item index within the category. Some code may depend on
29 the item values within a category increasing monotonically with the
31 #define _NL_ITEM(category, index) (((category) << 16) | (index))
33 /* Extract the category and item index from a constructed `nl_item' value. */
34 #define _NL_ITEM_CATEGORY(item) ((int) (item) >> 16)
35 #define _NL_ITEM_INDEX(item) ((int) (item) & 0xffff)
38 /* Enumeration of locale items that can be queried with `nl_langinfo'. */
41 /* LC_TIME category: date and time formatting. */
43 /* Abbreviated days of the week. */
44 ABDAY_1
= _NL_ITEM (LC_TIME
, 0), /* Sun */
45 #define ABDAY_1 ABDAY_1
47 #define ABDAY_2 ABDAY_2
49 #define ABDAY_3 ABDAY_3
51 #define ABDAY_4 ABDAY_4
53 #define ABDAY_5 ABDAY_5
55 #define ABDAY_6 ABDAY_6
57 #define ABDAY_7 ABDAY_7
59 /* Long-named days of the week. */
66 DAY_4
, /* Wednesday */
75 /* Abbreviated month names. */
77 #define ABMON_1 ABMON_1
79 #define ABMON_2 ABMON_2
81 #define ABMON_3 ABMON_3
83 #define ABMON_4 ABMON_4
85 #define ABMON_5 ABMON_5
87 #define ABMON_6 ABMON_6
89 #define ABMON_7 ABMON_7
91 #define ABMON_8 ABMON_8
93 #define ABMON_9 ABMON_9
95 #define ABMON_10 ABMON_10
97 #define ABMON_11 ABMON_11
99 #define ABMON_12 ABMON_12
101 /* Long month names. */
121 #define MON_10 MON_10
123 #define MON_11 MON_11
125 #define MON_12 MON_12
127 AM_STR
, /* Ante meridian string. */
128 #define AM_STR AM_STR
129 PM_STR
, /* Post meridian string. */
130 #define PM_STR PM_STR
132 D_T_FMT
, /* Date and time format for strftime. */
133 #define D_T_FMT D_T_FMT
134 D_FMT
, /* Date format for strftime. */
136 T_FMT
, /* Time format for strftime. */
138 T_FMT_AMPM
, /* 12-hour time format for strftime. */
139 #define T_FMT_AMPM T_FMT_AMPM
141 ERA
, /* Alternate era. */
143 ERA_YEAR
, /* Year in alternate era format. */
144 #define ERA_YEAR ERA_YEAR
145 ERA_D_FMT
, /* Date in alternate era format. */
146 #define ERA_D_FMT ERA_D_FMT
147 ALT_DIGITS
, /* Alternate symbols for digits. */
148 #define ALT_DIGITS ALT_DIGITS
149 ERA_D_T_FMT
, /* Date and time in alternate era format. */
150 #define ERA_D_T_FMT ERA_D_T_FMT
151 ERA_T_FMT
, /* Time in alternate era format. */
152 #define ERA_T_FMT ERA_T_FMT
154 _NL_TIME_NUM_ALT_DIGITS
, /* Number entries in the alt_digits arrays. */
156 _NL_TIME_ERA_NUM_ENTRIES
, /* Number entries in the era arrays. */
157 _NL_TIME_ERA_ENTRIES_EB
, /* Structure with era entries in usable form.*/
158 _NL_TIME_ERA_ENTRIES_EL
,
160 _NL_NUM_LC_TIME
, /* Number of indices in LC_TIME category. */
162 /* LC_COLLATE category: text sorting.
163 This information is accessed by the strcoll and strxfrm functions.
164 These `nl_langinfo' names are used only internally. */
165 _NL_COLLATE_NRULES
= _NL_ITEM (LC_COLLATE
, 0),
167 _NL_COLLATE_HASH_SIZE
,
168 _NL_COLLATE_HASH_LAYERS
,
169 _NL_COLLATE_TABLE_EB
,
170 _NL_COLLATE_TABLE_EL
,
171 _NL_COLLATE_UNDEFINED
,
172 _NL_COLLATE_EXTRA_EB
,
173 _NL_COLLATE_EXTRA_EL
,
174 _NL_COLLATE_ELEM_HASH_SIZE
,
175 _NL_COLLATE_ELEM_HASH_EB
,
176 _NL_COLLATE_ELEM_HASH_EL
,
177 _NL_COLLATE_ELEM_STR_POOL
,
178 _NL_COLLATE_ELEM_VAL_EB
,
179 _NL_COLLATE_ELEM_VAL_EL
,
180 _NL_COLLATE_SYMB_HASH_SIZE
,
181 _NL_COLLATE_SYMB_HASH_EB
,
182 _NL_COLLATE_SYMB_HASH_EL
,
183 _NL_COLLATE_SYMB_STR_POOL
,
184 _NL_COLLATE_SYMB_CLASS_EB
,
185 _NL_COLLATE_SYMB_CLASS_EL
,
188 /* LC_CTYPE category: character classification.
189 This information is accessed by the functions in <ctype.h>.
190 These `nl_langinfo' names are used only internally. */
191 _NL_CTYPE_CLASS
= _NL_ITEM (LC_CTYPE
, 0),
192 _NL_CTYPE_TOUPPER_EB
,
193 _NL_CTYPE_TOLOWER_EB
,
194 _NL_CTYPE_TOUPPER_EL
,
195 _NL_CTYPE_TOLOWER_EL
,
200 _NL_CTYPE_HASH_LAYERS
,
201 _NL_CTYPE_CLASS_NAMES
,
204 _NL_CTYPE_MB_CUR_MAX
,
205 _NL_CTYPE_CODESET_NAME
,
208 /* LC_MONETARY category: formatting of monetary quantities.
209 These items each correspond to a member of `struct lconv',
210 defined in <locale.h>. */
211 INT_CURR_SYMBOL
= _NL_ITEM (LC_MONETARY
, 0),
212 #define INT_CURR_SYMBOL INT_CURR_SYMBOL
214 #define CURRENCY_SYMBOL CURRENCY_SYMBOL
216 #define MON_DECIMAL_POINT MON_DECIMAL_POINT
218 #define MON_THOUSANDS_SEP MON_THOUSANDS_SEP
220 #define MON_GROUPING MON_GROUPING
222 #define POSITIVE_SIGN POSITIVE_SIGN
224 #define NEGATIVE_SIGN NEGATIVE_SIGN
226 #define INT_FRAC_DIGITS INT_FRAC_DIGITS
228 #define FRAC_DIGITS FRAC_DIGITS
230 #define P_CS_PRECEDES P_CS_PRECEDES
232 #define P_SEP_BY_SPACE P_SEP_BY_SPACE
234 #define N_CS_PRECEDES N_CS_PRECEDES
236 #define N_SEP_BY_SPACE N_SEP_BY_SPACE
238 #define P_SIGN_POSN P_SIGN_POSN
240 #define N_SIGN_POSN N_SIGN_POSN
243 /* LC_NUMERIC category: formatting of numbers.
244 These also correspond to members of `struct lconv'; see <locale.h>. */
245 DECIMAL_POINT
= _NL_ITEM (LC_NUMERIC
, 0),
246 #define DECIMAL_POINT DECIMAL_POINT
248 #define THOUSANDS_SEP THOUSANDS_SEP
250 #define GROUPING GROUPING
253 YESEXPR
= _NL_ITEM (LC_MESSAGES
, 0), /* Regex matching ``yes'' input. */
254 #define YESEXPR YESEXPR
255 NOEXPR
, /* Regex matching ``no'' input. */
256 #define NOEXPR NOEXPR
257 YESSTR
, /* Output string for ``yes''. */
258 #define YESSTR YESSTR
259 NOSTR
, /* Output string for ``no''. */
263 /* This marks the highest value used. */
268 /* Return the current locale's value for ITEM.
269 If ITEM is invalid, an empty string is returned.
271 The string returned will not change until `setlocale' is called;
272 it is usually in read-only memory and cannot be modified. */
274 extern char *nl_langinfo
__P ((nl_item __item
));
279 #endif /* langinfo.h */