mirror of
https://sourceware.org/git/glibc.git
synced 2024-11-24 10:22:41 +08:00
a673fbcb1f
2000-01-01 Ulrich Drepper <drepper@cygnus.com> * locale/programs/ld-ctype.c: Implement rest of transliteration definition parsing. * locale/programs/locfile-kw.gperf: New keyword translit_ignore. * locale/programs/locfile-token.h: Add tok_translit_ignore.
416 lines
18 KiB
C
416 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 173
|
|
#define MIN_WORD_LENGTH 3
|
|
#define MAX_WORD_LENGTH 22
|
|
#define MIN_HASH_VALUE 3
|
|
#define MAX_HASH_VALUE 645
|
|
/* maximum key range = 643, duplicates = 0 */
|
|
|
|
#ifdef __GNUC__
|
|
__inline
|
|
#endif
|
|
static unsigned int
|
|
hash (register const char *str, register unsigned int len)
|
|
{
|
|
static const unsigned short asso_values[] =
|
|
{
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
10, 0, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 15, 646, 0, 0, 0,
|
|
10, 20, 0, 0, 646, 646, 0, 646, 0, 5,
|
|
646, 646, 10, 0, 10, 5, 646, 646, 646, 20,
|
|
646, 646, 646, 646, 646, 30, 646, 0, 25, 110,
|
|
5, 0, 25, 0, 5, 105, 646, 20, 125, 85,
|
|
175, 0, 75, 10, 5, 125, 0, 135, 45, 15,
|
|
10, 75, 0, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646, 646, 646, 646, 646,
|
|
646, 646, 646, 646, 646, 646
|
|
};
|
|
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},
|
|
{""},
|
|
{"era_t_fmt", tok_era_t_fmt, 0},
|
|
{"LC_NUMERIC", tok_lc_numeric, 0},
|
|
{"height", tok_height, 0},
|
|
{"LC_IDENTIFICATION", tok_lc_identification, 0},
|
|
{"LC_CTYPE", tok_lc_ctype, 0},
|
|
{"era_d_fmt", tok_era_d_fmt, 0},
|
|
{"graph", tok_graph, 0},
|
|
{"order_start", tok_order_start, 0},
|
|
{"LC_NAME", tok_lc_name, 0},
|
|
{""},
|
|
{"UNDEFINED", tok_undefined, 0},
|
|
{"LC_COLLATE", tok_lc_collate, 0},
|
|
{"reorder-end", tok_reorder_end, 0},
|
|
{"tolower", tok_tolower, 0},
|
|
{"reorder-after", tok_reorder_after, 0},
|
|
{"order_end", tok_order_end, 0},
|
|
{""},
|
|
{"LC_MESSAGES", tok_lc_messages, 0},
|
|
{""},
|
|
{"LC_PAPER", tok_lc_paper, 0},
|
|
{"LC_MEASUREMENT", tok_lc_measurement, 0},
|
|
{"t_fmt", tok_t_fmt, 0},
|
|
{"IGNORE", tok_ignore, 0},
|
|
{"forward", tok_forward, 0},
|
|
{"fax", tok_fax, 0},
|
|
{"week", tok_week, 0},
|
|
{"d_fmt", tok_d_fmt, 0},
|
|
{"tel_dom_fmt", tok_tel_dom_fmt, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"era_d_t_fmt", tok_era_d_t_fmt, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"LC_MONETARY", tok_lc_monetary, 0},
|
|
{""},
|
|
{"backward", tok_backward, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""}, {""}, {""},
|
|
{"d_t_fmt", tok_d_t_fmt, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""}, {""}, {""}, {""}, {""},
|
|
{"day", tok_day, 0},
|
|
{""},
|
|
{"print", tok_print, 0},
|
|
{"yesstr", tok_yesstr, 0},
|
|
{"toupper", tok_toupper, 0},
|
|
{"grouping", tok_grouping, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"era_year", tok_era_year, 0},
|
|
{""}, {""}, {""},
|
|
{"yesexpr", tok_yesexpr, 0},
|
|
{""}, {""}, {""}, {""}, {""},
|
|
{"repertoiremap", tok_repertoiremap, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""},
|
|
{"title", tok_title, 0},
|
|
{""}, {""},
|
|
{"timezone", tok_timezone, 0},
|
|
{""},
|
|
{"digit", tok_digit, 0},
|
|
{""},
|
|
{"contact", tok_contact, 0},
|
|
{""},
|
|
{"from", tok_from, 0},
|
|
{""},
|
|
{"country_ab3", tok_country_ab3, 0},
|
|
{""}, {""}, {""},
|
|
{"conversion_rate", tok_conversion_rate, 0},
|
|
{"xdigit", tok_xdigit, 0},
|
|
{"collating-element", tok_collating_element, 0},
|
|
{"tel", tok_tel, 0},
|
|
{"else", tok_else, 0},
|
|
{"alpha", tok_alpha, 0},
|
|
{"country_ab2", tok_country_ab2, 0},
|
|
{""}, {""}, {""},
|
|
{"width", tok_width, 0},
|
|
{""},
|
|
{"address", tok_address, 0},
|
|
{""}, {""},
|
|
{"lower", tok_lower, 0},
|
|
{"tel_int_fmt", tok_tel_int_fmt, 0},
|
|
{""},
|
|
{"audience", tok_audience, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""},
|
|
{"elif", tok_elif, 0},
|
|
{""}, {""}, {""}, {""}, {""},
|
|
{"reorder-sections-end", tok_reorder_sections_end, 0},
|
|
{""},
|
|
{"reorder-sections-after", tok_reorder_sections_after, 0},
|
|
{"map", tok_map, 0},
|
|
{"lang_name", tok_lang_name, 0},
|
|
{"coll_weight_max", tok_coll_weight_max, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"postal_fmt", tok_postal_fmt, 0},
|
|
{""},
|
|
{"mon_grouping", tok_mon_grouping, 0},
|
|
{""},
|
|
{"translit_start", tok_translit_start, 0},
|
|
{"translit_ignore", tok_translit_ignore, 0},
|
|
{""},
|
|
{"translit_end", tok_translit_end, 0},
|
|
{"decimal_point", tok_decimal_point, 0},
|
|
{""},
|
|
{"abday", tok_abday, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"ifdef", tok_ifdef, 0},
|
|
{"define", tok_define, 0},
|
|
{"lang_ab", tok_lang_ab, 0},
|
|
{"lang_lib", tok_lang_lib, 0},
|
|
{"copy", tok_copy, 0},
|
|
{"nostr", tok_nostr, 0},
|
|
{""},
|
|
{"mon_decimal_point", tok_mon_decimal_point, 0},
|
|
{"category", tok_category, 0},
|
|
{""},
|
|
{"blank", tok_blank, 0},
|
|
{""},
|
|
{"country_post", tok_country_post, 0},
|
|
{""}, {""},
|
|
{"t_fmt_ampm", tok_t_fmt_ampm, 0},
|
|
{""},
|
|
{"duo_valid_to", tok_duo_valid_to, 0},
|
|
{""}, {""},
|
|
{"space", tok_space, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""},
|
|
{"abbreviation", tok_abbreviation, 0},
|
|
{"name_fmt", tok_name_fmt, 0},
|
|
{""},
|
|
{"punct", tok_punct, 0},
|
|
{""},
|
|
{"name_mr", tok_name_mr, 0},
|
|
{"first_weekday", tok_first_weekday, 0},
|
|
{""}, {""},
|
|
{"escape_char", tok_escape_char, 0},
|
|
{""},
|
|
{"first_workday", tok_first_workday, 0},
|
|
{"p_sep_by_space", tok_p_sep_by_space, 0},
|
|
{"upper", tok_upper, 0},
|
|
{""}, {""},
|
|
{"symbol-equivalence", tok_symbol_equivalence, 0},
|
|
{""},
|
|
{"endif", tok_endif, 0},
|
|
{"measurement", tok_measurement, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"country_car", tok_country_car, 0},
|
|
{"comment_char", tok_comment_char, 0},
|
|
{""}, {""},
|
|
{"default_missing", tok_default_missing, 0},
|
|
{"source", tok_source, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""},
|
|
{"outdigit", tok_outdigit, 0},
|
|
{""}, {""},
|
|
{"collating-symbol", tok_collating_symbol, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""},
|
|
{"position", tok_position, 0},
|
|
{""},
|
|
{"am_pm", tok_am_pm, 0},
|
|
{"noexpr", tok_noexpr, 0},
|
|
{""},
|
|
{"mon", tok_mon, 0},
|
|
{"territory", tok_territory, 0},
|
|
{"alt_digits", tok_alt_digits, 0},
|
|
{""}, {""},
|
|
{"language", tok_language, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{"charconv", tok_charconv, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""},
|
|
{"duo_valid_from", tok_duo_valid_from, 0},
|
|
{""},
|
|
{"p_sign_posn", tok_p_sign_posn, 0},
|
|
{""},
|
|
{"positive_sign", tok_positive_sign, 0},
|
|
{""}, {""}, {""},
|
|
{"country_name", tok_country_name, 0},
|
|
{""}, {""},
|
|
{"alnum", tok_alnum, 0},
|
|
{"frac_digits", tok_frac_digits, 0},
|
|
{"mon_thousands_sep", tok_mon_thousands_sep, 0},
|
|
{""}, {""}, {""}, {""}, {""},
|
|
{"duo_p_sep_by_space", tok_duo_p_sep_by_space, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"revision", tok_revision, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""},
|
|
{"n_sep_by_space", tok_n_sep_by_space, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{"lang_term", tok_lang_term, 0},
|
|
{"duo_frac_digits", tok_duo_frac_digits, 0},
|
|
{""},
|
|
{"name_ms", tok_name_ms, 0},
|
|
{"name_mrs", tok_name_mrs, 0},
|
|
{""},
|
|
{"email", tok_email, 0},
|
|
{""},
|
|
{"duo_int_p_sep_by_space", tok_duo_int_p_sep_by_space, 0},
|
|
{"thousands_sep", tok_thousands_sep, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""}, {""},
|
|
{"undef", tok_undef, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""},
|
|
{"uno_valid_to", tok_uno_valid_to, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{"abmon", tok_abmon, 0},
|
|
{"country_num", tok_country_num, 0},
|
|
{""},
|
|
{"p_cs_precedes", tok_p_cs_precedes, 0},
|
|
{""}, {""}, {""},
|
|
{"duo_p_cs_precedes", tok_duo_p_cs_precedes, 0},
|
|
{"name_gen", tok_name_gen, 0},
|
|
{""}, {""},
|
|
{"n_sign_posn", tok_n_sign_posn, 0},
|
|
{""},
|
|
{"negative_sign", tok_negative_sign, 0},
|
|
{"duo_currency_symbol", tok_duo_currency_symbol, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{"country_isbn", tok_country_isbn, 0},
|
|
{""}, {""},
|
|
{"duo_p_sign_posn", tok_duo_p_sign_posn, 0},
|
|
{""}, {""},
|
|
{"duo_n_sep_by_space", tok_duo_n_sep_by_space, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"cal_direction", tok_cal_direction, 0},
|
|
{"duo_int_frac_digits", tok_duo_int_frac_digits, 0},
|
|
{"currency_symbol", tok_currency_symbol, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""},
|
|
{"include", tok_include, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""},
|
|
{"duo_int_n_sep_by_space", tok_duo_int_n_sep_by_space, 0},
|
|
{""}, {""}, {""}, {""}, {""},
|
|
{"int_p_sep_by_space", tok_int_p_sep_by_space, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""},
|
|
{"uno_valid_from", tok_uno_valid_from, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"name_miss", tok_name_miss, 0},
|
|
{""},
|
|
{"duo_int_p_cs_precedes", tok_duo_int_p_cs_precedes, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"application", tok_application, 0},
|
|
{""}, {""}, {""},
|
|
{"int_frac_digits", tok_int_frac_digits, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"int_prefix", tok_int_prefix, 0},
|
|
{""}, {""},
|
|
{"n_cs_precedes", tok_n_cs_precedes, 0},
|
|
{"charclass", tok_charclass, 0},
|
|
{""}, {""},
|
|
{"duo_n_cs_precedes", tok_duo_n_cs_precedes, 0},
|
|
{""}, {""},
|
|
{"class", tok_class, 0},
|
|
{""}, {""}, {""},
|
|
{"section-symbol", tok_section_symbol, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"duo_int_curr_symbol", tok_duo_int_curr_symbol, 0},
|
|
{""}, {""}, {""}, {""}, {""},
|
|
{"duo_n_sign_posn", tok_duo_n_sign_posn, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{"duo_int_p_sign_posn", tok_duo_int_p_sign_posn, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""},
|
|
{"int_select", tok_int_select, 0},
|
|
{""},
|
|
{"int_p_cs_precedes", tok_int_p_cs_precedes, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""}, {""},
|
|
{"cntrl", tok_cntrl, 0},
|
|
{""}, {""}, {""}, {""},
|
|
{"int_p_sign_posn", tok_int_p_sign_posn, 0},
|
|
{""}, {""},
|
|
{"int_n_sep_by_space", tok_int_n_sep_by_space, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""},
|
|
{"int_curr_symbol", tok_int_curr_symbol, 0},
|
|
{""}, {""}, {""}, {""}, {""},
|
|
{"duo_int_n_cs_precedes", tok_duo_int_n_cs_precedes, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""},
|
|
{"duo_int_n_sign_posn", tok_duo_int_n_sign_posn, 0},
|
|
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
|
|
{""}, {""}, {""},
|
|
{"int_n_cs_precedes", tok_int_n_cs_precedes, 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;
|
|
}
|