Logo Search packages:      
Sourcecode: glibc version File versions

locfile-kw.h

/* ANSI-C code produced by gperf version 2.7.2 */
/* Command-line: gperf -acCgopt -k'1,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 Lesser General Public
   License as published by the Free Software Foundation; either
   version 2.1 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
   Lesser General Public License for more details.

   You should have received a copy of the GNU Lesser General Public
   License along with the GNU C Library; 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 175
#define MIN_WORD_LENGTH 3
#define MAX_WORD_LENGTH 22
#define MIN_HASH_VALUE 3
#define MAX_HASH_VALUE 687
/* maximum key range = 685, duplicates = 0 */

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

Generated by  Doxygen 1.6.0   Back to index