24fcef56cc032c6895439e00f58f9bc4aef98e9d
[gcc.git] / gcc / java / keyword.h
1 /* C code produced by gperf version 2.7 */
2 /* Command-line: gperf -L C -C -F , 0 -p -t -j1 -i 1 -g -o -N java_keyword -k1,4,$ keyword.gperf */
3 /* Keyword definition for the GNU compiler for the Java(TM) language.
4 Copyright (C) 1997, 1998 Free Software Foundation, Inc.
5 Contributed by Alexandre Petit-Bianco (apbianco@cygnus.com)
6
7 This file is part of GNU CC.
8
9 GNU CC is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2, or (at your option)
12 any later version.
13
14 GNU CC is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
18
19 You should have received a copy of the GNU General Public License
20 along with GNU CC; see the file COPYING. If not, write to
21 the Free Software Foundation, 59 Temple Place - Suite 330,
22 Boston, MA 02111-1307, USA.
23
24 Java and all Java-based marks are trademarks or registered trademarks
25 of Sun Microsystems, Inc. in the United States and other countries.
26 The Free Software Foundation is independent of Sun Microsystems, Inc. */
27
28 struct java_keyword { const char *const name; const int token; };
29 #ifdef __GNUC__
30 __inline
31 #endif
32 static unsigned int hash PARAMS ((const char *, unsigned int));
33 #ifdef __GNUC__
34 __inline
35 #endif
36 const struct java_keyword *java_keyword PARAMS ((const char *, unsigned int));
37
38 #define TOTAL_KEYWORDS 52
39 #define MIN_WORD_LENGTH 2
40 #define MAX_WORD_LENGTH 12
41 #define MIN_HASH_VALUE 7
42 #define MAX_HASH_VALUE 85
43 /* maximum key range = 79, duplicates = 0 */
44
45 #ifdef __GNUC__
46 __inline
47 #endif
48 static unsigned int
49 hash (str, len)
50 register const char *str;
51 register unsigned int len;
52 {
53 static const unsigned char asso_values[] =
54 {
55 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
56 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
57 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
58 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
59 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
60 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
61 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
62 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
63 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
64 86, 86, 86, 86, 86, 86, 86, 1, 34, 3,
65 1, 1, 18, 7, 21, 28, 86, 14, 1, 86,
66 18, 20, 37, 86, 15, 6, 2, 5, 40, 36,
67 86, 36, 86, 86, 86, 86, 86, 86, 86, 86,
68 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
69 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
70 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
71 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
72 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
73 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
74 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
75 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
76 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
77 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
78 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
79 86, 86, 86, 86, 86, 86, 86, 86, 86, 86,
80 86, 86, 86, 86, 86, 86
81 };
82 register int hval = len;
83
84 switch (hval)
85 {
86 default:
87 case 4:
88 hval += asso_values[(unsigned char)str[3]];
89 case 3:
90 case 2:
91 case 1:
92 hval += asso_values[(unsigned char)str[0]];
93 break;
94 }
95 return hval + asso_values[(unsigned char)str[len - 1]];
96 }
97
98 #ifdef __GNUC__
99 __inline
100 #endif
101 const struct java_keyword *
102 java_keyword (str, len)
103 register const char *str;
104 register unsigned int len;
105 {
106 static const struct java_keyword wordlist[] =
107 {
108 {"", 0}, {"", 0}, {"", 0}, {"", 0}, {"", 0}, {"", 0}, {"", 0},
109 {"else", ELSE_TK},
110 {"true", TRUE_TK},
111 {"case", CASE_TK},
112 {"assert", ASSERT_TK},
113 {"default", DEFAULT_TK},
114 {"", 0},
115 {"abstract", ABSTRACT_TK},
116 {"continue", CONTINUE_TK},
117 {"extends", EXTENDS_TK},
118 {"const", CONST_TK},
119 {"static", STATIC_TK},
120 {"this", THIS_TK},
121 {"long", LONG_TK},
122 {"class", CLASS_TK},
123 {"", 0},
124 {"synchronized", SYNCHRONIZED_TK},
125 {"do", DO_TK},
126 {"null", NULL_TK},
127 {"final", FINAL_TK},
128 {"float", FLOAT_TK},
129 {"super", SUPER_TK},
130 {"short", SHORT_TK},
131 {"", 0},
132 {"false", FALSE_TK},
133 {"transient", TRANSIENT_TK},
134 {"catch", CATCH_TK},
135 {"int", INT_TK},
136 {"throws", THROWS_TK},
137 {"switch", SWITCH_TK},
138 {"for", FOR_TK},
139 {"char", CHAR_TK},
140 {"", 0},
141 {"interface", INTERFACE_TK},
142 {"byte", BYTE_TK},
143 {"try", TRY_TK},
144 {"double", DOUBLE_TK},
145 {"while", WHILE_TK},
146 {"return", RETURN_TK},
147 {"implements", IMPLEMENTS_TK},
148 {"void", VOID_TK},
149 {"public", PUBLIC_TK},
150 {"if", IF_TK},
151 {"protected", PROTECTED_TK},
152 {"volatile", VOLATILE_TK},
153 {"goto", GOTO_TK},
154 {"", 0},
155 {"native", NATIVE_TK},
156 {"break", BREAK_TK},
157 {"", 0},
158 {"import", IMPORT_TK},
159 {"new", NEW_TK},
160 {"instanceof", INSTANCEOF_TK},
161 {"package", PACKAGE_TK},
162 {"boolean", BOOLEAN_TK},
163 {"", 0},
164 {"finally", FINALLY_TK},
165 {"throw", THROW_TK},
166 {"", 0}, {"", 0}, {"", 0}, {"", 0}, {"", 0}, {"", 0}, {"", 0}, {"", 0}, {"", 0},
167 {"", 0}, {"", 0}, {"", 0}, {"", 0}, {"", 0}, {"", 0},
168 {"strictfp", STRICT_TK},
169 {"", 0}, {"", 0}, {"", 0}, {"", 0}, {"", 0},
170 {"private", PRIVATE_TK}
171 };
172
173 if (len <= MAX_WORD_LENGTH && len >= MIN_WORD_LENGTH)
174 {
175 register int key = hash (str, len);
176
177 if (key <= MAX_HASH_VALUE && key >= 0)
178 {
179 register const char *s = wordlist[key].name;
180
181 if (*str == *s && !strcmp (str + 1, s + 1))
182 return &wordlist[key];
183 }
184 }
185 return 0;
186 }