diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2011-11-06 21:41:27 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-11-06 21:41:27 -0500 |
commit | dede6faac448db4251f8996d7dec6afb5a43726a (patch) | |
tree | dcf34d731bc4626b9e232151acee3673da84adaf /scripts | |
parent | 21404b772a1c65f7b935b8c0fddc388a949f4e31 (diff) | |
parent | 5f7efb4c6da9f90cb306923ced2a6494d065a595 (diff) |
Merge branch 'kbuild' of git://git.kernel.org/pub/scm/linux/kernel/git/mmarek/kbuild
* 'kbuild' of git://git.kernel.org/pub/scm/linux/kernel/git/mmarek/kbuild:
Kbuild: append missing-syscalls to the default target list
genksyms: Regenerate lexer and parser
genksyms: Do not expand internal types
genksyms: Minor parser cleanup
Makefile: remove a duplicated line
fixdep: fix extraneous dependencies
scripts/Makefile.build: do not reference EXTRA_CFLAGS as CFLAGS replacement
kbuild: prevent make from deleting _shipped files
kbuild: Do not delete empty files in make distclean
Diffstat (limited to 'scripts')
-rw-r--r-- | scripts/Makefile.build | 2 | ||||
-rw-r--r-- | scripts/Makefile.lib | 4 | ||||
-rw-r--r-- | scripts/basic/fixdep.c | 1 | ||||
-rw-r--r-- | scripts/genksyms/genksyms.c | 3 | ||||
-rw-r--r-- | scripts/genksyms/genksyms.h | 4 | ||||
-rw-r--r-- | scripts/genksyms/lex.l | 8 | ||||
-rw-r--r-- | scripts/genksyms/lex.lex.c_shipped | 12 | ||||
-rw-r--r-- | scripts/genksyms/parse.tab.c_shipped | 645 | ||||
-rw-r--r-- | scripts/genksyms/parse.tab.h_shipped | 7 | ||||
-rw-r--r-- | scripts/genksyms/parse.y | 40 |
10 files changed, 399 insertions, 327 deletions
diff --git a/scripts/Makefile.build b/scripts/Makefile.build index a0fd5029cfe..d2b366c16b6 100644 --- a/scripts/Makefile.build +++ b/scripts/Makefile.build | |||
@@ -46,7 +46,7 @@ include $(kbuild-file) | |||
46 | # If the save-* variables changed error out | 46 | # If the save-* variables changed error out |
47 | ifeq ($(KBUILD_NOPEDANTIC),) | 47 | ifeq ($(KBUILD_NOPEDANTIC),) |
48 | ifneq ("$(save-cflags)","$(CFLAGS)") | 48 | ifneq ("$(save-cflags)","$(CFLAGS)") |
49 | $(error CFLAGS was changed in "$(kbuild-file)". Fix it to use EXTRA_CFLAGS) | 49 | $(error CFLAGS was changed in "$(kbuild-file)". Fix it to use ccflags-y) |
50 | endif | 50 | endif |
51 | endif | 51 | endif |
52 | 52 | ||
diff --git a/scripts/Makefile.lib b/scripts/Makefile.lib index aeea84a2483..5d986d9adf1 100644 --- a/scripts/Makefile.lib +++ b/scripts/Makefile.lib | |||
@@ -167,6 +167,7 @@ ifdef REGENERATE_PARSERS | |||
167 | quiet_cmd_gperf = GPERF $@ | 167 | quiet_cmd_gperf = GPERF $@ |
168 | cmd_gperf = gperf -t --output-file $@ -a -C -E -g -k 1,3,$$ -p -t $< | 168 | cmd_gperf = gperf -t --output-file $@ -a -C -E -g -k 1,3,$$ -p -t $< |
169 | 169 | ||
170 | .PRECIOUS: $(src)/%.hash.c_shipped | ||
170 | $(src)/%.hash.c_shipped: $(src)/%.gperf | 171 | $(src)/%.hash.c_shipped: $(src)/%.gperf |
171 | $(call cmd,gperf) | 172 | $(call cmd,gperf) |
172 | 173 | ||
@@ -177,6 +178,7 @@ LEX_PREFIX = $(if $(LEX_PREFIX_${baseprereq}),$(LEX_PREFIX_${baseprereq}),yy) | |||
177 | quiet_cmd_flex = LEX $@ | 178 | quiet_cmd_flex = LEX $@ |
178 | cmd_flex = flex -o$@ -L -P $(LEX_PREFIX) $< | 179 | cmd_flex = flex -o$@ -L -P $(LEX_PREFIX) $< |
179 | 180 | ||
181 | .PRECIOUS: $(src)/%.lex.c_shipped | ||
180 | $(src)/%.lex.c_shipped: $(src)/%.l | 182 | $(src)/%.lex.c_shipped: $(src)/%.l |
181 | $(call cmd,flex) | 183 | $(call cmd,flex) |
182 | 184 | ||
@@ -187,12 +189,14 @@ YACC_PREFIX = $(if $(YACC_PREFIX_${baseprereq}),$(YACC_PREFIX_${baseprereq}),yy) | |||
187 | quiet_cmd_bison = YACC $@ | 189 | quiet_cmd_bison = YACC $@ |
188 | cmd_bison = bison -o$@ -t -l -p $(YACC_PREFIX) $< | 190 | cmd_bison = bison -o$@ -t -l -p $(YACC_PREFIX) $< |
189 | 191 | ||
192 | .PRECIOUS: $(src)/%.tab.c_shipped | ||
190 | $(src)/%.tab.c_shipped: $(src)/%.y | 193 | $(src)/%.tab.c_shipped: $(src)/%.y |
191 | $(call cmd,bison) | 194 | $(call cmd,bison) |
192 | 195 | ||
193 | quiet_cmd_bison_h = YACC $@ | 196 | quiet_cmd_bison_h = YACC $@ |
194 | cmd_bison_h = bison -o/dev/null --defines=$@ -t -l -p $(YACC_PREFIX) $< | 197 | cmd_bison_h = bison -o/dev/null --defines=$@ -t -l -p $(YACC_PREFIX) $< |
195 | 198 | ||
199 | .PRECIOUS: $(src)/%.tab.h_shipped | ||
196 | $(src)/%.tab.h_shipped: $(src)/%.y | 200 | $(src)/%.tab.h_shipped: $(src)/%.y |
197 | $(call cmd,bison_h) | 201 | $(call cmd,bison_h) |
198 | 202 | ||
diff --git a/scripts/basic/fixdep.c b/scripts/basic/fixdep.c index 291228e2598..cb1f50cf12e 100644 --- a/scripts/basic/fixdep.c +++ b/scripts/basic/fixdep.c | |||
@@ -345,6 +345,7 @@ static void parse_dep_file(void *map, size_t len) | |||
345 | memcpy(s, m, p-m); s[p-m] = 0; | 345 | memcpy(s, m, p-m); s[p-m] = 0; |
346 | if (strrcmp(s, "include/generated/autoconf.h") && | 346 | if (strrcmp(s, "include/generated/autoconf.h") && |
347 | strrcmp(s, "arch/um/include/uml-config.h") && | 347 | strrcmp(s, "arch/um/include/uml-config.h") && |
348 | strrcmp(s, "include/linux/kconfig.h") && | ||
348 | strrcmp(s, ".ver")) { | 349 | strrcmp(s, ".ver")) { |
349 | /* | 350 | /* |
350 | * Do not list the source file as dependency, so that | 351 | * Do not list the source file as dependency, so that |
diff --git a/scripts/genksyms/genksyms.c b/scripts/genksyms/genksyms.c index 6d3fda0ce2a..8a106499ec4 100644 --- a/scripts/genksyms/genksyms.c +++ b/scripts/genksyms/genksyms.c | |||
@@ -40,7 +40,8 @@ static struct symbol *symtab[HASH_BUCKETS]; | |||
40 | static FILE *debugfile; | 40 | static FILE *debugfile; |
41 | 41 | ||
42 | int cur_line = 1; | 42 | int cur_line = 1; |
43 | char *cur_filename; | 43 | char *cur_filename, *source_file; |
44 | int in_source_file; | ||
44 | 45 | ||
45 | static int flag_debug, flag_dump_defs, flag_reference, flag_dump_types, | 46 | static int flag_debug, flag_dump_defs, flag_reference, flag_dump_types, |
46 | flag_preserve, flag_warnings; | 47 | flag_preserve, flag_warnings; |
diff --git a/scripts/genksyms/genksyms.h b/scripts/genksyms/genksyms.h index 7ec52ae3846..3bffdcaaa27 100644 --- a/scripts/genksyms/genksyms.h +++ b/scripts/genksyms/genksyms.h | |||
@@ -37,6 +37,7 @@ enum symbol_status { | |||
37 | struct string_list { | 37 | struct string_list { |
38 | struct string_list *next; | 38 | struct string_list *next; |
39 | enum symbol_type tag; | 39 | enum symbol_type tag; |
40 | int in_source_file; | ||
40 | char *string; | 41 | char *string; |
41 | }; | 42 | }; |
42 | 43 | ||
@@ -57,7 +58,8 @@ typedef struct string_list **yystype; | |||
57 | #define YYSTYPE yystype | 58 | #define YYSTYPE yystype |
58 | 59 | ||
59 | extern int cur_line; | 60 | extern int cur_line; |
60 | extern char *cur_filename; | 61 | extern char *cur_filename, *source_file; |
62 | extern int in_source_file; | ||
61 | 63 | ||
62 | struct symbol *find_symbol(const char *name, enum symbol_type ns, int exact); | 64 | struct symbol *find_symbol(const char *name, enum symbol_type ns, int exact); |
63 | struct symbol *add_symbol(const char *name, enum symbol_type type, | 65 | struct symbol *add_symbol(const char *name, enum symbol_type type, |
diff --git a/scripts/genksyms/lex.l b/scripts/genksyms/lex.l index 400ae06a70d..f770071719c 100644 --- a/scripts/genksyms/lex.l +++ b/scripts/genksyms/lex.l | |||
@@ -116,6 +116,7 @@ MC_TOKEN ([~%^&*+=|<>/-]=)|(&&)|("||")|(->)|(<<)|(>>) | |||
116 | cur_node->tag = \ | 116 | cur_node->tag = \ |
117 | find_symbol(cur_node->string, SYM_ENUM_CONST, 1)?\ | 117 | find_symbol(cur_node->string, SYM_ENUM_CONST, 1)?\ |
118 | SYM_ENUM_CONST : SYM_NORMAL ; \ | 118 | SYM_ENUM_CONST : SYM_NORMAL ; \ |
119 | cur_node->in_source_file = in_source_file; \ | ||
119 | } while (0) | 120 | } while (0) |
120 | 121 | ||
121 | #define APP _APP(yytext, yyleng) | 122 | #define APP _APP(yytext, yyleng) |
@@ -166,6 +167,13 @@ repeat: | |||
166 | cur_filename = memcpy(xmalloc(e-file+1), file, e-file+1); | 167 | cur_filename = memcpy(xmalloc(e-file+1), file, e-file+1); |
167 | cur_line = atoi(yytext+2); | 168 | cur_line = atoi(yytext+2); |
168 | 169 | ||
170 | if (!source_file) { | ||
171 | source_file = xstrdup(cur_filename); | ||
172 | in_source_file = 1; | ||
173 | } else { | ||
174 | in_source_file = (strcmp(cur_filename, source_file) == 0); | ||
175 | } | ||
176 | |||
169 | goto repeat; | 177 | goto repeat; |
170 | } | 178 | } |
171 | 179 | ||
diff --git a/scripts/genksyms/lex.lex.c_shipped b/scripts/genksyms/lex.lex.c_shipped index c83cf60410b..0bf4157e616 100644 --- a/scripts/genksyms/lex.lex.c_shipped +++ b/scripts/genksyms/lex.lex.c_shipped | |||
@@ -660,7 +660,7 @@ static int input (void ); | |||
660 | /* This used to be an fputs(), but since the string might contain NUL's, | 660 | /* This used to be an fputs(), but since the string might contain NUL's, |
661 | * we now use fwrite(). | 661 | * we now use fwrite(). |
662 | */ | 662 | */ |
663 | #define ECHO do { if (fwrite( yytext, yyleng, 1, yyout )) {} } while (0) | 663 | #define ECHO fwrite( yytext, yyleng, 1, yyout ) |
664 | #endif | 664 | #endif |
665 | 665 | ||
666 | /* Gets input and stuffs it into "buf". number of characters read, or YY_NULL, | 666 | /* Gets input and stuffs it into "buf". number of characters read, or YY_NULL, |
@@ -671,7 +671,7 @@ static int input (void ); | |||
671 | if ( YY_CURRENT_BUFFER_LVALUE->yy_is_interactive ) \ | 671 | if ( YY_CURRENT_BUFFER_LVALUE->yy_is_interactive ) \ |
672 | { \ | 672 | { \ |
673 | int c = '*'; \ | 673 | int c = '*'; \ |
674 | unsigned n; \ | 674 | int n; \ |
675 | for ( n = 0; n < max_size && \ | 675 | for ( n = 0; n < max_size && \ |
676 | (c = getc( yyin )) != EOF && c != '\n'; ++n ) \ | 676 | (c = getc( yyin )) != EOF && c != '\n'; ++n ) \ |
677 | buf[n] = (char) c; \ | 677 | buf[n] = (char) c; \ |
@@ -1926,6 +1926,7 @@ void yyfree (void * ptr ) | |||
1926 | cur_node->tag = \ | 1926 | cur_node->tag = \ |
1927 | find_symbol(cur_node->string, SYM_ENUM_CONST, 1)?\ | 1927 | find_symbol(cur_node->string, SYM_ENUM_CONST, 1)?\ |
1928 | SYM_ENUM_CONST : SYM_NORMAL ; \ | 1928 | SYM_ENUM_CONST : SYM_NORMAL ; \ |
1929 | cur_node->in_source_file = in_source_file; \ | ||
1929 | } while (0) | 1930 | } while (0) |
1930 | 1931 | ||
1931 | #define APP _APP(yytext, yyleng) | 1932 | #define APP _APP(yytext, yyleng) |
@@ -1975,6 +1976,13 @@ repeat: | |||
1975 | cur_filename = memcpy(xmalloc(e-file+1), file, e-file+1); | 1976 | cur_filename = memcpy(xmalloc(e-file+1), file, e-file+1); |
1976 | cur_line = atoi(yytext+2); | 1977 | cur_line = atoi(yytext+2); |
1977 | 1978 | ||
1979 | if (!source_file) { | ||
1980 | source_file = xstrdup(cur_filename); | ||
1981 | in_source_file = 1; | ||
1982 | } else { | ||
1983 | in_source_file = (strcmp(cur_filename, source_file) == 0); | ||
1984 | } | ||
1985 | |||
1978 | goto repeat; | 1986 | goto repeat; |
1979 | } | 1987 | } |
1980 | 1988 | ||
diff --git a/scripts/genksyms/parse.tab.c_shipped b/scripts/genksyms/parse.tab.c_shipped index 61d4a5d0985..ece53c79bb5 100644 --- a/scripts/genksyms/parse.tab.c_shipped +++ b/scripts/genksyms/parse.tab.c_shipped | |||
@@ -1,9 +1,8 @@ | |||
1 | /* A Bison parser, made by GNU Bison 2.4.3. */ | 1 | /* A Bison parser, made by GNU Bison 2.5. */ |
2 | 2 | ||
3 | /* Skeleton implementation for Bison's Yacc-like parsers in C | 3 | /* Bison implementation for Yacc-like parsers in C |
4 | 4 | ||
5 | Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006, | 5 | Copyright (C) 1984, 1989-1990, 2000-2011 Free Software Foundation, Inc. |
6 | 2009, 2010 Free Software Foundation, Inc. | ||
7 | 6 | ||
8 | This program is free software: you can redistribute it and/or modify | 7 | This program is free software: you can redistribute it and/or modify |
9 | it under the terms of the GNU General Public License as published by | 8 | it under the terms of the GNU General Public License as published by |
@@ -45,7 +44,7 @@ | |||
45 | #define YYBISON 1 | 44 | #define YYBISON 1 |
46 | 45 | ||
47 | /* Bison version. */ | 46 | /* Bison version. */ |
48 | #define YYBISON_VERSION "2.4.3" | 47 | #define YYBISON_VERSION "2.5" |
49 | 48 | ||
50 | /* Skeleton name. */ | 49 | /* Skeleton name. */ |
51 | #define YYSKELETON_NAME "yacc.c" | 50 | #define YYSKELETON_NAME "yacc.c" |
@@ -96,6 +95,25 @@ remove_list(struct string_list **pb, struct string_list **pe) | |||
96 | free_list(b, e); | 95 | free_list(b, e); |
97 | } | 96 | } |
98 | 97 | ||
98 | /* Record definition of a struct/union/enum */ | ||
99 | static void record_compound(struct string_list **keyw, | ||
100 | struct string_list **ident, | ||
101 | struct string_list **body, | ||
102 | enum symbol_type type) | ||
103 | { | ||
104 | struct string_list *b = *body, *i = *ident, *r; | ||
105 | |||
106 | if (i->in_source_file) { | ||
107 | remove_node(keyw); | ||
108 | (*ident)->tag = type; | ||
109 | remove_list(body, ident); | ||
110 | return; | ||
111 | } | ||
112 | r = copy_node(i); r->tag = type; | ||
113 | r->next = (*keyw)->next; *body = r; (*keyw)->next = NULL; | ||
114 | add_symbol(i->string, type, b, is_extern); | ||
115 | } | ||
116 | |||
99 | 117 | ||
100 | 118 | ||
101 | 119 | ||
@@ -283,11 +301,11 @@ YYID (yyi) | |||
283 | # define alloca _alloca | 301 | # define alloca _alloca |
284 | # else | 302 | # else |
285 | # define YYSTACK_ALLOC alloca | 303 | # define YYSTACK_ALLOC alloca |
286 | # if ! defined _ALLOCA_H && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \ | 304 | # if ! defined _ALLOCA_H && ! defined EXIT_SUCCESS && (defined __STDC__ || defined __C99__FUNC__ \ |
287 | || defined __cplusplus || defined _MSC_VER) | 305 | || defined __cplusplus || defined _MSC_VER) |
288 | # include <stdlib.h> /* INFRINGES ON USER NAME SPACE */ | 306 | # include <stdlib.h> /* INFRINGES ON USER NAME SPACE */ |
289 | # ifndef _STDLIB_H | 307 | # ifndef EXIT_SUCCESS |
290 | # define _STDLIB_H 1 | 308 | # define EXIT_SUCCESS 0 |
291 | # endif | 309 | # endif |
292 | # endif | 310 | # endif |
293 | # endif | 311 | # endif |
@@ -310,24 +328,24 @@ YYID (yyi) | |||
310 | # ifndef YYSTACK_ALLOC_MAXIMUM | 328 | # ifndef YYSTACK_ALLOC_MAXIMUM |
311 | # define YYSTACK_ALLOC_MAXIMUM YYSIZE_MAXIMUM | 329 | # define YYSTACK_ALLOC_MAXIMUM YYSIZE_MAXIMUM |
312 | # endif | 330 | # endif |
313 | # if (defined __cplusplus && ! defined _STDLIB_H \ | 331 | # if (defined __cplusplus && ! defined EXIT_SUCCESS \ |
314 | && ! ((defined YYMALLOC || defined malloc) \ | 332 | && ! ((defined YYMALLOC || defined malloc) \ |
315 | && (defined YYFREE || defined free))) | 333 | && (defined YYFREE || defined free))) |
316 | # include <stdlib.h> /* INFRINGES ON USER NAME SPACE */ | 334 | # include <stdlib.h> /* INFRINGES ON USER NAME SPACE */ |
317 | # ifndef _STDLIB_H | 335 | # ifndef EXIT_SUCCESS |
318 | # define _STDLIB_H 1 | 336 | # define EXIT_SUCCESS 0 |
319 | # endif | 337 | # endif |
320 | # endif | 338 | # endif |
321 | # ifndef YYMALLOC | 339 | # ifndef YYMALLOC |
322 | # define YYMALLOC malloc | 340 | # define YYMALLOC malloc |
323 | # if ! defined malloc && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \ | 341 | # if ! defined malloc && ! defined EXIT_SUCCESS && (defined __STDC__ || defined __C99__FUNC__ \ |
324 | || defined __cplusplus || defined _MSC_VER) | 342 | || defined __cplusplus || defined _MSC_VER) |
325 | void *malloc (YYSIZE_T); /* INFRINGES ON USER NAME SPACE */ | 343 | void *malloc (YYSIZE_T); /* INFRINGES ON USER NAME SPACE */ |
326 | # endif | 344 | # endif |
327 | # endif | 345 | # endif |
328 | # ifndef YYFREE | 346 | # ifndef YYFREE |
329 | # define YYFREE free | 347 | # define YYFREE free |
330 | # if ! defined free && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \ | 348 | # if ! defined free && ! defined EXIT_SUCCESS && (defined __STDC__ || defined __C99__FUNC__ \ |
331 | || defined __cplusplus || defined _MSC_VER) | 349 | || defined __cplusplus || defined _MSC_VER) |
332 | void free (void *); /* INFRINGES ON USER NAME SPACE */ | 350 | void free (void *); /* INFRINGES ON USER NAME SPACE */ |
333 | # endif | 351 | # endif |
@@ -356,23 +374,7 @@ union yyalloc | |||
356 | ((N) * (sizeof (yytype_int16) + sizeof (YYSTYPE)) \ | 374 | ((N) * (sizeof (yytype_int16) + sizeof (YYSTYPE)) \ |
357 | + YYSTACK_GAP_MAXIMUM) | 375 | + YYSTACK_GAP_MAXIMUM) |
358 | 376 | ||
359 | /* Copy COUNT objects from FROM to TO. The source and destination do | 377 | # define YYCOPY_NEEDED 1 |
360 | not overlap. */ | ||
361 | # ifndef YYCOPY | ||
362 | # if defined __GNUC__ && 1 < __GNUC__ | ||
363 | # define YYCOPY(To, From, Count) \ | ||
364 | __builtin_memcpy (To, From, (Count) * sizeof (*(From))) | ||
365 | # else | ||
366 | # define YYCOPY(To, From, Count) \ | ||
367 | do \ | ||
368 | { \ | ||
369 | YYSIZE_T yyi; \ | ||
370 | for (yyi = 0; yyi < (Count); yyi++) \ | ||
371 | (To)[yyi] = (From)[yyi]; \ | ||
372 | } \ | ||
373 | while (YYID (0)) | ||
374 | # endif | ||
375 | # endif | ||
376 | 378 | ||
377 | /* Relocate STACK from its old location to the new one. The | 379 | /* Relocate STACK from its old location to the new one. The |
378 | local variables YYSIZE and YYSTACKSIZE give the old and new number of | 380 | local variables YYSIZE and YYSTACKSIZE give the old and new number of |
@@ -392,6 +394,26 @@ union yyalloc | |||
392 | 394 | ||
393 | #endif | 395 | #endif |
394 | 396 | ||
397 | #if defined YYCOPY_NEEDED && YYCOPY_NEEDED | ||
398 | /* Copy COUNT objects from FROM to TO. The source and destination do | ||
399 | not overlap. */ | ||
400 | # ifndef YYCOPY | ||
401 | # if defined __GNUC__ && 1 < __GNUC__ | ||
402 | # define YYCOPY(To, From, Count) \ | ||
403 | __builtin_memcpy (To, From, (Count) * sizeof (*(From))) | ||
404 | # else | ||
405 | # define YYCOPY(To, From, Count) \ | ||
406 | do \ | ||
407 | { \ | ||
408 | YYSIZE_T yyi; \ | ||
409 | for (yyi = 0; yyi < (Count); yyi++) \ | ||
410 | (To)[yyi] = (From)[yyi]; \ | ||
411 | } \ | ||
412 | while (YYID (0)) | ||
413 | # endif | ||
414 | # endif | ||
415 | #endif /* !YYCOPY_NEEDED */ | ||
416 | |||
395 | /* YYFINAL -- State number of the termination state. */ | 417 | /* YYFINAL -- State number of the termination state. */ |
396 | #define YYFINAL 4 | 418 | #define YYFINAL 4 |
397 | /* YYLAST -- Last index in YYTABLE. */ | 419 | /* YYLAST -- Last index in YYTABLE. */ |
@@ -514,20 +536,20 @@ static const yytype_int8 yyrhs[] = | |||
514 | /* YYRLINE[YYN] -- source line where rule number YYN was defined. */ | 536 | /* YYRLINE[YYN] -- source line where rule number YYN was defined. */ |
515 | static const yytype_uint16 yyrline[] = | 537 | static const yytype_uint16 yyrline[] = |
516 | { | 538 | { |
517 | 0, 104, 104, 105, 109, 109, 115, 115, 117, 117, | 539 | 0, 123, 123, 124, 128, 128, 134, 134, 136, 136, |
518 | 119, 120, 121, 122, 123, 124, 128, 142, 143, 147, | 540 | 138, 139, 140, 141, 142, 143, 147, 161, 162, 166, |
519 | 155, 168, 174, 175, 179, 180, 184, 190, 194, 195, | 541 | 174, 187, 193, 194, 198, 199, 203, 209, 213, 214, |
520 | 196, 197, 198, 202, 203, 204, 205, 209, 211, 213, | 542 | 215, 216, 217, 221, 222, 223, 224, 228, 230, 232, |
521 | 217, 224, 231, 241, 244, 245, 249, 250, 251, 252, | 543 | 236, 238, 240, 245, 248, 249, 253, 254, 255, 256, |
522 | 253, 254, 255, 256, 257, 258, 259, 263, 268, 269, | 544 | 257, 258, 259, 260, 261, 262, 263, 267, 272, 273, |
523 | 273, 274, 278, 278, 278, 279, 287, 288, 292, 301, | 545 | 277, 278, 282, 282, 282, 283, 291, 292, 296, 305, |
524 | 303, 305, 307, 309, 316, 317, 321, 322, 323, 325, | 546 | 307, 309, 311, 313, 320, 321, 325, 326, 327, 329, |
525 | 327, 329, 331, 336, 337, 338, 342, 343, 347, 348, | 547 | 331, 333, 335, 340, 341, 342, 346, 347, 351, 352, |
526 | 353, 358, 360, 364, 365, 373, 377, 379, 381, 383, | 548 | 357, 362, 364, 368, 369, 377, 381, 383, 385, 387, |
527 | 385, 390, 399, 400, 405, 410, 411, 415, 416, 420, | 549 | 389, 394, 403, 404, 409, 414, 415, 419, 420, 424, |
528 | 421, 425, 427, 432, 433, 437, 438, 442, 443, 444, | 550 | 425, 429, 431, 436, 437, 441, 442, 446, 447, 448, |
529 | 448, 452, 453, 457, 458, 462, 463, 466, 471, 479, | 551 | 452, 456, 457, 461, 462, 466, 467, 470, 475, 483, |
530 | 483, 484, 488 | 552 | 487, 488, 492 |
531 | }; | 553 | }; |
532 | #endif | 554 | #endif |
533 | 555 | ||
@@ -618,8 +640,8 @@ static const yytype_uint8 yyr2[] = | |||
618 | 0, 1, 5 | 640 | 0, 1, 5 |
619 | }; | 641 | }; |
620 | 642 | ||
621 | /* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state | 643 | /* YYDEFACT[STATE-NAME] -- Default reduction number in state STATE-NUM. |
622 | STATE-NUM when YYTABLE doesn't specify something else to do. Zero | 644 | Performed when YYTABLE doesn't specify something else to do. Zero |
623 | means the default is an error. */ | 645 | means the default is an error. */ |
624 | static const yytype_uint8 yydefact[] = | 646 | static const yytype_uint8 yydefact[] = |
625 | { | 647 | { |
@@ -692,8 +714,7 @@ static const yytype_int16 yypgoto[] = | |||
692 | 714 | ||
693 | /* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If | 715 | /* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If |
694 | positive, shift that token. If negative, reduce the rule which | 716 | positive, shift that token. If negative, reduce the rule which |
695 | number is the opposite. If zero, do what YYDEFACT says. | 717 | number is the opposite. If YYTABLE_NINF, syntax error. */ |
696 | If YYTABLE_NINF, syntax error. */ | ||
697 | #define YYTABLE_NINF -109 | 718 | #define YYTABLE_NINF -109 |
698 | static const yytype_int16 yytable[] = | 719 | static const yytype_int16 yytable[] = |
699 | { | 720 | { |
@@ -753,6 +774,12 @@ static const yytype_int16 yytable[] = | |||
753 | 0, 0, 34 | 774 | 0, 0, 34 |
754 | }; | 775 | }; |
755 | 776 | ||
777 | #define yypact_value_is_default(yystate) \ | ||
778 | ((yystate) == (-135)) | ||
779 | |||
780 | #define yytable_value_is_error(yytable_value) \ | ||
781 | YYID (0) | ||
782 | |||
756 | static const yytype_int16 yycheck[] = | 783 | static const yytype_int16 yycheck[] = |
757 | { | 784 | { |
758 | 59, 38, 79, 3, 1, 8, 56, 37, 26, 37, | 785 | 59, 38, 79, 3, 1, 8, 56, 37, 26, 37, |
@@ -869,7 +896,6 @@ do \ | |||
869 | { \ | 896 | { \ |
870 | yychar = (Token); \ | 897 | yychar = (Token); \ |
871 | yylval = (Value); \ | 898 | yylval = (Value); \ |
872 | yytoken = YYTRANSLATE (yychar); \ | ||
873 | YYPOPSTACK (1); \ | 899 | YYPOPSTACK (1); \ |
874 | goto yybackup; \ | 900 | goto yybackup; \ |
875 | } \ | 901 | } \ |
@@ -911,19 +937,10 @@ while (YYID (0)) | |||
911 | #endif | 937 | #endif |
912 | 938 | ||
913 | 939 | ||
914 | /* YY_LOCATION_PRINT -- Print the location on the stream. | 940 | /* This macro is provided for backward compatibility. */ |
915 | This macro was not mandated originally: define only if we know | ||
916 | we won't break user code: when these are the locations we know. */ | ||
917 | 941 | ||
918 | #ifndef YY_LOCATION_PRINT | 942 | #ifndef YY_LOCATION_PRINT |
919 | # if defined YYLTYPE_IS_TRIVIAL && YYLTYPE_IS_TRIVIAL | 943 | # define YY_LOCATION_PRINT(File, Loc) ((void) 0) |
920 | # define YY_LOCATION_PRINT(File, Loc) \ | ||
921 | fprintf (File, "%d.%d-%d.%d", \ | ||
922 | (Loc).first_line, (Loc).first_column, \ | ||
923 | (Loc).last_line, (Loc).last_column) | ||
924 | # else | ||
925 | # define YY_LOCATION_PRINT(File, Loc) ((void) 0) | ||
926 | # endif | ||
927 | #endif | 944 | #endif |
928 | 945 | ||
929 | 946 | ||
@@ -1115,7 +1132,6 @@ int yydebug; | |||
1115 | # define YYMAXDEPTH 10000 | 1132 | # define YYMAXDEPTH 10000 |
1116 | #endif | 1133 | #endif |
1117 | 1134 | ||
1118 | |||
1119 | 1135 | ||
1120 | #if YYERROR_VERBOSE | 1136 | #if YYERROR_VERBOSE |
1121 | 1137 | ||
@@ -1218,115 +1234,142 @@ yytnamerr (char *yyres, const char *yystr) | |||
1218 | } | 1234 | } |
1219 | # endif | 1235 | # endif |
1220 | 1236 | ||
1221 | /* Copy into YYRESULT an error message about the unexpected token | 1237 | /* Copy into *YYMSG, which is of size *YYMSG_ALLOC, an error message |
1222 | YYCHAR while in state YYSTATE. Return the number of bytes copied, | 1238 | about the unexpected token YYTOKEN for the state stack whose top is |
1223 | including the terminating null byte. If YYRESULT is null, do not | 1239 | YYSSP. |
1224 | copy anything; just return the number of bytes that would be | ||
1225 | copied. As a special case, return 0 if an ordinary "syntax error" | ||
1226 | message will do. Return YYSIZE_MAXIMUM if overflow occurs during | ||
1227 | size calculation. */ | ||
1228 | static YYSIZE_T | ||
1229 | yysyntax_error (char *yyresult, int yystate, int yychar) | ||
1230 | { | ||
1231 | int yyn = yypact[yystate]; | ||
1232 | 1240 | ||
1233 | if (! (YYPACT_NINF < yyn && yyn <= YYLAST)) | 1241 | Return 0 if *YYMSG was successfully written. Return 1 if *YYMSG is |
1234 | return 0; | 1242 | not large enough to hold the message. In that case, also set |
1235 | else | 1243 | *YYMSG_ALLOC to the required number of bytes. Return 2 if the |
1244 | required number of bytes is too large to store. */ | ||
1245 | static int | ||
1246 | yysyntax_error (YYSIZE_T *yymsg_alloc, char **yymsg, | ||
1247 | yytype_int16 *yyssp, int yytoken) | ||
1248 | { | ||
1249 | YYSIZE_T yysize0 = yytnamerr (0, yytname[yytoken]); | ||
1250 | YYSIZE_T yysize = yysize0; | ||
1251 | YYSIZE_T yysize1; | ||
1252 | enum { YYERROR_VERBOSE_ARGS_MAXIMUM = 5 }; | ||
1253 | /* Internationalized format string. */ | ||
1254 | const char *yyformat = 0; | ||
1255 | /* Arguments of yyformat. */ | ||
1256 | char const *yyarg[YYERROR_VERBOSE_ARGS_MAXIMUM]; | ||
1257 | /* Number of reported tokens (one for the "unexpected", one per | ||
1258 | "expected"). */ | ||
1259 | int yycount = 0; | ||
1260 | |||
1261 | /* There are many possibilities here to consider: | ||
1262 | - Assume YYFAIL is not used. It's too flawed to consider. See | ||
1263 | <http://lists.gnu.org/archive/html/bison-patches/2009-12/msg00024.html> | ||
1264 | for details. YYERROR is fine as it does not invoke this | ||
1265 | function. | ||
1266 | - If this state is a consistent state with a default action, then | ||
1267 | the only way this function was invoked is if the default action | ||
1268 | is an error action. In that case, don't check for expected | ||
1269 | tokens because there are none. | ||
1270 | - The only way there can be no lookahead present (in yychar) is if | ||
1271 | this state is a consistent state with a default action. Thus, | ||
1272 | detecting the absence of a lookahead is sufficient to determine | ||
1273 | that there is no unexpected or expected token to report. In that | ||
1274 | case, just report a simple "syntax error". | ||
1275 | - Don't assume there isn't a lookahead just because this state is a | ||
1276 | consistent state with a default action. There might have been a | ||
1277 | previous inconsistent state, consistent state with a non-default | ||
1278 | action, or user semantic action that manipulated yychar. | ||
1279 | - Of course, the expected token list depends on states to have | ||
1280 | correct lookahead information, and it depends on the parser not | ||
1281 | to perform extra reductions after fetching a lookahead from the | ||
1282 | scanner and before detecting a syntax error. Thus, state merging | ||
1283 | (from LALR or IELR) and default reductions corrupt the expected | ||
1284 | token list. However, the list is correct for canonical LR with | ||
1285 | one exception: it will still contain any token that will not be | ||
1286 | accepted due to an error action in a later state. | ||
1287 | */ | ||
1288 | if (yytoken != YYEMPTY) | ||
1236 | { | 1289 | { |
1237 | int yytype = YYTRANSLATE (yychar); | 1290 | int yyn = yypact[*yyssp]; |
1238 | YYSIZE_T yysize0 = yytnamerr (0, yytname[yytype]); | 1291 | yyarg[yycount++] = yytname[yytoken]; |
1239 | YYSIZE_T yysize = yysize0; | 1292 | if (!yypact_value_is_default (yyn)) |
1240 | YYSIZE_T yysize1; | 1293 | { |
1241 | int yysize_overflow = 0; | 1294 | /* Start YYX at -YYN if negative to avoid negative indexes in |
1242 | enum { YYERROR_VERBOSE_ARGS_MAXIMUM = 5 }; | 1295 | YYCHECK. In other words, skip the first -YYN actions for |
1243 | char const *yyarg[YYERROR_VERBOSE_ARGS_MAXIMUM]; | 1296 | this state because they are default actions. */ |
1244 | int yyx; | 1297 | int yyxbegin = yyn < 0 ? -yyn : 0; |
1245 | 1298 | /* Stay within bounds of both yycheck and yytname. */ | |
1246 | # if 0 | 1299 | int yychecklim = YYLAST - yyn + 1; |
1247 | /* This is so xgettext sees the translatable formats that are | 1300 | int yyxend = yychecklim < YYNTOKENS ? yychecklim : YYNTOKENS; |
1248 | constructed on the fly. */ | 1301 | int yyx; |
1249 | YY_("syntax error, unexpected %s"); | 1302 | |
1250 | YY_("syntax error, unexpected %s, expecting %s"); | 1303 | for (yyx = yyxbegin; yyx < yyxend; ++yyx) |
1251 | YY_("syntax error, unexpected %s, expecting %s or %s"); | 1304 | if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR |
1252 | YY_("syntax error, unexpected %s, expecting %s or %s or %s"); | 1305 | && !yytable_value_is_error (yytable[yyx + yyn])) |
1253 | YY_("syntax error, unexpected %s, expecting %s or %s or %s or %s"); | 1306 | { |
1254 | # endif | 1307 | if (yycount == YYERROR_VERBOSE_ARGS_MAXIMUM) |
1255 | char *yyfmt; | 1308 | { |
1256 | char const *yyf; | 1309 | yycount = 1; |
1257 | static char const yyunexpected[] = "syntax error, unexpected %s"; | 1310 | yysize = yysize0; |
1258 | static char const yyexpecting[] = ", expecting %s"; | 1311 | break; |
1259 | static char const yyor[] = " or %s"; | 1312 | } |
1260 | char yyformat[sizeof yyunexpected | 1313 | yyarg[yycount++] = yytname[yyx]; |
1261 | + sizeof yyexpecting - 1 | 1314 | yysize1 = yysize + yytnamerr (0, yytname[yyx]); |
1262 | + ((YYERROR_VERBOSE_ARGS_MAXIMUM - 2) | 1315 | if (! (yysize <= yysize1 |
1263 | * (sizeof yyor - 1))]; | 1316 | && yysize1 <= YYSTACK_ALLOC_MAXIMUM)) |
1264 | char const *yyprefix = yyexpecting; | 1317 | return 2; |
1265 | 1318 | yysize = yysize1; | |
1266 | /* Start YYX at -YYN if negative to avoid negative indexes in | 1319 | } |
1267 | YYCHECK. */ | 1320 | } |
1268 | int yyxbegin = yyn < 0 ? -yyn : 0; | 1321 | } |
1269 | |||
1270 | /* Stay within bounds of both yycheck and yytname. */ | ||
1271 | int yychecklim = YYLAST - yyn + 1; | ||
1272 | int yyxend = yychecklim < YYNTOKENS ? yychecklim : YYNTOKENS; | ||
1273 | int yycount = 1; | ||
1274 | |||
1275 | yyarg[0] = yytname[yytype]; | ||
1276 | yyfmt = yystpcpy (yyformat, yyunexpected); | ||
1277 | |||
1278 | for (yyx = yyxbegin; yyx < yyxend; ++yyx) | ||
1279 | if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR) | ||
1280 | { | ||
1281 | if (yycount == YYERROR_VERBOSE_ARGS_MAXIMUM) | ||
1282 | { | ||
1283 | yycount = 1; | ||
1284 | yysize = yysize0; | ||
1285 | yyformat[sizeof yyunexpected - 1] = '\0'; | ||
1286 | break; | ||
1287 | } | ||
1288 | yyarg[yycount++] = yytname[yyx]; | ||
1289 | yysize1 = yysize + yytnamerr (0, yytname[yyx]); | ||
1290 | yysize_overflow |= (yysize1 < yysize); | ||
1291 | yysize = yysize1; | ||
1292 | yyfmt = yystpcpy (yyfmt, yyprefix); | ||
1293 | yyprefix = yyor; | ||
1294 | } | ||
1295 | 1322 | ||
1296 | yyf = YY_(yyformat); | 1323 | switch (yycount) |
1297 | yysize1 = yysize + yystrlen (yyf); | 1324 | { |
1298 | yysize_overflow |= (yysize1 < yysize); | 1325 | # define YYCASE_(N, S) \ |
1299 | yysize = yysize1; | 1326 | case N: \ |
1327 | yyformat = S; \ | ||
1328 | break | ||
1329 | YYCASE_(0, YY_("syntax error")); | ||
1330 | YYCASE_(1, YY_("syntax error, unexpected %s")); | ||
1331 | YYCASE_(2, YY_("syntax error, unexpected %s, expecting %s")); | ||
1332 | YYCASE_(3, YY_("syntax error, unexpected %s, expecting %s or %s")); | ||
1333 | YYCASE_(4, YY_("syntax error, unexpected %s, expecting %s or %s or %s")); | ||
1334 | YYCASE_(5, YY_("syntax error, unexpected %s, expecting %s or %s or %s or %s")); | ||
1335 | # undef YYCASE_ | ||
1336 | } | ||
1300 | 1337 | ||
1301 | if (yysize_overflow) | 1338 | yysize1 = yysize + yystrlen (yyformat); |
1302 | return YYSIZE_MAXIMUM; | 1339 | if (! (yysize <= yysize1 && yysize1 <= YYSTACK_ALLOC_MAXIMUM)) |
1340 | return 2; | ||
1341 | yysize = yysize1; | ||
1303 | 1342 | ||
1304 | if (yyresult) | 1343 | if (*yymsg_alloc < yysize) |
1305 | { | 1344 | { |
1306 | /* Avoid sprintf, as that infringes on the user's name space. | 1345 | *yymsg_alloc = 2 * yysize; |
1307 | Don't have undefined behavior even if the translation | 1346 | if (! (yysize <= *yymsg_alloc |
1308 | produced a string with the wrong number of "%s"s. */ | 1347 | && *yymsg_alloc <= YYSTACK_ALLOC_MAXIMUM)) |
1309 | char *yyp = yyresult; | 1348 | *yymsg_alloc = YYSTACK_ALLOC_MAXIMUM; |
1310 | int yyi = 0; | 1349 | return 1; |
1311 | while ((*yyp = *yyf) != '\0') | ||
1312 | { | ||
1313 | if (*yyp == '%' && yyf[1] == 's' && yyi < yycount) | ||
1314 | { | ||
1315 | yyp += yytnamerr (yyp, yyarg[yyi++]); | ||
1316 | yyf += 2; | ||
1317 | } | ||
1318 | else | ||
1319 | { | ||
1320 | yyp++; | ||
1321 | yyf++; | ||
1322 | } | ||
1323 | } | ||
1324 | } | ||
1325 | return yysize; | ||
1326 | } | 1350 | } |
1351 | |||
1352 | /* Avoid sprintf, as that infringes on the user's name space. | ||
1353 | Don't have undefined behavior even if the translation | ||
1354 | produced a string with the wrong number of "%s"s. */ | ||
1355 | { | ||
1356 | char *yyp = *yymsg; | ||
1357 | int yyi = 0; | ||
1358 | while ((*yyp = *yyformat) != '\0') | ||
1359 | if (*yyp == '%' && yyformat[1] == 's' && yyi < yycount) | ||
1360 | { | ||
1361 | yyp += yytnamerr (yyp, yyarg[yyi++]); | ||
1362 | yyformat += 2; | ||
1363 | } | ||
1364 | else | ||
1365 | { | ||
1366 | yyp++; | ||
1367 | yyformat++; | ||
1368 | } | ||
1369 | } | ||
1370 | return 0; | ||
1327 | } | 1371 | } |
1328 | #endif /* YYERROR_VERBOSE */ | 1372 | #endif /* YYERROR_VERBOSE */ |
1329 | |||
1330 | 1373 | ||
1331 | /*-----------------------------------------------. | 1374 | /*-----------------------------------------------. |
1332 | | Release the memory associated to this symbol. | | 1375 | | Release the memory associated to this symbol. | |
@@ -1359,6 +1402,7 @@ yydestruct (yymsg, yytype, yyvaluep) | |||
1359 | } | 1402 | } |
1360 | } | 1403 | } |
1361 | 1404 | ||
1405 | |||
1362 | /* Prevent warnings from -Wmissing-prototypes. */ | 1406 | /* Prevent warnings from -Wmissing-prototypes. */ |
1363 | #ifdef YYPARSE_PARAM | 1407 | #ifdef YYPARSE_PARAM |
1364 | #if defined __STDC__ || defined __cplusplus | 1408 | #if defined __STDC__ || defined __cplusplus |
@@ -1385,10 +1429,9 @@ YYSTYPE yylval; | |||
1385 | int yynerrs; | 1429 | int yynerrs; |
1386 | 1430 | ||
1387 | 1431 | ||
1388 | 1432 | /*----------. | |
1389 | /*-------------------------. | 1433 | | yyparse. | |
1390 | | yyparse or yypush_parse. | | 1434 | `----------*/ |
1391 | `-------------------------*/ | ||
1392 | 1435 | ||
1393 | #ifdef YYPARSE_PARAM | 1436 | #ifdef YYPARSE_PARAM |
1394 | #if (defined __STDC__ || defined __C99__FUNC__ \ | 1437 | #if (defined __STDC__ || defined __C99__FUNC__ \ |
@@ -1412,8 +1455,6 @@ yyparse () | |||
1412 | #endif | 1455 | #endif |
1413 | #endif | 1456 | #endif |
1414 | { | 1457 | { |
1415 | |||
1416 | |||
1417 | int yystate; | 1458 | int yystate; |
1418 | /* Number of tokens to shift before error messages enabled. */ | 1459 | /* Number of tokens to shift before error messages enabled. */ |
1419 | int yyerrstatus; | 1460 | int yyerrstatus; |
@@ -1568,7 +1609,7 @@ yybackup: | |||
1568 | 1609 | ||
1569 | /* First try to decide what to do without reference to lookahead token. */ | 1610 | /* First try to decide what to do without reference to lookahead token. */ |
1570 | yyn = yypact[yystate]; | 1611 | yyn = yypact[yystate]; |
1571 | if (yyn == YYPACT_NINF) | 1612 | if (yypact_value_is_default (yyn)) |
1572 | goto yydefault; | 1613 | goto yydefault; |
1573 | 1614 | ||
1574 | /* Not known => get a lookahead token if don't already have one. */ | 1615 | /* Not known => get a lookahead token if don't already have one. */ |
@@ -1599,8 +1640,8 @@ yybackup: | |||
1599 | yyn = yytable[yyn]; | 1640 | yyn = yytable[yyn]; |
1600 | if (yyn <= 0) | 1641 | if (yyn <= 0) |
1601 | { | 1642 | { |
1602 | if (yyn == 0 || yyn == YYTABLE_NINF) | 1643 | if (yytable_value_is_error (yyn)) |
1603 | goto yyerrlab; | 1644 | goto yyerrlab; |
1604 | yyn = -yyn; | 1645 | yyn = -yyn; |
1605 | goto yyreduce; | 1646 | goto yyreduce; |
1606 | } | 1647 | } |
@@ -1655,42 +1696,42 @@ yyreduce: | |||
1655 | { | 1696 | { |
1656 | case 4: | 1697 | case 4: |
1657 | 1698 | ||
1658 | { is_typedef = 0; is_extern = 0; current_name = NULL; decl_spec = NULL; ;} | 1699 | { is_typedef = 0; is_extern = 0; current_name = NULL; decl_spec = NULL; } |
1659 | break; | 1700 | break; |
1660 | 1701 | ||
1661 | case 5: | 1702 | case 5: |
1662 | 1703 | ||
1663 | { free_list(*(yyvsp[(2) - (2)]), NULL); *(yyvsp[(2) - (2)]) = NULL; ;} | 1704 | { free_list(*(yyvsp[(2) - (2)]), NULL); *(yyvsp[(2) - (2)]) = NULL; } |
1664 | break; | 1705 | break; |
1665 | 1706 | ||
1666 | case 6: | 1707 | case 6: |
1667 | 1708 | ||
1668 | { is_typedef = 1; ;} | 1709 | { is_typedef = 1; } |
1669 | break; | 1710 | break; |
1670 | 1711 | ||
1671 | case 7: | 1712 | case 7: |
1672 | 1713 | ||
1673 | { (yyval) = (yyvsp[(4) - (4)]); ;} | 1714 | { (yyval) = (yyvsp[(4) - (4)]); } |
1674 | break; | 1715 | break; |
1675 | 1716 | ||
1676 | case 8: | 1717 | case 8: |
1677 | 1718 | ||
1678 | { is_typedef = 1; ;} | 1719 | { is_typedef = 1; } |
1679 | break; | 1720 | break; |
1680 | 1721 | ||
1681 | case 9: | 1722 | case 9: |
1682 | 1723 | ||
1683 | { (yyval) = (yyvsp[(3) - (3)]); ;} | 1724 | { (yyval) = (yyvsp[(3) - (3)]); } |
1684 | break; | 1725 | break; |
1685 | 1726 | ||
1686 | case 14: | 1727 | case 14: |
1687 | 1728 | ||
1688 | { (yyval) = (yyvsp[(2) - (2)]); ;} | 1729 | { (yyval) = (yyvsp[(2) - (2)]); } |
1689 | break; | 1730 | break; |
1690 | 1731 | ||
1691 | case 15: | 1732 | case 15: |
1692 | 1733 | ||
1693 | { (yyval) = (yyvsp[(2) - (2)]); ;} | 1734 | { (yyval) = (yyvsp[(2) - (2)]); } |
1694 | break; | 1735 | break; |
1695 | 1736 | ||
1696 | case 16: | 1737 | case 16: |
@@ -1704,12 +1745,12 @@ yyreduce: | |||
1704 | current_name = NULL; | 1745 | current_name = NULL; |
1705 | } | 1746 | } |
1706 | (yyval) = (yyvsp[(3) - (3)]); | 1747 | (yyval) = (yyvsp[(3) - (3)]); |
1707 | ;} | 1748 | } |
1708 | break; | 1749 | break; |
1709 | 1750 | ||
1710 | case 17: | 1751 | case 17: |
1711 | 1752 | ||
1712 | { (yyval) = NULL; ;} | 1753 | { (yyval) = NULL; } |
1713 | break; | 1754 | break; |
1714 | 1755 | ||
1715 | case 19: | 1756 | case 19: |
@@ -1720,7 +1761,7 @@ yyreduce: | |||
1720 | is_typedef ? SYM_TYPEDEF : SYM_NORMAL, decl, is_extern); | 1761 | is_typedef ? SYM_TYPEDEF : SYM_NORMAL, decl, is_extern); |
1721 | current_name = NULL; | 1762 | current_name = NULL; |
1722 | (yyval) = (yyvsp[(1) - (1)]); | 1763 | (yyval) = (yyvsp[(1) - (1)]); |
1723 | ;} | 1764 | } |
1724 | break; | 1765 | break; |
1725 | 1766 | ||
1726 | case 20: | 1767 | case 20: |
@@ -1733,27 +1774,27 @@ yyreduce: | |||
1733 | is_typedef ? SYM_TYPEDEF : SYM_NORMAL, decl, is_extern); | 1774 | is_typedef ? SYM_TYPEDEF : SYM_NORMAL, decl, is_extern); |
1734 | current_name = NULL; | 1775 | current_name = NULL; |
1735 | (yyval) = (yyvsp[(3) - (3)]); | 1776 | (yyval) = (yyvsp[(3) - (3)]); |
1736 | ;} | 1777 | } |
1737 | break; | 1778 | break; |
1738 | 1779 | ||
1739 | case 21: | 1780 | case 21: |
1740 | 1781 | ||
1741 | { (yyval) = (yyvsp[(4) - (4)]) ? (yyvsp[(4) - (4)]) : (yyvsp[(3) - (4)]) ? (yyvsp[(3) - (4)]) : (yyvsp[(2) - (4)]) ? (yyvsp[(2) - (4)]) : (yyvsp[(1) - (4)]); ;} | 1782 | { (yyval) = (yyvsp[(4) - (4)]) ? (yyvsp[(4) - (4)]) : (yyvsp[(3) - (4)]) ? (yyvsp[(3) - (4)]) : (yyvsp[(2) - (4)]) ? (yyvsp[(2) - (4)]) : (yyvsp[(1) - (4)]); } |
1742 | break; | 1783 | break; |
1743 | 1784 | ||
1744 | case 22: | 1785 | case 22: |
1745 | 1786 | ||
1746 | { decl_spec = NULL; ;} | 1787 | { decl_spec = NULL; } |
1747 | break; | 1788 | break; |
1748 | 1789 | ||
1749 | case 24: | 1790 | case 24: |
1750 | 1791 | ||
1751 | { decl_spec = *(yyvsp[(1) - (1)]); ;} | 1792 | { decl_spec = *(yyvsp[(1) - (1)]); } |
1752 | break; | 1793 | break; |
1753 | 1794 | ||
1754 | case 25: | 1795 | case 25: |
1755 | 1796 | ||
1756 | { decl_spec = *(yyvsp[(2) - (2)]); ;} | 1797 | { decl_spec = *(yyvsp[(2) - (2)]); } |
1757 | break; | 1798 | break; |
1758 | 1799 | ||
1759 | case 26: | 1800 | case 26: |
@@ -1762,97 +1803,82 @@ yyreduce: | |||
1762 | is really irrelevant to the linkage. */ | 1803 | is really irrelevant to the linkage. */ |
1763 | remove_node((yyvsp[(1) - (1)])); | 1804 | remove_node((yyvsp[(1) - (1)])); |
1764 | (yyval) = (yyvsp[(1) - (1)]); | 1805 | (yyval) = (yyvsp[(1) - (1)]); |
1765 | ;} | 1806 | } |
1766 | break; | 1807 | break; |
1767 | 1808 | ||
1768 | case 31: | 1809 | case 31: |
1769 | 1810 | ||
1770 | { is_extern = 1; (yyval) = (yyvsp[(1) - (1)]); ;} | 1811 | { is_extern = 1; (yyval) = (yyvsp[(1) - (1)]); } |
1771 | break; | 1812 | break; |
1772 | 1813 | ||
1773 | case 32: | 1814 | case 32: |
1774 | 1815 | ||
1775 | { is_extern = 0; (yyval) = (yyvsp[(1) - (1)]); ;} | 1816 | { is_extern = 0; (yyval) = (yyvsp[(1) - (1)]); } |
1776 | break; | 1817 | break; |
1777 | 1818 | ||
1778 | case 37: | 1819 | case 37: |
1779 | 1820 | ||
1780 | { remove_node((yyvsp[(1) - (2)])); (*(yyvsp[(2) - (2)]))->tag = SYM_STRUCT; (yyval) = (yyvsp[(2) - (2)]); ;} | 1821 | { remove_node((yyvsp[(1) - (2)])); (*(yyvsp[(2) - (2)]))->tag = SYM_STRUCT; (yyval) = (yyvsp[(2) - (2)]); } |
1781 | break; | 1822 | break; |
1782 | 1823 | ||
1783 | case 38: | 1824 | case 38: |
1784 | 1825 | ||
1785 | { remove_node((yyvsp[(1) - (2)])); (*(yyvsp[(2) - (2)]))->tag = SYM_UNION; (yyval) = (yyvsp[(2) - (2)]); ;} | 1826 | { remove_node((yyvsp[(1) - (2)])); (*(yyvsp[(2) - (2)]))->tag = SYM_UNION; (yyval) = (yyvsp[(2) - (2)]); } |
1786 | break; | 1827 | break; |
1787 | 1828 | ||
1788 | case 39: | 1829 | case 39: |
1789 | 1830 | ||
1790 | { remove_node((yyvsp[(1) - (2)])); (*(yyvsp[(2) - (2)]))->tag = SYM_ENUM; (yyval) = (yyvsp[(2) - (2)]); ;} | 1831 | { remove_node((yyvsp[(1) - (2)])); (*(yyvsp[(2) - (2)]))->tag = SYM_ENUM; (yyval) = (yyvsp[(2) - (2)]); } |
1791 | break; | 1832 | break; |
1792 | 1833 | ||
1793 | case 40: | 1834 | case 40: |
1794 | 1835 | ||
1795 | { struct string_list *s = *(yyvsp[(3) - (3)]), *i = *(yyvsp[(2) - (3)]), *r; | 1836 | { record_compound((yyvsp[(1) - (3)]), (yyvsp[(2) - (3)]), (yyvsp[(3) - (3)]), SYM_STRUCT); (yyval) = (yyvsp[(3) - (3)]); } |
1796 | r = copy_node(i); r->tag = SYM_STRUCT; | ||
1797 | r->next = (*(yyvsp[(1) - (3)]))->next; *(yyvsp[(3) - (3)]) = r; (*(yyvsp[(1) - (3)]))->next = NULL; | ||
1798 | add_symbol(i->string, SYM_STRUCT, s, is_extern); | ||
1799 | (yyval) = (yyvsp[(3) - (3)]); | ||
1800 | ;} | ||
1801 | break; | 1837 | break; |
1802 | 1838 | ||
1803 | case 41: | 1839 | case 41: |
1804 | 1840 | ||
1805 | { struct string_list *s = *(yyvsp[(3) - (3)]), *i = *(yyvsp[(2) - (3)]), *r; | 1841 | { record_compound((yyvsp[(1) - (3)]), (yyvsp[(2) - (3)]), (yyvsp[(3) - (3)]), SYM_UNION); (yyval) = (yyvsp[(3) - (3)]); } |
1806 | r = copy_node(i); r->tag = SYM_UNION; | ||
1807 | r->next = (*(yyvsp[(1) - (3)]))->next; *(yyvsp[(3) - (3)]) = r; (*(yyvsp[(1) - (3)]))->next = NULL; | ||
1808 | add_symbol(i->string, SYM_UNION, s, is_extern); | ||
1809 | (yyval) = (yyvsp[(3) - (3)]); | ||
1810 | ;} | ||
1811 | break; | 1842 | break; |
1812 | 1843 | ||
1813 | case 42: | 1844 | case 42: |
1814 | 1845 | ||
1815 | { struct string_list *s = *(yyvsp[(3) - (3)]), *i = *(yyvsp[(2) - (3)]), *r; | 1846 | { record_compound((yyvsp[(1) - (3)]), (yyvsp[(2) - (3)]), (yyvsp[(3) - (3)]), SYM_ENUM); (yyval) = (yyvsp[(3) - (3)]); } |
1816 | r = copy_node(i); r->tag = SYM_ENUM; | ||
1817 | r->next = (*(yyvsp[(1) - (3)]))->next; *(yyvsp[(3) - (3)]) = r; (*(yyvsp[(1) - (3)]))->next = NULL; | ||
1818 | add_symbol(i->string, SYM_ENUM, s, is_extern); | ||
1819 | (yyval) = (yyvsp[(3) - (3)]); | ||
1820 | ;} | ||
1821 | break; | 1847 | break; |
1822 | 1848 | ||
1823 | case 43: | 1849 | case 43: |
1824 | 1850 | ||
1825 | { add_symbol(NULL, SYM_ENUM, NULL, 0); (yyval) = (yyvsp[(2) - (2)]); ;} | 1851 | { add_symbol(NULL, SYM_ENUM, NULL, 0); (yyval) = (yyvsp[(2) - (2)]); } |
1826 | break; | 1852 | break; |
1827 | 1853 | ||
1828 | case 44: | 1854 | case 44: |
1829 | 1855 | ||
1830 | { (yyval) = (yyvsp[(2) - (2)]); ;} | 1856 | { (yyval) = (yyvsp[(2) - (2)]); } |
1831 | break; | 1857 | break; |
1832 | 1858 | ||
1833 | case 45: | 1859 | case 45: |
1834 | 1860 | ||
1835 | { (yyval) = (yyvsp[(2) - (2)]); ;} | 1861 | { (yyval) = (yyvsp[(2) - (2)]); } |
1836 | break; | 1862 | break; |
1837 | 1863 | ||
1838 | case 56: | 1864 | case 56: |
1839 | 1865 | ||
1840 | { (*(yyvsp[(1) - (1)]))->tag = SYM_TYPEDEF; (yyval) = (yyvsp[(1) - (1)]); ;} | 1866 | { (*(yyvsp[(1) - (1)]))->tag = SYM_TYPEDEF; (yyval) = (yyvsp[(1) - (1)]); } |
1841 | break; | 1867 | break; |
1842 | 1868 | ||
1843 | case 57: | 1869 | case 57: |
1844 | 1870 | ||
1845 | { (yyval) = (yyvsp[(2) - (2)]) ? (yyvsp[(2) - (2)]) : (yyvsp[(1) - (2)]); ;} | 1871 | { (yyval) = (yyvsp[(2) - (2)]) ? (yyvsp[(2) - (2)]) : (yyvsp[(1) - (2)]); } |
1846 | break; | 1872 | break; |
1847 | 1873 | ||
1848 | case 58: | 1874 | case 58: |
1849 | 1875 | ||
1850 | { (yyval) = NULL; ;} | 1876 | { (yyval) = NULL; } |
1851 | break; | 1877 | break; |
1852 | 1878 | ||
1853 | case 61: | 1879 | case 61: |
1854 | 1880 | ||
1855 | { (yyval) = (yyvsp[(2) - (2)]); ;} | 1881 | { (yyval) = (yyvsp[(2) - (2)]); } |
1856 | break; | 1882 | break; |
1857 | 1883 | ||
1858 | case 65: | 1884 | case 65: |
@@ -1860,12 +1886,12 @@ yyreduce: | |||
1860 | { /* restrict has no effect in prototypes so ignore it */ | 1886 | { /* restrict has no effect in prototypes so ignore it */ |
1861 | remove_node((yyvsp[(1) - (1)])); | 1887 | remove_node((yyvsp[(1) - (1)])); |
1862 | (yyval) = (yyvsp[(1) - (1)]); | 1888 | (yyval) = (yyvsp[(1) - (1)]); |
1863 | ;} | 1889 | } |
1864 | break; | 1890 | break; |
1865 | 1891 | ||
1866 | case 66: | 1892 | case 66: |
1867 | 1893 | ||
1868 | { (yyval) = (yyvsp[(2) - (2)]); ;} | 1894 | { (yyval) = (yyvsp[(2) - (2)]); } |
1869 | break; | 1895 | break; |
1870 | 1896 | ||
1871 | case 68: | 1897 | case 68: |
@@ -1877,97 +1903,97 @@ yyreduce: | |||
1877 | current_name = (*(yyvsp[(1) - (1)]))->string; | 1903 | current_name = (*(yyvsp[(1) - (1)]))->string; |
1878 | (yyval) = (yyvsp[(1) - (1)]); | 1904 | (yyval) = (yyvsp[(1) - (1)]); |
1879 | } | 1905 | } |
1880 | ;} | 1906 | } |
1881 | break; | 1907 | break; |
1882 | 1908 | ||
1883 | case 69: | 1909 | case 69: |
1884 | 1910 | ||
1885 | { (yyval) = (yyvsp[(4) - (4)]); ;} | 1911 | { (yyval) = (yyvsp[(4) - (4)]); } |
1886 | break; | 1912 | break; |
1887 | 1913 | ||
1888 | case 70: | 1914 | case 70: |
1889 | 1915 | ||
1890 | { (yyval) = (yyvsp[(4) - (4)]); ;} | 1916 | { (yyval) = (yyvsp[(4) - (4)]); } |
1891 | break; | 1917 | break; |
1892 | 1918 | ||
1893 | case 71: | 1919 | case 71: |
1894 | 1920 | ||
1895 | { (yyval) = (yyvsp[(2) - (2)]); ;} | 1921 | { (yyval) = (yyvsp[(2) - (2)]); } |
1896 | break; | 1922 | break; |
1897 | 1923 | ||
1898 | case 72: | 1924 | case 72: |
1899 | 1925 | ||
1900 | { (yyval) = (yyvsp[(3) - (3)]); ;} | 1926 | { (yyval) = (yyvsp[(3) - (3)]); } |
1901 | break; | 1927 | break; |
1902 | 1928 | ||
1903 | case 73: | 1929 | case 73: |
1904 | 1930 | ||
1905 | { (yyval) = (yyvsp[(3) - (3)]); ;} | 1931 | { (yyval) = (yyvsp[(3) - (3)]); } |
1906 | break; | 1932 | break; |
1907 | 1933 | ||
1908 | case 74: | 1934 | case 74: |
1909 | 1935 | ||
1910 | { (yyval) = (yyvsp[(2) - (2)]); ;} | 1936 | { (yyval) = (yyvsp[(2) - (2)]); } |
1911 | break; | 1937 | break; |
1912 | 1938 | ||
1913 | case 78: | 1939 | case 78: |
1914 | 1940 | ||
1915 | { (yyval) = (yyvsp[(4) - (4)]); ;} | 1941 | { (yyval) = (yyvsp[(4) - (4)]); } |
1916 | break; | 1942 | break; |
1917 | 1943 | ||
1918 | case 79: | 1944 | case 79: |
1919 | 1945 | ||
1920 | { (yyval) = (yyvsp[(4) - (4)]); ;} | 1946 | { (yyval) = (yyvsp[(4) - (4)]); } |
1921 | break; | 1947 | break; |
1922 | 1948 | ||
1923 | case 80: | 1949 | case 80: |
1924 | 1950 | ||
1925 | { (yyval) = (yyvsp[(2) - (2)]); ;} | 1951 | { (yyval) = (yyvsp[(2) - (2)]); } |
1926 | break; | 1952 | break; |
1927 | 1953 | ||
1928 | case 81: | 1954 | case 81: |
1929 | 1955 | ||
1930 | { (yyval) = (yyvsp[(3) - (3)]); ;} | 1956 | { (yyval) = (yyvsp[(3) - (3)]); } |
1931 | break; | 1957 | break; |
1932 | 1958 | ||
1933 | case 82: | 1959 | case 82: |
1934 | 1960 | ||
1935 | { (yyval) = (yyvsp[(3) - (3)]); ;} | 1961 | { (yyval) = (yyvsp[(3) - (3)]); } |
1936 | break; | 1962 | break; |
1937 | 1963 | ||
1938 | case 83: | 1964 | case 83: |
1939 | 1965 | ||
1940 | { (yyval) = (yyvsp[(2) - (2)]); ;} | 1966 | { (yyval) = (yyvsp[(2) - (2)]); } |
1941 | break; | 1967 | break; |
1942 | 1968 | ||
1943 | case 85: | 1969 | case 85: |
1944 | 1970 | ||
1945 | { (yyval) = (yyvsp[(3) - (3)]); ;} | 1971 | { (yyval) = (yyvsp[(3) - (3)]); } |
1946 | break; | 1972 | break; |
1947 | 1973 | ||
1948 | case 86: | 1974 | case 86: |
1949 | 1975 | ||
1950 | { (yyval) = NULL; ;} | 1976 | { (yyval) = NULL; } |
1951 | break; | 1977 | break; |
1952 | 1978 | ||
1953 | case 89: | 1979 | case 89: |
1954 | 1980 | ||
1955 | { (yyval) = (yyvsp[(3) - (3)]); ;} | 1981 | { (yyval) = (yyvsp[(3) - (3)]); } |
1956 | break; | 1982 | break; |
1957 | 1983 | ||
1958 | case 90: | 1984 | case 90: |
1959 | 1985 | ||
1960 | { (yyval) = (yyvsp[(2) - (2)]) ? (yyvsp[(2) - (2)]) : (yyvsp[(1) - (2)]); ;} | 1986 | { (yyval) = (yyvsp[(2) - (2)]) ? (yyvsp[(2) - (2)]) : (yyvsp[(1) - (2)]); } |
1961 | break; | 1987 | break; |
1962 | 1988 | ||
1963 | case 91: | 1989 | case 91: |
1964 | 1990 | ||
1965 | { (yyval) = (yyvsp[(2) - (2)]) ? (yyvsp[(2) - (2)]) : (yyvsp[(1) - (2)]); ;} | 1991 | { (yyval) = (yyvsp[(2) - (2)]) ? (yyvsp[(2) - (2)]) : (yyvsp[(1) - (2)]); } |
1966 | break; | 1992 | break; |
1967 | 1993 | ||
1968 | case 93: | 1994 | case 93: |
1969 | 1995 | ||
1970 | { (yyval) = NULL; ;} | 1996 | { (yyval) = NULL; } |
1971 | break; | 1997 | break; |
1972 | 1998 | ||
1973 | case 94: | 1999 | case 94: |
@@ -1976,39 +2002,39 @@ yyreduce: | |||
1976 | private parameter names. */ | 2002 | private parameter names. */ |
1977 | remove_node((yyvsp[(1) - (1)])); | 2003 | remove_node((yyvsp[(1) - (1)])); |
1978 | (yyval) = (yyvsp[(1) - (1)]); | 2004 | (yyval) = (yyvsp[(1) - (1)]); |
1979 | ;} | 2005 | } |
1980 | break; | 2006 | break; |
1981 | 2007 | ||
1982 | case 95: | 2008 | case 95: |
1983 | 2009 | ||
1984 | { remove_node((yyvsp[(1) - (1)])); | 2010 | { remove_node((yyvsp[(1) - (1)])); |
1985 | (yyval) = (yyvsp[(1) - (1)]); | 2011 | (yyval) = (yyvsp[(1) - (1)]); |
1986 | ;} | 2012 | } |
1987 | break; | 2013 | break; |
1988 | 2014 | ||
1989 | case 96: | 2015 | case 96: |
1990 | 2016 | ||
1991 | { (yyval) = (yyvsp[(4) - (4)]); ;} | 2017 | { (yyval) = (yyvsp[(4) - (4)]); } |
1992 | break; | 2018 | break; |
1993 | 2019 | ||
1994 | case 97: | 2020 | case 97: |
1995 | 2021 | ||
1996 | { (yyval) = (yyvsp[(4) - (4)]); ;} | 2022 | { (yyval) = (yyvsp[(4) - (4)]); } |
1997 | break; | 2023 | break; |
1998 | 2024 | ||
1999 | case 98: | 2025 | case 98: |
2000 | 2026 | ||
2001 | { (yyval) = (yyvsp[(2) - (2)]); ;} | 2027 | { (yyval) = (yyvsp[(2) - (2)]); } |
2002 | break; | 2028 | break; |
2003 | 2029 | ||
2004 | case 99: | 2030 | case 99: |
2005 | 2031 | ||
2006 | { (yyval) = (yyvsp[(3) - (3)]); ;} | 2032 | { (yyval) = (yyvsp[(3) - (3)]); } |
2007 | break; | 2033 | break; |
2008 | 2034 | ||
2009 | case 100: | 2035 | case 100: |
2010 | 2036 | ||
2011 | { (yyval) = (yyvsp[(3) - (3)]); ;} | 2037 | { (yyval) = (yyvsp[(3) - (3)]); } |
2012 | break; | 2038 | break; |
2013 | 2039 | ||
2014 | case 101: | 2040 | case 101: |
@@ -2017,87 +2043,87 @@ yyreduce: | |||
2017 | *(yyvsp[(2) - (3)]) = NULL; | 2043 | *(yyvsp[(2) - (3)]) = NULL; |
2018 | add_symbol(current_name, SYM_NORMAL, decl, is_extern); | 2044 | add_symbol(current_name, SYM_NORMAL, decl, is_extern); |
2019 | (yyval) = (yyvsp[(3) - (3)]); | 2045 | (yyval) = (yyvsp[(3) - (3)]); |
2020 | ;} | 2046 | } |
2021 | break; | 2047 | break; |
2022 | 2048 | ||
2023 | case 102: | 2049 | case 102: |
2024 | 2050 | ||
2025 | { (yyval) = NULL; ;} | 2051 | { (yyval) = NULL; } |
2026 | break; | 2052 | break; |
2027 | 2053 | ||
2028 | case 104: | 2054 | case 104: |
2029 | 2055 | ||
2030 | { remove_list((yyvsp[(2) - (2)]), &(*(yyvsp[(1) - (2)]))->next); (yyval) = (yyvsp[(2) - (2)]); ;} | 2056 | { remove_list((yyvsp[(2) - (2)]), &(*(yyvsp[(1) - (2)]))->next); (yyval) = (yyvsp[(2) - (2)]); } |
2031 | break; | 2057 | break; |
2032 | 2058 | ||
2033 | case 105: | 2059 | case 105: |
2034 | 2060 | ||
2035 | { (yyval) = (yyvsp[(3) - (3)]); ;} | 2061 | { (yyval) = (yyvsp[(3) - (3)]); } |
2036 | break; | 2062 | break; |
2037 | 2063 | ||
2038 | case 106: | 2064 | case 106: |
2039 | 2065 | ||
2040 | { (yyval) = (yyvsp[(3) - (3)]); ;} | 2066 | { (yyval) = (yyvsp[(3) - (3)]); } |
2041 | break; | 2067 | break; |
2042 | 2068 | ||
2043 | case 107: | 2069 | case 107: |
2044 | 2070 | ||
2045 | { (yyval) = NULL; ;} | 2071 | { (yyval) = NULL; } |
2046 | break; | 2072 | break; |
2047 | 2073 | ||
2048 | case 110: | 2074 | case 110: |
2049 | 2075 | ||
2050 | { (yyval) = (yyvsp[(2) - (2)]); ;} | 2076 | { (yyval) = (yyvsp[(2) - (2)]); } |
2051 | break; | 2077 | break; |
2052 | 2078 | ||
2053 | case 111: | 2079 | case 111: |
2054 | 2080 | ||
2055 | { (yyval) = (yyvsp[(3) - (3)]); ;} | 2081 | { (yyval) = (yyvsp[(3) - (3)]); } |
2056 | break; | 2082 | break; |
2057 | 2083 | ||
2058 | case 112: | 2084 | case 112: |
2059 | 2085 | ||
2060 | { (yyval) = (yyvsp[(2) - (2)]); ;} | 2086 | { (yyval) = (yyvsp[(2) - (2)]); } |
2061 | break; | 2087 | break; |
2062 | 2088 | ||
2063 | case 113: | 2089 | case 113: |
2064 | 2090 | ||
2065 | { (yyval) = NULL; ;} | 2091 | { (yyval) = NULL; } |
2066 | break; | 2092 | break; |
2067 | 2093 | ||
2068 | case 116: | 2094 | case 116: |
2069 | 2095 | ||
2070 | { (yyval) = (yyvsp[(3) - (3)]); ;} | 2096 | { (yyval) = (yyvsp[(3) - (3)]); } |
2071 | break; | 2097 | break; |
2072 | 2098 | ||
2073 | case 117: | 2099 | case 117: |
2074 | 2100 | ||
2075 | { (yyval) = (yyvsp[(2) - (2)]) ? (yyvsp[(2) - (2)]) : (yyvsp[(1) - (2)]); ;} | 2101 | { (yyval) = (yyvsp[(2) - (2)]) ? (yyvsp[(2) - (2)]) : (yyvsp[(1) - (2)]); } |
2076 | break; | 2102 | break; |
2077 | 2103 | ||
2078 | case 118: | 2104 | case 118: |
2079 | 2105 | ||
2080 | { (yyval) = (yyvsp[(2) - (2)]); ;} | 2106 | { (yyval) = (yyvsp[(2) - (2)]); } |
2081 | break; | 2107 | break; |
2082 | 2108 | ||
2083 | case 120: | 2109 | case 120: |
2084 | 2110 | ||
2085 | { (yyval) = (yyvsp[(2) - (2)]); ;} | 2111 | { (yyval) = (yyvsp[(2) - (2)]); } |
2086 | break; | 2112 | break; |
2087 | 2113 | ||
2088 | case 121: | 2114 | case 121: |
2089 | 2115 | ||
2090 | { (yyval) = NULL; ;} | 2116 | { (yyval) = NULL; } |
2091 | break; | 2117 | break; |
2092 | 2118 | ||
2093 | case 123: | 2119 | case 123: |
2094 | 2120 | ||
2095 | { (yyval) = (yyvsp[(3) - (3)]); ;} | 2121 | { (yyval) = (yyvsp[(3) - (3)]); } |
2096 | break; | 2122 | break; |
2097 | 2123 | ||
2098 | case 124: | 2124 | case 124: |
2099 | 2125 | ||
2100 | { (yyval) = (yyvsp[(4) - (4)]); ;} | 2126 | { (yyval) = (yyvsp[(4) - (4)]); } |
2101 | break; | 2127 | break; |
2102 | 2128 | ||
2103 | case 127: | 2129 | case 127: |
@@ -2105,7 +2131,7 @@ yyreduce: | |||
2105 | { | 2131 | { |
2106 | const char *name = strdup((*(yyvsp[(1) - (1)]))->string); | 2132 | const char *name = strdup((*(yyvsp[(1) - (1)]))->string); |
2107 | add_symbol(name, SYM_ENUM_CONST, NULL, 0); | 2133 | add_symbol(name, SYM_ENUM_CONST, NULL, 0); |
2108 | ;} | 2134 | } |
2109 | break; | 2135 | break; |
2110 | 2136 | ||
2111 | case 128: | 2137 | case 128: |
@@ -2114,28 +2140,39 @@ yyreduce: | |||
2114 | const char *name = strdup((*(yyvsp[(1) - (3)]))->string); | 2140 | const char *name = strdup((*(yyvsp[(1) - (3)]))->string); |
2115 | struct string_list *expr = copy_list_range(*(yyvsp[(3) - (3)]), *(yyvsp[(2) - (3)])); | 2141 | struct string_list *expr = copy_list_range(*(yyvsp[(3) - (3)]), *(yyvsp[(2) - (3)])); |
2116 | add_symbol(name, SYM_ENUM_CONST, expr, 0); | 2142 | add_symbol(name, SYM_ENUM_CONST, expr, 0); |
2117 | ;} | 2143 | } |
2118 | break; | 2144 | break; |
2119 | 2145 | ||
2120 | case 129: | 2146 | case 129: |
2121 | 2147 | ||
2122 | { (yyval) = (yyvsp[(2) - (2)]); ;} | 2148 | { (yyval) = (yyvsp[(2) - (2)]); } |
2123 | break; | 2149 | break; |
2124 | 2150 | ||
2125 | case 130: | 2151 | case 130: |
2126 | 2152 | ||
2127 | { (yyval) = NULL; ;} | 2153 | { (yyval) = NULL; } |
2128 | break; | 2154 | break; |
2129 | 2155 | ||
2130 | case 132: | 2156 | case 132: |
2131 | 2157 | ||
2132 | { export_symbol((*(yyvsp[(3) - (5)]))->string); (yyval) = (yyvsp[(5) - (5)]); ;} | 2158 | { export_symbol((*(yyvsp[(3) - (5)]))->string); (yyval) = (yyvsp[(5) - (5)]); } |
2133 | break; | 2159 | break; |
2134 | 2160 | ||
2135 | 2161 | ||
2136 | 2162 | ||
2137 | default: break; | 2163 | default: break; |
2138 | } | 2164 | } |
2165 | /* User semantic actions sometimes alter yychar, and that requires | ||
2166 | that yytoken be updated with the new translation. We take the | ||
2167 | approach of translating immediately before every use of yytoken. | ||
2168 | One alternative is translating here after every semantic action, | ||
2169 | but that translation would be missed if the semantic action invokes | ||
2170 | YYABORT, YYACCEPT, or YYERROR immediately after altering yychar or | ||
2171 | if it invokes YYBACKUP. In the case of YYABORT or YYACCEPT, an | ||
2172 | incorrect destructor might then be invoked immediately. In the | ||
2173 | case of YYERROR or YYBACKUP, subsequent parser actions might lead | ||
2174 | to an incorrect destructor call or verbose syntax error message | ||
2175 | before the lookahead is translated. */ | ||
2139 | YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc); | 2176 | YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc); |
2140 | 2177 | ||
2141 | YYPOPSTACK (yylen); | 2178 | YYPOPSTACK (yylen); |
@@ -2163,6 +2200,10 @@ yyreduce: | |||
2163 | | yyerrlab -- here on detecting error | | 2200 | | yyerrlab -- here on detecting error | |
2164 | `------------------------------------*/ | 2201 | `------------------------------------*/ |
2165 | yyerrlab: | 2202 | yyerrlab: |
2203 | /* Make sure we have latest lookahead translation. See comments at | ||
2204 | user semantic actions for why this is necessary. */ | ||
2205 | yytoken = yychar == YYEMPTY ? YYEMPTY : YYTRANSLATE (yychar); | ||
2206 | |||
2166 | /* If not already recovering from an error, report this error. */ | 2207 | /* If not already recovering from an error, report this error. */ |
2167 | if (!yyerrstatus) | 2208 | if (!yyerrstatus) |
2168 | { | 2209 | { |
@@ -2170,37 +2211,36 @@ yyerrlab: | |||
2170 | #if ! YYERROR_VERBOSE | 2211 | #if ! YYERROR_VERBOSE |
2171 | yyerror (YY_("syntax error")); | 2212 | yyerror (YY_("syntax error")); |
2172 | #else | 2213 | #else |
2214 | # define YYSYNTAX_ERROR yysyntax_error (&yymsg_alloc, &yymsg, \ | ||
2215 | yyssp, yytoken) | ||
2173 | { | 2216 | { |
2174 | YYSIZE_T yysize = yysyntax_error (0, yystate, yychar); | 2217 | char const *yymsgp = YY_("syntax error"); |
2175 | if (yymsg_alloc < yysize && yymsg_alloc < YYSTACK_ALLOC_MAXIMUM) | 2218 | int yysyntax_error_status; |
2176 | { | 2219 | yysyntax_error_status = YYSYNTAX_ERROR; |
2177 | YYSIZE_T yyalloc = 2 * yysize; | 2220 | if (yysyntax_error_status == 0) |
2178 | if (! (yysize <= yyalloc && yyalloc <= YYSTACK_ALLOC_MAXIMUM)) | 2221 | yymsgp = yymsg; |
2179 | yyalloc = YYSTACK_ALLOC_MAXIMUM; | 2222 | else if (yysyntax_error_status == 1) |
2180 | if (yymsg != yymsgbuf) | 2223 | { |
2181 | YYSTACK_FREE (yymsg); | 2224 | if (yymsg != yymsgbuf) |
2182 | yymsg = (char *) YYSTACK_ALLOC (yyalloc); | 2225 | YYSTACK_FREE (yymsg); |
2183 | if (yymsg) | 2226 | yymsg = (char *) YYSTACK_ALLOC (yymsg_alloc); |
2184 | yymsg_alloc = yyalloc; | 2227 | if (!yymsg) |
2185 | else | 2228 | { |
2186 | { | 2229 | yymsg = yymsgbuf; |
2187 | yymsg = yymsgbuf; | 2230 | yymsg_alloc = sizeof yymsgbuf; |
2188 | yymsg_alloc = sizeof yymsgbuf; | 2231 | yysyntax_error_status = 2; |
2189 | } | 2232 | } |
2190 | } | 2233 | else |
2191 | 2234 | { | |
2192 | if (0 < yysize && yysize <= yymsg_alloc) | 2235 | yysyntax_error_status = YYSYNTAX_ERROR; |
2193 | { | 2236 | yymsgp = yymsg; |
2194 | (void) yysyntax_error (yymsg, yystate, yychar); | 2237 | } |
2195 | yyerror (yymsg); | 2238 | } |
2196 | } | 2239 | yyerror (yymsgp); |
2197 | else | 2240 | if (yysyntax_error_status == 2) |
2198 | { | 2241 | goto yyexhaustedlab; |
2199 | yyerror (YY_("syntax error")); | ||
2200 | if (yysize != 0) | ||
2201 | goto yyexhaustedlab; | ||
2202 | } | ||
2203 | } | 2242 | } |
2243 | # undef YYSYNTAX_ERROR | ||
2204 | #endif | 2244 | #endif |
2205 | } | 2245 | } |
2206 | 2246 | ||
@@ -2259,7 +2299,7 @@ yyerrlab1: | |||
2259 | for (;;) | 2299 | for (;;) |
2260 | { | 2300 | { |
2261 | yyn = yypact[yystate]; | 2301 | yyn = yypact[yystate]; |
2262 | if (yyn != YYPACT_NINF) | 2302 | if (!yypact_value_is_default (yyn)) |
2263 | { | 2303 | { |
2264 | yyn += YYTERROR; | 2304 | yyn += YYTERROR; |
2265 | if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR) | 2305 | if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR) |
@@ -2318,8 +2358,13 @@ yyexhaustedlab: | |||
2318 | 2358 | ||
2319 | yyreturn: | 2359 | yyreturn: |
2320 | if (yychar != YYEMPTY) | 2360 | if (yychar != YYEMPTY) |
2321 | yydestruct ("Cleanup: discarding lookahead", | 2361 | { |
2322 | yytoken, &yylval); | 2362 | /* Make sure we have latest lookahead translation. See comments at |
2363 | user semantic actions for why this is necessary. */ | ||
2364 | yytoken = YYTRANSLATE (yychar); | ||
2365 | yydestruct ("Cleanup: discarding lookahead", | ||
2366 | yytoken, &yylval); | ||
2367 | } | ||
2323 | /* Do not reclaim the symbols of the rule which action triggered | 2368 | /* Do not reclaim the symbols of the rule which action triggered |
2324 | this YYABORT or YYACCEPT. */ | 2369 | this YYABORT or YYACCEPT. */ |
2325 | YYPOPSTACK (yylen); | 2370 | YYPOPSTACK (yylen); |
diff --git a/scripts/genksyms/parse.tab.h_shipped b/scripts/genksyms/parse.tab.h_shipped index 350c2b403e2..93240a3cdec 100644 --- a/scripts/genksyms/parse.tab.h_shipped +++ b/scripts/genksyms/parse.tab.h_shipped | |||
@@ -1,9 +1,8 @@ | |||
1 | /* A Bison parser, made by GNU Bison 2.4.3. */ | 1 | /* A Bison parser, made by GNU Bison 2.5. */ |
2 | 2 | ||
3 | /* Skeleton interface for Bison's Yacc-like parsers in C | 3 | /* Bison interface for Yacc-like parsers in C |
4 | 4 | ||
5 | Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006, | 5 | Copyright (C) 1984, 1989-1990, 2000-2011 Free Software Foundation, Inc. |
6 | 2009, 2010 Free Software Foundation, Inc. | ||
7 | 6 | ||
8 | This program is free software: you can redistribute it and/or modify | 7 | This program is free software: you can redistribute it and/or modify |
9 | it under the terms of the GNU General Public License as published by | 8 | it under the terms of the GNU General Public License as published by |
diff --git a/scripts/genksyms/parse.y b/scripts/genksyms/parse.y index ba5c242866c..23c39998ad8 100644 --- a/scripts/genksyms/parse.y +++ b/scripts/genksyms/parse.y | |||
@@ -51,6 +51,25 @@ remove_list(struct string_list **pb, struct string_list **pe) | |||
51 | free_list(b, e); | 51 | free_list(b, e); |
52 | } | 52 | } |
53 | 53 | ||
54 | /* Record definition of a struct/union/enum */ | ||
55 | static void record_compound(struct string_list **keyw, | ||
56 | struct string_list **ident, | ||
57 | struct string_list **body, | ||
58 | enum symbol_type type) | ||
59 | { | ||
60 | struct string_list *b = *body, *i = *ident, *r; | ||
61 | |||
62 | if (i->in_source_file) { | ||
63 | remove_node(keyw); | ||
64 | (*ident)->tag = type; | ||
65 | remove_list(body, ident); | ||
66 | return; | ||
67 | } | ||
68 | r = copy_node(i); r->tag = type; | ||
69 | r->next = (*keyw)->next; *body = r; (*keyw)->next = NULL; | ||
70 | add_symbol(i->string, type, b, is_extern); | ||
71 | } | ||
72 | |||
54 | %} | 73 | %} |
55 | 74 | ||
56 | %token ASM_KEYW | 75 | %token ASM_KEYW |
@@ -215,26 +234,11 @@ type_specifier: | |||
215 | 234 | ||
216 | /* Full definitions of an s/u/e. Record it. */ | 235 | /* Full definitions of an s/u/e. Record it. */ |
217 | | STRUCT_KEYW IDENT class_body | 236 | | STRUCT_KEYW IDENT class_body |
218 | { struct string_list *s = *$3, *i = *$2, *r; | 237 | { record_compound($1, $2, $3, SYM_STRUCT); $$ = $3; } |
219 | r = copy_node(i); r->tag = SYM_STRUCT; | ||
220 | r->next = (*$1)->next; *$3 = r; (*$1)->next = NULL; | ||
221 | add_symbol(i->string, SYM_STRUCT, s, is_extern); | ||
222 | $$ = $3; | ||
223 | } | ||
224 | | UNION_KEYW IDENT class_body | 238 | | UNION_KEYW IDENT class_body |
225 | { struct string_list *s = *$3, *i = *$2, *r; | 239 | { record_compound($1, $2, $3, SYM_UNION); $$ = $3; } |
226 | r = copy_node(i); r->tag = SYM_UNION; | ||
227 | r->next = (*$1)->next; *$3 = r; (*$1)->next = NULL; | ||
228 | add_symbol(i->string, SYM_UNION, s, is_extern); | ||
229 | $$ = $3; | ||
230 | } | ||
231 | | ENUM_KEYW IDENT enum_body | 240 | | ENUM_KEYW IDENT enum_body |
232 | { struct string_list *s = *$3, *i = *$2, *r; | 241 | { record_compound($1, $2, $3, SYM_ENUM); $$ = $3; } |
233 | r = copy_node(i); r->tag = SYM_ENUM; | ||
234 | r->next = (*$1)->next; *$3 = r; (*$1)->next = NULL; | ||
235 | add_symbol(i->string, SYM_ENUM, s, is_extern); | ||
236 | $$ = $3; | ||
237 | } | ||
238 | /* | 242 | /* |
239 | * Anonymous enum definition. Tell add_symbol() to restart its counter. | 243 | * Anonymous enum definition. Tell add_symbol() to restart its counter. |
240 | */ | 244 | */ |