glibc/locale/programs/locfile-kw.h

410 lines
18 KiB
C

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