mirror of
git://sourceware.org/git/glibc.git
synced 2025-01-18 12:16:13 +08:00
4b10dd6c19
* 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.
405 lines
18 KiB
C
405 lines
18 KiB
C
/* ANSI-C code produced by gperf version 2.7.1 (19981006 egcs) */
|
|
/* Command-line: gperf -acCgopt -k1,2,5,9,$ -L ANSI-C -N locfile_hash programs/locfile-kw.gperf */
|
|
/* Copyright (C) 1996, 1997, 1998, 1999 Free Software Foundation, Inc.
|
|
This file is part of the GNU C Library.
|
|
Contributed by Ulrich Drepper <drepper@gnu.org>, 1996.
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Library General Public License as
|
|
published by the Free Software Foundation; either version 2 of the
|
|
License, or (at your option) any later version.
|
|
|
|
The GNU C Library is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Library General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Library General Public
|
|
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
Boston, MA 02111-1307, USA. */
|
|
|
|
#include <string.h>
|
|
|
|
#include "locfile-token.h"
|
|
struct keyword_t ;
|
|
|
|
#define TOTAL_KEYWORDS 172
|
|
#define MIN_WORD_LENGTH 3
|
|
#define MAX_WORD_LENGTH 22
|
|
#define MIN_HASH_VALUE 3
|
|
#define MAX_HASH_VALUE 545
|
|
/* maximum key range = 543, duplicates = 0 */
|
|
|
|
#ifdef __GNUC__
|
|
__inline
|
|
#endif
|
|
static unsigned int
|
|
hash (register const char *str, register unsigned int len)
|
|
{
|
|
static const unsigned short asso_values[] =
|
|
{
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
5, 0, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 20, 546, 0, 0, 0,
|
|
5, 30, 0, 0, 546, 546, 0, 546, 0, 0,
|
|
546, 546, 10, 0, 5, 10, 546, 546, 546, 0,
|
|
546, 546, 546, 546, 546, 30, 546, 0, 10, 125,
|
|
5, 0, 105, 30, 5, 95, 546, 0, 105, 155,
|
|
135, 50, 75, 0, 5, 45, 0, 55, 0, 30,
|
|
25, 25, 10, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546, 546, 546, 546, 546,
|
|
546, 546, 546, 546, 546, 546
|
|
};
|
|
register int hval = len;
|
|
|
|
switch (hval)
|
|
{
|
|
default:
|
|
case 9:
|
|
hval += asso_values[(unsigned char)str[8]];
|
|
case 8:
|
|
case 7:
|
|
case 6:
|
|
case 5:
|
|
hval += asso_values[(unsigned char)str[4]];
|
|
case 4:
|
|
case 3:
|
|
case 2:
|
|
hval += asso_values[(unsigned char)str[1]];
|
|
case 1:
|
|
hval += asso_values[(unsigned char)str[0]];
|
|
break;
|
|
}
|
|
return hval + asso_values[(unsigned char)str[len - 1]];
|
|
}
|
|
|
|
#ifdef __GNUC__
|
|
__inline
|
|
#endif
|
|
const struct keyword_t *
|
|
locfile_hash (register const char *str, register unsigned int len)
|
|
{
|
|
static const struct keyword_t wordlist[] =
|
|
{
|
|
{""}, {""}, {""},
|
|
{"END", tok_end, 0},
|
|
{""}, {""}, {""},
|
|
{"LC_TIME", tok_lc_time, 0},
|
|
{"era", tok_era, 0},
|
|
{"date", tok_date, 0},
|
|
{"LC_ADDRESS", tok_lc_address, 0},
|
|
{""},
|
|
{"LC_TELEPHONE", tok_lc_telephone, 0},
|
|
{"LC_CTYPE", tok_lc_ctype, 0},
|
|
{"era_t_fmt", tok_era_t_fmt, 0},
|
|
{"LC_COLLATE", tok_lc_collate, 0},
|
|
{"height", tok_height, 0},
|
|
{"LC_IDENTIFICATION", tok_lc_identification, 0},
|
|
{""},
|
|
{"era_d_fmt", tok_era_d_fmt, 0},
|
|
{"LC_NUMERIC", tok_lc_numeric, 0},
|
|
{""}, {""}, {""},
|
|
{"UNDEFINED", tok_undefined, 0},
|
|
{""},
|
|
{"reorder-end", tok_reorder_end, 0},
|
|
{"LC_NAME", tok_lc_name, 0},
|
|
{"reorder-after", tok_reorder_after, 0},
|
|
{"LC_MEASUREMENT", tok_lc_measurement, 0},
|
|
{""},
|
|
{"LC_MONETARY", tok_lc_monetary, 0},
|
|
{""},
|
|
{"day", tok_day, 0},
|
|
{"week", tok_week, 0},
|
|
{"t_fmt", tok_t_fmt, 0},
|
|
{"yesstr", tok_yesstr, 0},
|
|
{""},
|
|
{"LC_PAPER", tok_lc_paper, 0},
|
|
{""},
|
|
{"d_fmt", tok_d_fmt, 0},
|
|
{"LC_MESSAGES", tok_lc_messages, 0},
|
|
{""},
|
|
{"era_year", tok_era_year, 0},
|
|
{""}, {""},
|
|
{"IGNORE", tok_ignore, 0},
|
|
{""}, {""}, {""},
|
|
{"graph", tok_graph, 0},
|
|
{""}, {""},
|
|
{"backward", tok_backward, 0},
|
|
{""}, {""}, {""},
|
|
{"address", tok_address, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"yesexpr", tok_yesexpr, 0},
|
|
{"audience", tok_audience, 0},
|
|
{""},
|
|
{"abday", tok_abday, 0},
|
|
{""}, {""}, {""}, {""}, {""},
|
|
{"order_start", tok_order_start, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{"order_end", tok_order_end, 0},
|
|
{"reorder-sections-end", tok_reorder_sections_end, 0},
|
|
{""},
|
|
{"reorder-sections-after", tok_reorder_sections_after, 0},
|
|
{""}, {""},
|
|
{"print", tok_print, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""},
|
|
{"tolower", tok_tolower, 0},
|
|
{""},
|
|
{"translit_start", tok_translit_start, 0},
|
|
{""}, {""},
|
|
{"translit_end", tok_translit_end, 0},
|
|
{""}, {""},
|
|
{"title", tok_title, 0},
|
|
{""}, {""},
|
|
{"repertoiremap", tok_repertoiremap, 0},
|
|
{""},
|
|
{"digit", tok_digit, 0},
|
|
{""}, {""},
|
|
{"tel", tok_tel, 0},
|
|
{"else", tok_else, 0},
|
|
{"alpha", tok_alpha, 0},
|
|
{""}, {""},
|
|
{"timezone", tok_timezone, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""},
|
|
{"blank", tok_blank, 0},
|
|
{"tel_dom_fmt", tok_tel_dom_fmt, 0},
|
|
{""}, {""}, {""},
|
|
{"space", tok_space, 0},
|
|
{"era_d_t_fmt", tok_era_d_t_fmt, 0},
|
|
{"duo_valid_to", tok_duo_valid_to, 0},
|
|
{""}, {""}, {""},
|
|
{"xdigit", tok_xdigit, 0},
|
|
{""},
|
|
{"fax", tok_fax, 0},
|
|
{""},
|
|
{"punct", tok_punct, 0},
|
|
{""},
|
|
{"toupper", tok_toupper, 0},
|
|
{"symbol-equivalence", tok_symbol_equivalence, 0},
|
|
{""},
|
|
{"width", tok_width, 0},
|
|
{"escape_char", tok_escape_char, 0},
|
|
{""}, {""},
|
|
{"lang_name", tok_lang_name, 0},
|
|
{"upper", tok_upper, 0},
|
|
{"define", tok_define, 0},
|
|
{"d_t_fmt", tok_d_t_fmt, 0},
|
|
{"grouping", tok_grouping, 0},
|
|
{""}, {""}, {""},
|
|
{"lang_ab", tok_lang_ab, 0},
|
|
{"lang_lib", tok_lang_lib, 0},
|
|
{"territory", tok_territory, 0},
|
|
{""}, {""},
|
|
{"abbreviation", tok_abbreviation, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{"alt_digits", tok_alt_digits, 0},
|
|
{""},
|
|
{"forward", tok_forward, 0},
|
|
{"language", tok_language, 0},
|
|
{""},
|
|
{"lower", tok_lower, 0},
|
|
{""}, {""},
|
|
{"name_fmt", tok_name_fmt, 0},
|
|
{""}, {""}, {""},
|
|
{"name_mr", tok_name_mr, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"contact", tok_contact, 0},
|
|
{"thousands_sep", tok_thousands_sep, 0},
|
|
{""}, {""},
|
|
{"country_ab3", tok_country_ab3, 0},
|
|
{""},
|
|
{"category", tok_category, 0},
|
|
{""}, {""},
|
|
{"country_ab2", tok_country_ab2, 0},
|
|
{""},
|
|
{"revision", tok_revision, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""},
|
|
{"nostr", tok_nostr, 0},
|
|
{""}, {""}, {""},
|
|
{"copy", tok_copy, 0},
|
|
{""}, {""}, {""},
|
|
{"outdigit", tok_outdigit, 0},
|
|
{""}, {""},
|
|
{"tel_int_fmt", tok_tel_int_fmt, 0},
|
|
{""}, {""},
|
|
{"elif", tok_elif, 0},
|
|
{""}, {""},
|
|
{"name_ms", tok_name_ms, 0},
|
|
{"name_mrs", tok_name_mrs, 0},
|
|
{""}, {""},
|
|
{"measurement", tok_measurement, 0},
|
|
{"collating-element", tok_collating_element, 0},
|
|
{""},
|
|
{"p_sep_by_space", tok_p_sep_by_space, 0},
|
|
{""},
|
|
{"source", tok_source, 0},
|
|
{"duo_p_cs_precedes", tok_duo_p_cs_precedes, 0},
|
|
{"duo_p_sep_by_space", tok_duo_p_sep_by_space, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"map", tok_map, 0},
|
|
{"duo_valid_from", tok_duo_valid_from, 0},
|
|
{""}, {""}, {""},
|
|
{"first_weekday", tok_first_weekday, 0},
|
|
{""},
|
|
{"conversion_rate", tok_conversion_rate, 0},
|
|
{""}, {""},
|
|
{"first_workday", tok_first_workday, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"decimal_point", tok_decimal_point, 0},
|
|
{""}, {""}, {""},
|
|
{"duo_int_p_sep_by_space", tok_duo_int_p_sep_by_space, 0},
|
|
{""}, {""},
|
|
{"duo_frac_digits", tok_duo_frac_digits, 0},
|
|
{""},
|
|
{"uno_valid_to", tok_uno_valid_to, 0},
|
|
{""}, {""},
|
|
{"default_missing", tok_default_missing, 0},
|
|
{""},
|
|
{"country_post", tok_country_post, 0},
|
|
{"charconv", tok_charconv, 0},
|
|
{"name_miss", tok_name_miss, 0},
|
|
{""}, {""}, {""},
|
|
{"position", tok_position, 0},
|
|
{"from", tok_from, 0},
|
|
{"t_fmt_ampm", tok_t_fmt_ampm, 0},
|
|
{"noexpr", tok_noexpr, 0},
|
|
{""}, {""}, {""},
|
|
{"coll_weight_max", tok_coll_weight_max, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{"n_sep_by_space", tok_n_sep_by_space, 0},
|
|
{"abmon", tok_abmon, 0},
|
|
{""},
|
|
{"duo_n_cs_precedes", tok_duo_n_cs_precedes, 0},
|
|
{"duo_n_sep_by_space", tok_duo_n_sep_by_space, 0},
|
|
{""},
|
|
{"postal_fmt", tok_postal_fmt, 0},
|
|
{"frac_digits", tok_frac_digits, 0},
|
|
{"include", tok_include, 0},
|
|
{""}, {""}, {""},
|
|
{"duo_int_p_cs_precedes", tok_duo_int_p_cs_precedes, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""},
|
|
{"positive_sign", tok_positive_sign, 0},
|
|
{"section-symbol", tok_section_symbol, 0},
|
|
{""}, {""}, {""},
|
|
{"name_gen", tok_name_gen, 0},
|
|
{"duo_currency_symbol", tok_duo_currency_symbol, 0},
|
|
{""}, {""},
|
|
{"duo_int_n_sep_by_space", tok_duo_int_n_sep_by_space, 0},
|
|
{"negative_sign", tok_negative_sign, 0},
|
|
{""},
|
|
{"duo_p_sign_posn", tok_duo_p_sign_posn, 0},
|
|
{"country_car", tok_country_car, 0},
|
|
{"comment_char", tok_comment_char, 0},
|
|
{"p_cs_precedes", tok_p_cs_precedes, 0},
|
|
{""}, {""}, {""},
|
|
{"country_name", tok_country_name, 0},
|
|
{""},
|
|
{"duo_int_frac_digits", tok_duo_int_frac_digits, 0},
|
|
{"class", tok_class, 0},
|
|
{"collating-symbol", tok_collating_symbol, 0},
|
|
{""}, {""}, {""},
|
|
{"currency_symbol", tok_currency_symbol, 0},
|
|
{"p_sign_posn", tok_p_sign_posn, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""},
|
|
{"mon_thousands_sep", tok_mon_thousands_sep, 0},
|
|
{"mon", tok_mon, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""},
|
|
{"endif", tok_endif, 0},
|
|
{""},
|
|
{"mon_grouping", tok_mon_grouping, 0},
|
|
{""},
|
|
{"charclass", tok_charclass, 0},
|
|
{""},
|
|
{"duo_int_n_cs_precedes", tok_duo_int_n_cs_precedes, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{"uno_valid_from", tok_uno_valid_from, 0},
|
|
{""}, {""}, {""}, {""}, {""},
|
|
{"email", tok_email, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"duo_n_sign_posn", tok_duo_n_sign_posn, 0},
|
|
{""}, {""},
|
|
{"n_cs_precedes", tok_n_cs_precedes, 0},
|
|
{""}, {""}, {""},
|
|
{"mon_decimal_point", tok_mon_decimal_point, 0},
|
|
{""},
|
|
{"duo_int_p_sign_posn", tok_duo_int_p_sign_posn, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""},
|
|
{"n_sign_posn", tok_n_sign_posn, 0},
|
|
{""}, {""}, {""}, {""}, {""},
|
|
{"int_p_cs_precedes", tok_int_p_cs_precedes, 0},
|
|
{"int_p_sep_by_space", tok_int_p_sep_by_space, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"cal_direction", tok_cal_direction, 0},
|
|
{"duo_int_curr_symbol", tok_duo_int_curr_symbol, 0},
|
|
{"undef", tok_undef, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"int_select", tok_int_select, 0},
|
|
{"application", tok_application, 0},
|
|
{""}, {""}, {""},
|
|
{"ifdef", tok_ifdef, 0},
|
|
{""},
|
|
{"country_isbn", tok_country_isbn, 0},
|
|
{""}, {""},
|
|
{"alnum", tok_alnum, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"int_frac_digits", tok_int_frac_digits, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{"int_prefix", tok_int_prefix, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{"duo_int_n_sign_posn", tok_duo_int_n_sign_posn, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{"lang_term", tok_lang_term, 0},
|
|
{""}, {""},
|
|
{"int_n_cs_precedes", tok_int_n_cs_precedes, 0},
|
|
{"int_n_sep_by_space", tok_int_n_sep_by_space, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""},
|
|
{"am_pm", tok_am_pm, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"cntrl", tok_cntrl, 0},
|
|
{"country_num", tok_country_num, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{"int_p_sign_posn", tok_int_p_sign_posn, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""},
|
|
{"int_curr_symbol", tok_int_curr_symbol, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""}, {""},
|
|
{"int_n_sign_posn", tok_int_n_sign_posn, 0}
|
|
};
|
|
|
|
if (len <= MAX_WORD_LENGTH && len >= MIN_WORD_LENGTH)
|
|
{
|
|
register int key = hash (str, len);
|
|
|
|
if (key <= MAX_HASH_VALUE && key >= 0)
|
|
{
|
|
register const char *s = wordlist[key].name;
|
|
|
|
if (*str == *s && !strncmp (str + 1, s + 1, len - 1))
|
|
return &wordlist[key];
|
|
}
|
|
}
|
|
return 0;
|
|
}
|