/* C code produced by gperf version 2.5 (GNU C++ version) */ /* Command-line: gperf -acCgopt -k1,2,5,$ -N locfile_hash programs/locfile-kw.gperf */ /* Copyright (C) 1996 Free Software Foundation, Inc. This file is part of the GNU C Library. Contributed by Ulrich Drepper, . 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 #include "locfile-token.h" struct keyword_t ; #define TOTAL_KEYWORDS 73 #define MIN_WORD_LENGTH 3 #define MAX_WORD_LENGTH 17 #define MIN_HASH_VALUE 3 #define MAX_HASH_VALUE 185 /* maximum key range = 183, duplicates = 0 */ #ifdef __GNUC__ inline #endif static unsigned int hash (register const char *str, register int len) { static const unsigned char asso_values[] = { 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 186, 0, 0, 0, 0, 0, 186, 0, 186, 186, 0, 186, 0, 35, 186, 186, 0, 0, 0, 5, 186, 186, 186, 0, 186, 186, 186, 186, 186, 15, 186, 0, 0, 5, 15, 10, 55, 30, 15, 75, 186, 20, 5, 40, 10, 0, 0, 186, 35, 30, 0, 70, 186, 10, 20, 75, 186, 186, 186, 186, 186, 186, }; register int hval = len; switch (hval) { default: case 5: hval += asso_values[(int) str[4]]; case 4: case 3: case 2: hval += asso_values[(int) str[1]]; case 1: hval += asso_values[(int) str[0]]; break; } return hval + asso_values[(int) str[len - 1]]; } #ifdef __GNUC__ inline #endif const struct keyword_t * locfile_hash (register const char *str, register int len) { static const struct keyword_t wordlist[] = { {"",}, {"",}, {"",}, {"END", tok_end, 0}, {"",}, {"",}, {"IGNORE", tok_ignore, 0}, {"LC_TIME", tok_lc_time, 0}, {"LC_CTYPE", tok_lc_ctype, 0}, {"",}, {"alpha", tok_alpha, 0}, {"LC_MESSAGES", tok_lc_messages, 0}, {"",}, {"",}, {"UNDEFINED", tok_undefined, 0}, {"LC_NUMERIC", tok_lc_numeric, 0}, {"",}, {"",}, {"position", tok_position, 0}, {"",}, {"t_fmt", tok_t_fmt, 0}, {"",}, {"collating-element", tok_collating_element, 0}, {"positive_sign", tok_positive_sign, 0}, {"",}, {"abmon", tok_abmon, 0}, {"collating-symbol", tok_collating_symbol, 0}, {"",}, {"",}, {"",}, {"cntrl", tok_cntrl, 0}, {"",}, {"",}, {"backward", tok_backward, 0}, {"",}, {"d_fmt", tok_d_fmt, 0}, {"",}, {"",}, {"",}, {"p_sep_by_space", tok_p_sep_by_space, 0}, {"print", tok_print, 0}, {"",}, {"toupper", tok_toupper, 0}, {"negative_sign", tok_negative_sign, 0}, {"",}, {"LC_COLLATE", tok_lc_collate, 0}, {"LC_MONETARY", tok_lc_monetary, 0}, {"",}, {"era", tok_era, 0}, {"n_sep_by_space", tok_n_sep_by_space, 0}, {"blank", tok_blank, 0}, {"noexpr", tok_noexpr, 0}, {"tolower", tok_tolower, 0}, {"mon", tok_mon, 0}, {"era_t_fmt", tok_era_t_fmt, 0}, {"space", tok_space, 0}, {"",}, {"mon_thousands_sep", tok_mon_thousands_sep, 0}, {"thousands_sep", tok_thousands_sep, 0}, {"",}, {"alt_digits", tok_alt_digits, 0}, {"",}, {"comment_char", tok_comment_char, 0}, {"",}, {"charclass", tok_charclass, 0}, {"t_fmt_ampm", tok_t_fmt_ampm, 0}, {"p_sign_posn", tok_p_sign_posn, 0}, {"charmap", tok_charmap, 0}, {"",}, {"era_d_fmt", tok_era_d_fmt, 0}, {"",}, {"era_d_t_fmt", tok_era_d_t_fmt, 0}, {"mon_decimal_point", tok_mon_decimal_point, 0}, {"p_cs_precedes", tok_p_cs_precedes, 0}, {"",}, {"punct", tok_punct, 0}, {"n_sign_posn", tok_n_sign_posn, 0}, {"forward", tok_forward, 0}, {"decimal_point", tok_decimal_point, 0}, {"",}, {"lower", tok_lower, 0}, {"order_start", tok_order_start, 0}, {"",}, {"n_cs_precedes", tok_n_cs_precedes, 0}, {"copy", tok_copy, 0}, {"nostr", tok_nostr, 0}, {"escape_char", tok_escape_char, 0}, {"",}, {"",}, {"",}, {"alnum", tok_alnum, 0}, {"",}, {"d_t_fmt", tok_d_t_fmt, 0}, {"day", tok_day, 0}, {"order_end", tok_order_end, 0}, {"digit", tok_digit, 0}, {"",}, {"",}, {"",}, {"",}, {"graph", tok_graph, 0}, {"",}, {"",}, {"grouping", tok_grouping, 0}, {"",}, {"currency_symbol", tok_currency_symbol, 0}, {"",}, {"",}, {"",}, {"",}, {"int_curr_symbol", tok_int_curr_symbol, 0}, {"",}, {"mon_grouping", tok_mon_grouping, 0}, {"",}, {"",}, {"",}, {"xdigit", tok_xdigit, 0}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"am_pm", tok_am_pm, 0}, {"yesstr", tok_yesstr, 0}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"from", tok_from, 0}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"upper", tok_upper, 0}, {"frac_digits", tok_frac_digits, 0}, {"yesexpr", tok_yesexpr, 0}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"abday", tok_abday, 0}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"era_year", tok_era_year, 0}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"int_frac_digits", tok_int_frac_digits, 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 (*s == *str && !strncmp (str + 1, s + 1, len - 1)) return &wordlist[key]; } } return 0; }