diff options
author | Ulrich Drepper <drepper@redhat.com> | 1999-08-31 07:04:41 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 1999-08-31 07:04:41 +0000 |
commit | 4b10dd6c1959577f57850ca427a94fe22b9f3299 (patch) | |
tree | b385d9b27e5a40d5baf7cd7e27c7cc5ef7129b5b /locale/localeinfo.h | |
parent | 1d1740d6b12894ed6a430e2e98bf73c5243b2925 (diff) | |
download | glibc-4b10dd6c1959577f57850ca427a94fe22b9f3299.zip glibc-4b10dd6c1959577f57850ca427a94fe22b9f3299.tar.gz glibc-4b10dd6c1959577f57850ca427a94fe22b9f3299.tar.bz2 |
Update.
* locale/Makefile (distribute): Add iso-639.def and iso-3166.def.
Change charset.h to charmap.h.
(categories): Add new categories. Leave out collate for now.
Update build rules.
* locale/categories.def: Add definitions for new categories.
* locale/langinfo.h: Likewise.
* locale/locale.h: Likewise.
* locale/C-address.c: New file.
* locale/C-identification.c: New file.
* locale/C-measurement.c: New file.
* locale/C-name.c: New file.
* locale/C-paper.c: New file.
* locale/C-telephone.c: New file.
* locale/lc-address.c: Likewise.
* locale/lc-identification.c: Likewise.
* locale/lc-measurement.c: Likewise.
* locale/lc-name.c: Likewise.
* locale/lc-paper.c: Likewise.
* locale/lc-telephone.c: Likewise.
* locale/C-ctype.c: Update for locale rewrite.
* locale/C-messages.c: Likewise.
* locale/C-monetary.c: Likewise.
* locale/C-time.c: Likewise.
* locale/lc-collate.c: Likewise.
* locale/lc-ctype.c: Likewise.
* locale/lc-monetary.c: Likewise.
* locale/lc-time.c: Likewise.
* locale/localeinfo.h: Likewise.
* locale/newlocale.c: Likewise.
* locale/setlocale.c: Likewise.
* locale/weight.h: Likewise.
* locale/findlocale.c: Unconditionally use mmap.
Handle new categories.
* locale/loadlocale.c: Likewise.
* locale/iso-3166.def: New file.
* locale/iso-639.def: New file.
* locale/programs/charmap-kw.gperf: Add new keywords.
* locale/programs/locfile-kw.gperf: Likewise.
* locale/programs/locfile-token.h: Define new tokens.
* locale/programs/charmap.c: Rewrite to handle multibyte charsets.
* locale/programs/charmap.h: New file.
* locale/programs/charset.h: Removed.
* locale/programs/config.h: Add __LC_LAST.
* locale/programs/lc-address.c: New file.
* locale/programs/lc-identification.c: New file.
* locale/programs/lc-measurement.c: New file.
* locale/programs/lc-name.c: New file.
* locale/programs/lc-paper.c: New file.
* locale/programs/lc-telephone.c: New file.
* locale/programs/lc-collate.c: Update for locale rewrite.
* locale/programs/lc-ctype.c: Likewise.
* locale/programs/lc-messages.c: Likewise.
* locale/programs/lc-monetary.c: Likewise.
* locale/programs/lc-numeric.c: Likewise.
* locale/programs/lc-time.c: Likewise.
* locale/programs/locale.c: Likewise.
* locale/programs/localedef.c: Likewise.
* locale/programs/locfile.c: Likewise.
* locale/programs/repertoire.c: Likewise.
* locale/programs/repertoire.h: Likewise.
* locale/programs/locfile.c: Update prototypes.
Update handle_copy definition.
* locale/programs/linereader.c: Add handling of wide char strings and
new definition file syntax.
* locale/programs/linereader.h (struct token): Add elements for wide
character strings.
* locale/programs/locale-spec.c: Disable handling of collation
elements for now.
* locale/programs/simple-hash.h: Cleanup.
* locale/programs/stringtrans.h: Handle quite of end of line.
* string/strcoll.c: Fall back on strcmp for now.
* string/strxfrm.c: Fall back on strncpy/strlen for now.
* time/strftime.c: Use new wide character data for wcsftime.
* time/strptime.c: Remove _nl_C_LC_TIME declaration.
* wctype/cname-lookup.h: Update for new LC_CTYPE data.
Diffstat (limited to 'locale/localeinfo.h')
-rw-r--r-- | locale/localeinfo.h | 59 |
1 files changed, 33 insertions, 26 deletions
diff --git a/locale/localeinfo.h b/locale/localeinfo.h index 2c1ce65..773143d 100644 --- a/locale/localeinfo.h +++ b/locale/localeinfo.h @@ -1,5 +1,5 @@ -/* localeinfo.h -- declarations for internal libc locale interfaces - Copyright (C) 1995, 1996, 1997, 1999 Free Software Foundation, Inc. +/* Declarations for internal libc locale interfaces + Copyright (C) 1995, 1996, 1997, 1998, 1999 Free Software Foundation, Inc. This file is part of the GNU C Library. The GNU C Library is free software; you can redistribute it and/or @@ -24,17 +24,21 @@ #include <langinfo.h> #include <limits.h> #include <time.h> +#include <stdint.h> #include <sys/types.h> -#include "../intl/loadinfo.h" /* For loaded_l10nfile definition. */ +/* This has to be changed whenever a new locale is defined. */ +#define __LC_LAST 13 + +#include <intl/loadinfo.h> /* For loaded_l10nfile definition. */ /* Magic number at the beginning of a locale data file for CATEGORY. */ -#define LIMAGIC(category) (0x960617de ^ (category)) +#define LIMAGIC(category) (0x980505 ^ (category)) /* Two special weight constants for the collation data. */ -#define FORWARD_CHAR ((wchar_t) 0xfffffffd) -#define ELLIPSIS_CHAR ((wchar_t) 0xfffffffe) -#define IGNORE_CHAR ((wchar_t) 0xffffffff) +#define FORWARD_CHAR ((uint32_t) 0xfffffffd) +#define ELLIPSIS_CHAR ((uint32_t) 0xfffffffe) +#define IGNORE_CHAR ((uint32_t) 0xffffffff) /* We use a special value for the usage counter in `locale_data' to signal that this data must never be removed anymore. */ @@ -54,7 +58,7 @@ struct locale_data unsigned int nstrings; /* Number of strings below. */ union locale_data_value { - const wchar_t *wstr; + const uint32_t *wstr; const char *string; unsigned int word; } @@ -83,14 +87,15 @@ enum value_type byte, bytearray, word, - stringlist + stringlist, + wordarray }; /* Structure to access `era' information from LC_TIME. */ struct era_entry { - u_int32_t direction; /* Contains '+' or '-'. */ + uint32_t direction; /* Contains '+' or '-'. */ int32_t offset; int32_t start_date[3]; int32_t stop_date[3]; @@ -99,27 +104,26 @@ struct era_entry /* For each category declare the variable for the current locale data. */ -#define DEFINE_CATEGORY(category, category_name, items, a, b, c, d) \ +#define DEFINE_CATEGORY(category, category_name, items, a) \ extern struct locale_data *_nl_current_##category; #include "categories.def" #undef DEFINE_CATEGORY -extern const char _nl_category_names[LC_ALL + 1][16]; -extern const size_t _nl_category_name_sizes[LC_ALL + 1]; -extern struct locale_data * *const _nl_current[LC_ALL + 1]; +extern const char *const _nl_category_names[__LC_LAST]; +extern const size_t _nl_category_name_sizes[__LC_LAST]; +extern struct locale_data * *const _nl_current[__LC_LAST]; /* Name of the standard locales. */ extern const char _nl_C_name[]; extern const char _nl_POSIX_name[]; -/* XXX Temporily until the locale data has everything. */ -extern struct locale_data _nl_C_LC_TIME; - /* Extract the current CATEGORY locale's string for ITEM. */ #define _NL_CURRENT(category, item) \ - ((item) < _NL_WABDAY_1 || (item) > _NL_WALT_DIGITS \ - ? (_nl_current_##category->values[_NL_ITEM_INDEX (item)].string) \ - : _nl_C_LC_TIME.values[_NL_ITEM_INDEX (item)].string) + (_nl_current_##category->values[_NL_ITEM_INDEX (item)].string) + +/* Extract the current CATEGORY locale's string for ITEM. */ +#define _NL_CURRENT_WSTR(category, item) \ + ((wchar_t *) (_nl_current_##category->values[_NL_ITEM_INDEX (item)].wstr)) /* Extract the current CATEGORY locale's word for ITEM. */ #define _NL_CURRENT_WORD(category, item) \ @@ -154,15 +158,18 @@ extern struct era_entry *_nl_get_era_entry (const struct tm *tp); /* Return `alt_digit' which corresponds to NUMBER. Used in strftime. */ extern const char *_nl_get_alt_digit (unsigned int number); +/* Similar, but now for wide characters. */ +extern const wchar_t *_nl_get_walt_digit (unsigned int number); + /* Global variables for LC_COLLATE category data. */ -extern const u_int32_t *__collate_table; -extern const u_int32_t *__collate_extra; -extern const u_int32_t *__collate_element_hash; +extern const uint32_t *__collate_tablewc; +extern const uint32_t *__collate_extrawc; +extern const uint32_t *__collate_element_hash; extern const char *__collate_element_strings; -extern const wchar_t *__collate_element_values; -extern const u_int32_t *__collate_symbol_hash; +extern const uint32_t *__collate_element_values; +extern const uint32_t *__collate_symbol_hash; extern const char *__collate_symbol_strings; -extern const u_int32_t *__collate_symbol_classes; +extern const uint32_t *__collate_symbol_classes; #endif /* localeinfo.h */ |