1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196
|
/* C code produced by gperf version 3.0.1 */
/* Command-line: gperf --language=C --struct-type --slot-name=name --hash-fn-name=asm_hash --lookup-fn-name=asm_lookup */
/* Computed positions: -k'3,5' */
#if !((' ' == 32) && ('!' == 33) && ('"' == 34) && ('#' == 35) \
&& ('%' == 37) && ('&' == 38) && ('\'' == 39) && ('(' == 40) \
&& (')' == 41) && ('*' == 42) && ('+' == 43) && (',' == 44) \
&& ('-' == 45) && ('.' == 46) && ('/' == 47) && ('0' == 48) \
&& ('1' == 49) && ('2' == 50) && ('3' == 51) && ('4' == 52) \
&& ('5' == 53) && ('6' == 54) && ('7' == 55) && ('8' == 56) \
&& ('9' == 57) && (':' == 58) && (';' == 59) && ('<' == 60) \
&& ('=' == 61) && ('>' == 62) && ('?' == 63) && ('A' == 65) \
&& ('B' == 66) && ('C' == 67) && ('D' == 68) && ('E' == 69) \
&& ('F' == 70) && ('G' == 71) && ('H' == 72) && ('I' == 73) \
&& ('J' == 74) && ('K' == 75) && ('L' == 76) && ('M' == 77) \
&& ('N' == 78) && ('O' == 79) && ('P' == 80) && ('Q' == 81) \
&& ('R' == 82) && ('S' == 83) && ('T' == 84) && ('U' == 85) \
&& ('V' == 86) && ('W' == 87) && ('X' == 88) && ('Y' == 89) \
&& ('Z' == 90) && ('[' == 91) && ('\\' == 92) && (']' == 93) \
&& ('^' == 94) && ('_' == 95) && ('a' == 97) && ('b' == 98) \
&& ('c' == 99) && ('d' == 100) && ('e' == 101) && ('f' == 102) \
&& ('g' == 103) && ('h' == 104) && ('i' == 105) && ('j' == 106) \
&& ('k' == 107) && ('l' == 108) && ('m' == 109) && ('n' == 110) \
&& ('o' == 111) && ('p' == 112) && ('q' == 113) && ('r' == 114) \
&& ('s' == 115) && ('t' == 116) && ('u' == 117) && ('v' == 118) \
&& ('w' == 119) && ('x' == 120) && ('y' == 121) && ('z' == 122) \
&& ('{' == 123) && ('|' == 124) && ('}' == 125) && ('~' == 126))
/* The character set is not based on ISO-646. */
error "gperf generated tables don't work with this execution character set. Please report a bug to <bug-gnu-gperf@gnu.org>."
#endif
#include "strmake.h"
#define START_VARIABLE 1001
#define START_WORD 2001
#define START_SHARP 3001
#define START_YACC 4001
#define IS_RESERVED_WORD(a) ((a) >= START_WORD)
#define IS_RESERVED_VARIABLE(a) ((a) >= START_VARIABLE && (a) < START_WORD)
#define IS_RESERVED_SHARP(a) ((a) >= START_SHARP && (a) < START_YACC)
#define IS_RESERVED_YACC(a) ((a) >= START_YACC)
#define SHARP_SHARP 3001
#define SHARP_ASSERT 3002
#define SHARP_DEFINE 3003
#define SHARP_ELIF 3004
#define SHARP_ELSE 3005
#define SHARP_ENDIF 3006
#define SHARP_ERROR 3007
#define SHARP_IDENT 3008
#define SHARP_IF 3009
#define SHARP_IFDEF 3010
#define SHARP_IFNDEF 3011
#define SHARP_IMPORT 3012
#define SHARP_INCLUDE 3013
#define SHARP_INCLUDE_NEXT 3014
#define SHARP_LINE 3015
#define SHARP_PRAGMA 3016
#define SHARP_SCCS 3017
#define SHARP_UNASSERT 3018
#define SHARP_UNDEF 3019
#define SHARP_WARNING 3020
struct keyword { char *name; int token; };
#define TOTAL_KEYWORDS 20
#define MIN_WORD_LENGTH 2
#define MAX_WORD_LENGTH 13
#define MIN_HASH_VALUE 2
#define MAX_HASH_VALUE 32
/* maximum key range = 31, duplicates = 0 */
#ifdef __GNUC__
__inline
#else
#ifdef __cplusplus
inline
#endif
#endif
static unsigned int
asm_hash (str, len)
register const char *str;
register unsigned int len;
{
static unsigned char asso_values[] =
{
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 15, 33, 10,
10, 0, 15, 5, 33, 5, 33, 33, 0, 0,
0, 10, 33, 33, 10, 0, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
33, 33, 33, 33, 33, 33
};
register int hval = len;
switch (hval)
{
default:
hval += asso_values[(unsigned char)str[4]];
/*FALLTHROUGH*/
case 4:
case 3:
hval += asso_values[(unsigned char)str[2]];
/*FALLTHROUGH*/
case 2:
break;
}
return hval;
}
#ifdef __GNUC__
__inline
#endif
struct keyword *
asm_lookup (str, len)
register const char *str;
register unsigned int len;
{
static struct keyword wordlist[] =
{
{""}, {""},
{"##", SHARP_SHARP},
{""}, {""},
{"#else", SHARP_ELSE},
{"#undef", SHARP_UNDEF},
{"#assert", SHARP_ASSERT},
{"#include", SHARP_INCLUDE},
{"#unassert", SHARP_UNASSERT},
{"#line", SHARP_LINE},
{"#endif", SHARP_ENDIF},
{"#define", SHARP_DEFINE},
{"#include_next", SHARP_INCLUDE_NEXT},
{""},
{"#sccs", SHARP_SCCS},
{"#ident", SHARP_IDENT},
{"#import", SHARP_IMPORT},
{"#if", SHARP_IF},
{""},
{"#elif", SHARP_ELIF},
{"#ifdef", SHARP_IFDEF},
{"#pragma", SHARP_PRAGMA},
{"#warning", SHARP_WARNING},
{""}, {""},
{"#error", SHARP_ERROR},
{""}, {""}, {""}, {""}, {""},
{"#ifndef", SHARP_IFNDEF}
};
if (len <= MAX_WORD_LENGTH && len >= MIN_WORD_LENGTH)
{
register int key = asm_hash (str, len);
if (key <= MAX_HASH_VALUE && key >= 0)
{
register const char *s = wordlist[key].name;
if (*str == *s && !strcmp (str + 1, s + 1))
return &wordlist[key];
}
}
return 0;
}
int asm_reserved_sharp(const char *, int);
int
asm_reserved_sharp(str, len)
const char *str;
int len;
{
struct keyword *keyword;
/* Delete blanks. Ex. ' # define ' => '#define' */
str = strtrim(str, TRIM_ALL, &len);
keyword = asm_lookup(str, len);
return (keyword && IS_RESERVED_SHARP(keyword->token)) ? keyword->token : 0;
}
|