mirror of
https://sourceware.org/git/glibc.git
synced 2024-11-27 15:30:07 +00:00
2b83a2a4d9
Merged 1003.2 locale and localedef programs by Ulrich Drepper. * locale/charmap.c: New file. * locale/collate.c: New file. * locale/config.h: New file. * locale/ctype.c: New file. * locale/ctypedump.c: New file. * locale/hash.c: New file. * locale/hash.h: New file. * locale/iso-4217.def: New file. * locale/keyword.gperf: New file. * locale/keyword.h: New file. * locale/libintl.h: New file. * locale/locale.c: New file. * locale/localedef.c: New file. * locale/localedef.h: New file. * locale/locfile-lex.c: New file. * locale/locfile-parse.c: New file. * locale/messages.c: New file. * locale/monetary.c: New file. * locale/numeric.c: New file. * locale/token.h: New file. * posix/regex.c, posix/regex.h: New files, incorporated from GNU regex. * posix/Makefile (headers): Add regex.h. (routines): Add regex. (gpl2lgpl): Add regex.c and regex.h. Tue May 16 17:35:07 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu> * locale/loadlocale.c: Expect macro LOCALE_PATH to be defined, instead of hard-coding "/share/locale".
181 lines
5.7 KiB
C
181 lines
5.7 KiB
C
/* C code produced by gperf version 2.5 (GNU C++ version) */
|
|
/* Command-line: gperf -acCgopt -k1,2,5, keyword.gperf */
|
|
/* `strncmp' is used for comparison. */
|
|
#include <string.h>
|
|
|
|
/* This file defines `enum token'. */
|
|
#include "token.h"
|
|
struct locale_keyword { char *name; enum token token_id; };
|
|
|
|
#define TOTAL_KEYWORDS 68
|
|
#define MIN_WORD_LENGTH 3
|
|
#define MAX_WORD_LENGTH 17
|
|
#define MIN_HASH_VALUE 4
|
|
#define MAX_HASH_VALUE 140
|
|
/* maximum key range = 137, duplicates = 0 */
|
|
|
|
#ifdef __GNUC__
|
|
inline
|
|
#endif
|
|
static unsigned int
|
|
hash (register const char *str, register int len)
|
|
{
|
|
static const unsigned char asso_values[] =
|
|
{
|
|
141, 141, 141, 141, 141, 141, 141, 141, 141, 141,
|
|
141, 141, 141, 141, 141, 141, 141, 141, 141, 141,
|
|
141, 141, 141, 141, 141, 141, 141, 141, 141, 141,
|
|
141, 141, 141, 141, 141, 141, 141, 141, 141, 141,
|
|
141, 141, 141, 141, 141, 141, 141, 141, 141, 141,
|
|
141, 141, 141, 141, 141, 141, 141, 141, 141, 141,
|
|
141, 141, 141, 141, 141, 141, 141, 0, 141, 65,
|
|
5, 0, 141, 30, 141, 141, 0, 141, 0, 95,
|
|
141, 141, 0, 141, 45, 10, 141, 141, 141, 141,
|
|
141, 141, 141, 141, 141, 5, 141, 10, 85, 0,
|
|
20, 0, 40, 35, 30, 10, 141, 0, 30, 15,
|
|
15, 0, 0, 141, 55, 0, 0, 80, 141, 15,
|
|
10, 0, 141, 141, 141, 141, 141, 141,
|
|
};
|
|
register int hval = len;
|
|
|
|
switch (hval)
|
|
{
|
|
default:
|
|
case 5:
|
|
hval += asso_values[str[4]];
|
|
case 4:
|
|
case 3:
|
|
case 2:
|
|
hval += asso_values[str[1]];
|
|
case 1:
|
|
hval += asso_values[str[0]];
|
|
}
|
|
return hval;
|
|
}
|
|
|
|
#ifdef __GNUC__
|
|
inline
|
|
#endif
|
|
const struct locale_keyword *
|
|
in_word_set (register const char *str, register int len)
|
|
{
|
|
static const struct locale_keyword wordlist[] =
|
|
{
|
|
{"",}, {"",}, {"",}, {"",},
|
|
{"copy", TOK_COPY},
|
|
{"space", TOK_SPACE},
|
|
{"yesstr", YESSTR},
|
|
{"toupper", TOK_TOUPPER},
|
|
{"position", TOK_POSITION},
|
|
{"",},
|
|
{"t_fmt", T_FMT},
|
|
{"escape_char", TOK_ESCAPE_CHAR},
|
|
{"comment_char", TOK_COMMENT_CHAR},
|
|
{"positive_sign", POSITIVE_SIGN},
|
|
{"",},
|
|
{"t_fmt_ampm", T_FMT_AMPM},
|
|
{"",},
|
|
{"yesexpr", YESEXPR},
|
|
{"mon", MON_1},
|
|
{"p_sep_by_space", P_SEP_BY_SPACE},
|
|
{"LC_NUMERIC", _NL_NUM_LC_NUMERIC},
|
|
{"noexpr", NOEXPR},
|
|
{"tolower", TOK_TOLOWER},
|
|
{"p_cs_precedes", P_CS_PRECEDES},
|
|
{"UNDEFINED", TOK_UNDEFINED},
|
|
{"",},
|
|
{"collating_symbol", TOK_COLLATING_SYMBOL},
|
|
{"collating_element", TOK_COLLATING_ELEMENT},
|
|
{"negative_sign", NEGATIVE_SIGN},
|
|
{"",},
|
|
{"d_fmt", D_FMT},
|
|
{"",},
|
|
{"mon_thousands_sep", MON_THOUSANDS_SEP},
|
|
{"day", DAY_1},
|
|
{"n_sep_by_space", N_SEP_BY_SPACE},
|
|
{"digit", TOK_DIGIT},
|
|
{"IGNORE", TOK_IGNORE},
|
|
{"LC_TIME", _NL_NUM_LC_TIME},
|
|
{"n_cs_precedes", N_CS_PRECEDES},
|
|
{"",},
|
|
{"int_curr_symbol", INT_CURR_SYMBOL},
|
|
{"",}, {"",},
|
|
{"thousands_sep", THOUSANDS_SEP},
|
|
{"",},
|
|
{"am_pm", AM_STR},
|
|
{"xdigit", TOK_XDIGIT},
|
|
{"",},
|
|
{"decimal_point", DECIMAL_POINT},
|
|
{"",},
|
|
{"cntrl", TOK_CNTRL},
|
|
{"p_sign_posn", P_SIGN_POSN},
|
|
{"mon_decimal_point", MON_DECIMAL_POINT},
|
|
{"LC_CTYPE", _NL_NUM_LC_CTYPE},
|
|
{"",},
|
|
{"alpha", TOK_ALPHA},
|
|
{"",},
|
|
{"forward", TOK_FORWARD},
|
|
{"era", ERA},
|
|
{"",},
|
|
{"print", TOK_PRINT},
|
|
{"",},
|
|
{"mon_grouping", MON_GROUPING},
|
|
{"era_year", ERA_YEAR},
|
|
{"",}, {"",},
|
|
{"n_sign_posn", N_SIGN_POSN},
|
|
{"",},
|
|
{"END", TOK_END},
|
|
{"",},
|
|
{"alt_digits", ALT_DIGITS},
|
|
{"",},
|
|
{"d_t_fmt", D_T_FMT},
|
|
{"",}, {"",},
|
|
{"nostr", NOSTR},
|
|
{"LC_MESSAGES", _NL_NUM_LC_MESSAGES},
|
|
{"",}, {"",}, {"",},
|
|
{"int_frac_digits", INT_FRAC_DIGITS},
|
|
{"",}, {"",}, {"",},
|
|
{"era_d_fmt", ERA_D_FMT},
|
|
{"punct", TOK_PUNCT},
|
|
{"",}, {"",}, {"",}, {"",},
|
|
{"lower", TOK_LOWER},
|
|
{"",}, {"",}, {"",}, {"",},
|
|
{"currency_symbol", CURRENCY_SYMBOL},
|
|
{"",}, {"",},
|
|
{"grouping", GROUPING},
|
|
{"from", TOK_FROM},
|
|
{"abday", ABDAY_1},
|
|
{"",}, {"",}, {"",}, {"",},
|
|
{"LC_COLLATE", _NL_NUM_LC_COLLATE},
|
|
{"LC_MONETARY", _NL_NUM_LC_MONETARY},
|
|
{"",}, {"",}, {"",}, {"",},
|
|
{"frac_digits", FRAC_DIGITS},
|
|
{"",}, {"",}, {"",},
|
|
{"abmon", ABMON_1},
|
|
{"",}, {"",},
|
|
{"backward", TOK_BACKWARD},
|
|
{"order_end", TOK_ORDER_END},
|
|
{"blank", TOK_BLANK},
|
|
{"order_start", TOK_ORDER_START},
|
|
{"",}, {"",}, {"",},
|
|
{"graph", TOK_GRAPH},
|
|
{"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",},
|
|
{"",}, {"",}, {"",}, {"",}, {"",},
|
|
{"upper", TOK_UPPER},
|
|
};
|
|
|
|
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;
|
|
}
|