1 /* A Bison parser, made from parse-gram.y
4 #define YYBISON 1 /* Identify Bison output. */
6 #define yyparse gram_parse
8 #define yyerror gram_error
9 #define yylval gram_lval
10 #define yychar gram_char
11 #define yydebug gram_debug
12 #define yynerrs gram_nerrs
13 #define YYLSP_NEEDED 1
17 # define CHARACTER 258
19 # define PERCENT_TOKEN 260
20 # define PERCENT_NTERM 261
21 # define PERCENT_TYPE 262
22 # define PERCENT_UNION 263
23 # define PERCENT_EXPECT 264
24 # define PERCENT_START 265
25 # define PERCENT_LEFT 266
26 # define PERCENT_RIGHT 267
27 # define PERCENT_NONASSOC 268
28 # define PERCENT_PREC 269
29 # define PERCENT_VERBOSE 270
30 # define PERCENT_ERROR_VERBOSE 271
31 # define PERCENT_OUTPUT 272
32 # define PERCENT_FILE_PREFIX 273
33 # define PERCENT_NAME_PREFIX 274
34 # define PERCENT_DEFINE 275
35 # define PERCENT_PURE_PARSER 276
36 # define PERCENT_DEFINES 277
37 # define PERCENT_YACC 278
38 # define PERCENT_DEBUG 279
39 # define PERCENT_LOCATIONS 280
40 # define PERCENT_NO_LINES 281
41 # define PERCENT_SKELETON 282
42 # define PERCENT_TOKEN_TABLE 283
45 # define SEMICOLON 286
49 # define PERCENT_PERCENT 290
52 # define BRACED_CODE 293
54 #line 31 "parse-gram.y"
57 #include "muscle_tab.h"
63 #include "conflicts.h"
65 #define YYERROR_VERBOSE 1
67 /* Pass the control structure to YYPARSE and YYLEX. */
68 #define YYPARSE_PARAM gram_control
69 #define YYLEX_PARAM gram_control
70 /* YYPARSE receives GRAM_CONTROL as a void *. Provide a
71 correctly typed access to it. */
72 #define yycontrol ((gram_control_t *) gram_control)
74 /* Request detailed parse error messages, and pass them to
77 #define yyerror(Msg) \
78 gram_error (yycontrol, &yylloc, Msg)
80 /* When debugging our pure parser, we want to see values and locations
82 #define YYPRINT(File, Type, Value) \
83 yyprint (File, &yylloc, Type, &Value)
84 static void yyprint (FILE *file
, const yyltype
*loc
,
85 int type
, const yystype
*value
);
87 symbol_class current_class
= unknown_sym
;
88 char *current_type
= 0;
89 symbol_t
*current_lhs
;
90 associativity current_assoc
;
93 #line 72 "parse-gram.y"
102 # define YYSTYPE yystype
103 # define YYSTYPE_IS_TRIVIAL 1
107 typedef struct yyltype
116 # define YYLTYPE yyltype
117 # define YYLTYPE_IS_TRIVIAL 1
127 #define YYFLAG -32768
130 /* YYTRANSLATE(YYLEX) -- Bison token number corresponding to YYLEX. */
131 #define YYTRANSLATE(x) ((unsigned)(x) <= 293 ? yytranslate[x] : 68)
133 /* YYTRANSLATE[YYLEX] -- Bison token number corresponding to YYLEX. */
134 static const char yytranslate
[] =
136 0, 2, 2, 2, 2, 2, 2, 2, 2, 2,
137 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
138 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
139 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
140 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
141 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
142 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
143 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
144 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
145 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
146 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
147 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
148 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
149 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
150 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
151 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
152 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
153 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
154 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
155 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
156 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
157 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
158 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
159 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
160 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
161 2, 2, 2, 2, 2, 2, 1, 4, 5, 6,
162 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
163 17, 18, 19, 20, 21, 22, 23, 24, 25, 26,
164 27, 28, 29, 30, 31, 32, 33, 34, 35, 36,
169 static const short yyprhs
[] =
171 0, 0, 1, 7, 8, 11, 13, 15, 17, 21,
172 23, 25, 28, 32, 34, 38, 40, 44, 46, 49,
173 51, 53, 55, 57, 58, 62, 65, 66, 70, 71,
174 76, 80, 81, 86, 88, 90, 92, 93, 95, 97,
175 100, 102, 105, 107, 109, 112, 115, 119, 121, 124,
176 126, 129, 130, 136, 138, 142, 143, 146, 149, 153,
177 155, 157, 159, 161, 163, 165, 166, 169, 170
179 static const short yyrhs
[] =
181 -1, 42, 43, 37, 57, 66, 0, 0, 43, 44,
182 0, 45, 0, 38, 0, 26, 0, 22, 65, 65,
183 0, 24, 0, 18, 0, 11, 6, 0, 20, 32,
184 65, 0, 27, 0, 21, 32, 65, 0, 28, 0,
185 19, 32, 65, 0, 23, 0, 29, 65, 0, 30,
186 0, 17, 0, 25, 0, 49, 0, 0, 8, 46,
187 56, 0, 12, 62, 0, 0, 7, 47, 56, 0,
188 0, 9, 31, 48, 53, 0, 10, 40, 67, 0,
189 0, 51, 52, 50, 54, 0, 13, 0, 14, 0,
190 15, 0, 0, 31, 0, 36, 0, 53, 36, 0,
191 62, 0, 54, 62, 0, 31, 0, 36, 0, 36,
192 6, 0, 36, 64, 0, 36, 6, 64, 0, 55,
193 0, 56, 55, 0, 58, 0, 57, 58, 0, 0,
194 36, 34, 59, 60, 33, 0, 61, 0, 60, 35,
195 61, 0, 0, 61, 62, 0, 61, 63, 0, 61,
196 16, 62, 0, 36, 0, 64, 0, 5, 0, 40,
197 0, 4, 0, 4, 0, 0, 37, 39, 0, 0,
204 /* YYRLINE[YYN] -- source line where rule number YYN was defined. */
205 static const short yyrline
[] =
207 0, 131, 131, 139, 141, 144, 146, 150, 151, 152,
208 153, 154, 155, 156, 157, 158, 159, 160, 161, 162,
209 163, 164, 167, 169, 169, 174, 178, 178, 183, 183,
210 187, 195, 195, 202, 204, 205, 208, 210, 214, 216,
211 220, 226, 235, 240, 245, 251, 257, 267, 270, 274,
212 276, 279, 279, 284, 286, 289, 292, 294, 296, 300,
213 302, 303, 306, 312, 321, 329, 334, 340, 342
218 #if (YYDEBUG) || defined YYERROR_VERBOSE
220 /* YYTNAME[TOKEN_NUM] -- String name of the token TOKEN_NUM. */
221 static const char *const yytname
[] =
223 "$", "error", "$undefined.", "\"end of string\"", "STRING", "CHARACTER",
224 "INT", "\"%token\"", "\"%nterm\"", "\"%type\"", "\"%union\"",
225 "\"%expect\"", "\"%start\"", "\"%left\"", "\"%right\"", "\"%nonassoc\"",
226 "\"%prec\"", "\"%verbose\"", "\"%error-verbose\"", "\"%output\"",
227 "\"%file-prefix\"", "\"%name-prefix\"", "\"%define\"",
228 "\"%pure-parser\"", "\"%defines\"", "\"%yacc\"", "\"%debug\"",
229 "\"%locations\"", "\"%no-lines\"", "\"%skeleton\"", "\"%token-table\"",
230 "TYPE", "\"=\"", "\";\"", "\":\"", "\"|\"", "\"identifier\"", "\"%%\"",
231 "PROLOGUE", "EPILOGUE", "BRACED_CODE", "input", "@1", "directives",
232 "directive", "grammar_directives", "@2", "@3", "@4",
233 "precedence_directives", "@5", "precedence_directive", "type.opt",
234 "nterms_to_type.1", "terms_to_prec.1", "symbol_def", "symbol_defs.1",
235 "gram", "rules", "@6", "rhses.1", "rhs", "symbol", "action",
236 "string_as_id", "string_content", "epilogue.opt", "semi_colon_opt", 0
240 /* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */
241 static const short yyr1
[] =
243 0, 42, 41, 43, 43, 44, 44, 44, 44, 44,
244 44, 44, 44, 44, 44, 44, 44, 44, 44, 44,
245 44, 44, 45, 46, 45, 45, 47, 45, 48, 45,
246 45, 50, 49, 51, 51, 51, 52, 52, 53, 53,
247 54, 54, 55, 55, 55, 55, 55, 56, 56, 57,
248 57, 59, 58, 60, 60, 61, 61, 61, 61, 62,
249 62, 62, 63, 64, 65, 66, 66, 67, 67
252 /* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
253 static const short yyr2
[] =
255 0, 0, 5, 0, 2, 1, 1, 1, 3, 1,
256 1, 2, 3, 1, 3, 1, 3, 1, 2, 1,
257 1, 1, 1, 0, 3, 2, 0, 3, 0, 4,
258 3, 0, 4, 1, 1, 1, 0, 1, 1, 2,
259 1, 2, 1, 1, 2, 2, 3, 1, 2, 1,
260 2, 0, 5, 1, 3, 0, 2, 2, 3, 1,
261 1, 1, 1, 1, 1, 0, 2, 0, 1
264 /* YYDEFACT[S] -- default rule to reduce with in state S when YYTABLE
265 doesn't specify something else to do. Zero means the default is an
267 static const short yydefact
[] =
269 1, 3, 0, 26, 23, 0, 0, 0, 0, 33,
270 34, 35, 20, 10, 0, 0, 0, 0, 17, 9,
271 21, 7, 13, 15, 0, 19, 0, 6, 4, 5,
272 22, 36, 0, 0, 28, 67, 11, 63, 61, 59,
273 25, 60, 0, 0, 0, 64, 0, 18, 0, 65,
274 49, 37, 31, 42, 43, 47, 27, 24, 0, 68,
275 30, 16, 12, 14, 8, 51, 0, 50, 2, 0,
276 44, 45, 48, 38, 29, 55, 66, 32, 40, 46,
277 39, 0, 53, 41, 52, 55, 0, 62, 56, 57,
281 static const short yydefgoto
[] =
283 92, 1, 2, 28, 29, 33, 32, 58, 30, 69,
284 31, 52, 74, 77, 55, 56, 49, 50, 75, 81,
285 82, 88, 89, 41, 46, 68, 60
288 static const short yypact
[] =
290 -32768,-32768, 72,-32768,-32768, -22, -29, 8, -1,-32768,
291 -32768,-32768,-32768,-32768, -16, -14, -11, 22,-32768,-32768,
292 -32768,-32768,-32768,-32768, 22,-32768, -6,-32768,-32768,-32768,
293 -32768, 0, -24, -24,-32768, 1,-32768,-32768,-32768,-32768,
294 -32768,-32768, 22, 22, 22,-32768, 22,-32768, -2, -17,
295 -32768,-32768,-32768,-32768, 4,-32768, -24, -24, 2,-32768,
296 -32768,-32768,-32768,-32768,-32768,-32768, 3,-32768,-32768, -1,
297 32,-32768,-32768,-32768, 5,-32768,-32768, -1,-32768,-32768,
298 -32768, -18, -3,-32768,-32768,-32768, -1,-32768,-32768,-32768,
299 -3,-32768, 39, 40,-32768
302 static const short yypgoto
[] =
304 -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
305 -32768,-32768,-32768,-32768, -28, 10,-32768, -5,-32768,-32768,
306 -40, -8,-32768, -48, -19,-32768,-32768
313 static const short yytable
[] =
315 40, 37, 38, 37, 38, 47, 71, 53, 37, 34,
316 70, 35, 54, 86, 36, 84, 42, 85, 43, 48,
317 66, 44, 79, 61, 62, 63, 45, 64, 72, 72,
318 48, 51, 65, 39, 59, 39, 37, 87, 73, 93,
319 94, 80, 76, 57, 67, 90, 0, 0, 0, 0,
320 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
321 0, 78, 0, 0, 0, 0, 0, 0, 0, 83,
322 0, 0, 0, 0, 0, 0, 0, 0, 91, 3,
323 4, 5, 6, 7, 8, 9, 10, 11, 0, 12,
324 13, 14, 15, 16, 17, 18, 19, 20, 21, 22,
325 23, 24, 25, 0, 0, 0, 0, 0, 0, 26,
329 static const short yycheck
[] =
331 8, 4, 5, 4, 5, 24, 54, 31, 4, 31,
332 6, 40, 36, 16, 6, 33, 32, 35, 32, 36,
333 37, 32, 70, 42, 43, 44, 4, 46, 56, 57,
334 36, 31, 34, 36, 33, 36, 4, 40, 36, 0,
335 0, 36, 39, 33, 49, 85, -1, -1, -1, -1,
336 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
337 -1, 69, -1, -1, -1, -1, -1, -1, -1, 77,
338 -1, -1, -1, -1, -1, -1, -1, -1, 86, 7,
339 8, 9, 10, 11, 12, 13, 14, 15, -1, 17,
340 18, 19, 20, 21, 22, 23, 24, 25, 26, 27,
341 28, 29, 30, -1, -1, -1, -1, -1, -1, 37,
346 /* -*-C-*- Note some compilers choke on comments on `#line' lines. */
347 #line 3 "/usr/share/bison/bison.simple"
349 /* Skeleton output parser for bison,
351 Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002 Free Software
354 This program is free software; you can redistribute it and/or modify
355 it under the terms of the GNU General Public License as published by
356 the Free Software Foundation; either version 2, or (at your option)
359 This program is distributed in the hope that it will be useful,
360 but WITHOUT ANY WARRANTY; without even the implied warranty of
361 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
362 GNU General Public License for more details.
364 You should have received a copy of the GNU General Public License
365 along with this program; if not, write to the Free Software
366 Foundation, Inc., 59 Temple Place - Suite 330,
367 Boston, MA 02111-1307, USA. */
369 /* As a special exception, when this file is copied by Bison into a
370 Bison output file, you may use that output file without restriction.
371 This special exception was added by the Free Software Foundation
372 in version 1.24 of Bison. */
374 /* This is the parser code that is written into each bison parser when
375 the %semantic_parser declaration is not specified in the grammar.
376 It was written by Richard Stallman by simplifying the hairy parser
377 used when %semantic_parser is specified. */
379 /* All symbols defined below should begin with yy or YY, to avoid
380 infringing on user name space. This should be done even for local
381 variables, as they might otherwise be expanded by user macros.
382 There are some unavoidable exceptions within include files to
383 define necessary library symbols; they are noted "INFRINGES ON
384 USER NAME SPACE" below. */
386 #if ! defined (yyoverflow) || defined (YYERROR_VERBOSE)
388 /* The parser invokes alloca or malloc; define the necessary symbols. */
390 # if YYSTACK_USE_ALLOCA
391 # define YYSTACK_ALLOC alloca
393 # ifndef YYSTACK_USE_ALLOCA
394 # if defined (alloca) || defined (_ALLOCA_H)
395 # define YYSTACK_ALLOC alloca
398 # define YYSTACK_ALLOC __builtin_alloca
404 # ifdef YYSTACK_ALLOC
405 /* Pacify GCC's `empty if-body' warning. */
406 # define YYSTACK_FREE(Ptr) do { /* empty */; } while (0)
408 # if defined (__STDC__) || defined (__cplusplus)
409 # include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
410 # define YYSIZE_T size_t
412 # define YYSTACK_ALLOC malloc
413 # define YYSTACK_FREE free
415 #endif /* ! defined (yyoverflow) || defined (YYERROR_VERBOSE) */
418 #if (! defined (yyoverflow) \
419 && (! defined (__cplusplus) \
420 || (YYLTYPE_IS_TRIVIAL && YYSTYPE_IS_TRIVIAL)))
422 /* A type that is properly aligned for any stack member. */
432 /* The size of the maximum gap between one aligned stack and the next. */
433 # define YYSTACK_GAP_MAX (sizeof (union yyalloc) - 1)
435 /* The size of an array large to enough to hold all stacks, each with
438 # define YYSTACK_BYTES(N) \
439 ((N) * (sizeof (short) + sizeof (YYSTYPE) + sizeof (YYLTYPE)) \
440 + 2 * YYSTACK_GAP_MAX)
442 # define YYSTACK_BYTES(N) \
443 ((N) * (sizeof (short) + sizeof (YYSTYPE)) \
447 /* Copy COUNT objects from FROM to TO. The source and destination do
451 # define YYCOPY(To, From, Count) \
452 __builtin_memcpy (To, From, (Count) * sizeof (*(From)))
454 # define YYCOPY(To, From, Count) \
457 register YYSIZE_T yyi; \
458 for (yyi = 0; yyi < (Count); yyi++) \
459 (To)[yyi] = (From)[yyi]; \
465 /* Relocate STACK from its old location to the new one. The
466 local variables YYSIZE and YYSTACKSIZE give the old and new number of
467 elements in the stack, and YYPTR gives the new location of the
468 stack. Advance YYPTR to a properly aligned location for the next
470 # define YYSTACK_RELOCATE(Stack) \
473 YYSIZE_T yynewbytes; \
474 YYCOPY (&yyptr->Stack, Stack, yysize); \
475 Stack = &yyptr->Stack; \
476 yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAX; \
477 yyptr += yynewbytes / sizeof (*yyptr); \
484 #if ! defined (YYSIZE_T) && defined (__SIZE_TYPE__)
485 # define YYSIZE_T __SIZE_TYPE__
487 #if ! defined (YYSIZE_T) && defined (size_t)
488 # define YYSIZE_T size_t
490 #if ! defined (YYSIZE_T)
491 # if defined (__STDC__) || defined (__cplusplus)
492 # include <stddef.h> /* INFRINGES ON USER NAME SPACE */
493 # define YYSIZE_T size_t
496 #if ! defined (YYSIZE_T)
497 # define YYSIZE_T unsigned int
500 #define yyerrok (yyerrstatus = 0)
501 #define yyclearin (yychar = YYEMPTY)
504 #define YYACCEPT goto yyacceptlab
505 #define YYABORT goto yyabortlab
506 #define YYERROR goto yyerrlab1
507 /* Like YYERROR except do call yyerror. This remains here temporarily
508 to ease the transition to the new meaning of YYERROR, for GCC.
509 Once GCC version 2 has supplanted version 1, this can go. */
510 #define YYFAIL goto yyerrlab
511 #define YYRECOVERING() (!!yyerrstatus)
512 #define YYBACKUP(Token, Value) \
514 if (yychar == YYEMPTY && yylen == 1) \
518 yychar1 = YYTRANSLATE (yychar); \
524 yyerror ("syntax error: cannot back up"); \
530 #define YYERRCODE 256
533 /* YYLLOC_DEFAULT -- Compute the default location (before the actions
536 When YYLLOC_DEFAULT is run, CURRENT is set the location of the
537 first token. By default, to implement support for ranges, extend
538 its range to the last symbol. */
540 #ifndef YYLLOC_DEFAULT
541 # define YYLLOC_DEFAULT(Current, Rhs, N) \
542 Current.last_line = Rhs[N].last_line; \
543 Current.last_column = Rhs[N].last_column;
547 /* YYLEX -- calling `yylex' with the right arguments. */
552 # define YYLEX yylex (&yylval, &yylloc, YYLEX_PARAM)
554 # define YYLEX yylex (&yylval, &yylloc)
556 # else /* !YYLSP_NEEDED */
558 # define YYLEX yylex (&yylval, YYLEX_PARAM)
560 # define YYLEX yylex (&yylval)
562 # endif /* !YYLSP_NEEDED */
564 # define YYLEX yylex ()
568 /* Enable debugging if requested. */
572 # include <stdio.h> /* INFRINGES ON USER NAME SPACE */
573 # define YYFPRINTF fprintf
576 # define YYDPRINTF(Args) \
581 /* Nonzero means print parse trace. It is left uninitialized so that
582 multiple parsers can coexist. */
585 # define YYDPRINTF(Args)
586 #endif /* !YYDEBUG */
588 /* YYINITDEPTH -- initial size of the parser's stacks. */
590 # define YYINITDEPTH 200
593 /* YYMAXDEPTH -- maximum size the stacks can grow to (effective only
594 if the built-in stack extension method is used).
596 Do not make this value too large; the results are undefined if
597 SIZE_MAX < YYSTACK_BYTES (YYMAXDEPTH)
598 evaluated with infinite-precision integer arithmetic. */
605 # define YYMAXDEPTH 10000
608 #ifdef YYERROR_VERBOSE
611 # if defined (__GLIBC__) && defined (_STRING_H)
612 # define yystrlen strlen
614 /* Return the length of YYSTR. */
616 # if defined (__STDC__) || defined (__cplusplus)
617 yystrlen (const char *yystr
)
623 register const char *yys
= yystr
;
625 while (*yys
++ != '\0')
628 return yys
- yystr
- 1;
634 # if defined (__GLIBC__) && defined (_STRING_H) && defined (_GNU_SOURCE)
635 # define yystpcpy stpcpy
637 /* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in
640 # if defined (__STDC__) || defined (__cplusplus)
641 yystpcpy (char *yydest
, const char *yysrc
)
643 yystpcpy (yydest
, yysrc
)
648 register char *yyd
= yydest
;
649 register const char *yys
= yysrc
;
651 while ((*yyd
++ = *yys
++) != '\0')
660 #line 315 "/usr/share/bison/bison.simple"
663 /* The user can define YYPARSE_PARAM as the name of an argument to be passed
664 into yyparse. The argument should have type void *.
665 It should actually point to an object.
666 Grammar actions can access the variable by casting it
667 to the proper pointer type. */
670 # if defined (__STDC__) || defined (__cplusplus)
671 # define YYPARSE_PARAM_ARG void *YYPARSE_PARAM
672 # define YYPARSE_PARAM_DECL
674 # define YYPARSE_PARAM_ARG YYPARSE_PARAM
675 # define YYPARSE_PARAM_DECL void *YYPARSE_PARAM;
677 #else /* !YYPARSE_PARAM */
678 # define YYPARSE_PARAM_ARG
679 # define YYPARSE_PARAM_DECL
680 #endif /* !YYPARSE_PARAM */
682 /* Prevent warning if -Wstrict-prototypes. */
684 # ifdef YYPARSE_PARAM
685 int yyparse (void *);
691 /* YY_DECL_VARIABLES -- depending whether we use a pure parser,
692 variables are global, or local to YYPARSE. */
694 #define YY_DECL_NON_LSP_VARIABLES \
695 /* The lookahead symbol. */ \
698 /* The semantic value of the lookahead symbol. */ \
701 /* Number of parse errors so far. */ \
705 # define YY_DECL_VARIABLES \
706 YY_DECL_NON_LSP_VARIABLES \
708 /* Location data for the lookahead symbol. */ \
711 # define YY_DECL_VARIABLES \
712 YY_DECL_NON_LSP_VARIABLES
716 /* If nonreentrant, generate the variables here. */
723 yyparse (YYPARSE_PARAM_ARG
)
726 /* If reentrant, generate the variables here. */
731 register int yystate
;
734 /* Number of tokens to shift before error messages enabled. */
736 /* Lookahead token as an internal (translated) token number. */
739 /* Three stacks and their tools:
740 `yyss': related to states,
741 `yyvs': related to semantic values,
742 `yyls': related to locations.
744 Refer to the stacks thru separate pointers, to allow yyoverflow
745 to reallocate them elsewhere. */
747 /* The state stack. */
748 short yyssa
[YYINITDEPTH
];
750 register short *yyssp
;
752 /* The semantic value stack. */
753 YYSTYPE yyvsa
[YYINITDEPTH
];
754 YYSTYPE
*yyvs
= yyvsa
;
755 register YYSTYPE
*yyvsp
;
758 /* The location stack. */
759 YYLTYPE yylsa
[YYINITDEPTH
];
760 YYLTYPE
*yyls
= yylsa
;
765 # define YYPOPSTACK (yyvsp--, yyssp--, yylsp--)
767 # define YYPOPSTACK (yyvsp--, yyssp--)
770 YYSIZE_T yystacksize
= YYINITDEPTH
;
773 /* The variables used to return semantic value and location from the
780 /* When reducing, the number of symbols on the RHS of the reduced
784 YYDPRINTF ((stderr
, "Starting parse\n"));
789 yychar
= YYEMPTY
; /* Cause a token to be read. */
791 /* Initialize stack pointers.
792 Waste one element of value and location stack
793 so that they stay on the same level as the state stack.
794 The wasted elements are never initialized. */
803 /*------------------------------------------------------------.
804 | yynewstate -- Push a new state, which is found in yystate. |
805 `------------------------------------------------------------*/
807 /* In all cases, when you get here, the value and location stacks
808 have just been pushed. so pushing a state here evens the stacks.
815 if (yyssp
>= yyss
+ yystacksize
- 1)
817 /* Get the current used size of the three stacks, in elements. */
818 YYSIZE_T yysize
= yyssp
- yyss
+ 1;
822 /* Give user a chance to reallocate the stack. Use copies of
823 these so that the &'s don't force the real ones into
825 YYSTYPE
*yyvs1
= yyvs
;
828 /* Each stack pointer address is followed by the size of the
829 data in use in that stack, in bytes. */
831 YYLTYPE
*yyls1
= yyls
;
832 /* This used to be a conditional around just the two extra args,
833 but that might be undefined if yyoverflow is a macro. */
834 yyoverflow ("parser stack overflow",
835 &yyss1
, yysize
* sizeof (*yyssp
),
836 &yyvs1
, yysize
* sizeof (*yyvsp
),
837 &yyls1
, yysize
* sizeof (*yylsp
),
841 yyoverflow ("parser stack overflow",
842 &yyss1
, yysize
* sizeof (*yyssp
),
843 &yyvs1
, yysize
* sizeof (*yyvsp
),
849 #else /* no yyoverflow */
850 # ifndef YYSTACK_RELOCATE
853 /* Extend the stack our own way. */
854 if (yystacksize
>= YYMAXDEPTH
)
857 if (yystacksize
> YYMAXDEPTH
)
858 yystacksize
= YYMAXDEPTH
;
862 union yyalloc
*yyptr
=
863 (union yyalloc
*) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize
));
866 YYSTACK_RELOCATE (yyss
);
867 YYSTACK_RELOCATE (yyvs
);
869 YYSTACK_RELOCATE (yyls
);
871 # undef YYSTACK_RELOCATE
873 YYSTACK_FREE (yyss1
);
876 #endif /* no yyoverflow */
878 yyssp
= yyss
+ yysize
- 1;
879 yyvsp
= yyvs
+ yysize
- 1;
881 yylsp
= yyls
+ yysize
- 1;
884 YYDPRINTF ((stderr
, "Stack size increased to %lu\n",
885 (unsigned long int) yystacksize
));
887 if (yyssp
>= yyss
+ yystacksize
- 1)
891 YYDPRINTF ((stderr
, "Entering state %d\n", yystate
));
901 /* Do appropriate processing given the current state. */
902 /* Read a lookahead token if we need one and don't already have one. */
905 /* First try to decide what to do without reference to lookahead token. */
907 yyn
= yypact
[yystate
];
911 /* Not known => get a lookahead token if don't already have one. */
913 /* yychar is either YYEMPTY or YYEOF
914 or a valid token in external form. */
916 if (yychar
== YYEMPTY
)
918 YYDPRINTF ((stderr
, "Reading a token: "));
922 /* Convert token to internal form (in yychar1) for indexing tables with */
924 if (yychar
<= 0) /* This means end of input. */
927 yychar
= YYEOF
; /* Don't call YYLEX any more */
929 YYDPRINTF ((stderr
, "Now at end of input.\n"));
933 yychar1
= YYTRANSLATE (yychar
);
936 /* We have to keep this `#if YYDEBUG', since we use variables
937 which are defined only if `YYDEBUG' is set. */
940 YYFPRINTF (stderr
, "Next token is %d (%s",
941 yychar
, yytname
[yychar1
]);
942 /* Give the individual parser a way to print the precise
943 meaning of a token, for further debugging info. */
945 YYPRINT (stderr
, yychar
, yylval
);
947 YYFPRINTF (stderr
, ")\n");
953 if (yyn
< 0 || yyn
> YYLAST
|| yycheck
[yyn
] != yychar1
)
958 /* yyn is what to do for this token type in this state.
959 Negative => reduce, -yyn is rule number.
960 Positive => shift, yyn is new state.
961 New state is final state => don't bother to shift,
963 0, or most negative number => error. */
978 /* Shift the lookahead token. */
979 YYDPRINTF ((stderr
, "Shifting token %d (%s), ",
980 yychar
, yytname
[yychar1
]));
982 /* Discard the token being shifted unless it is eof. */
991 /* Count tokens shifted since error; after three, turn off error
1000 /*-----------------------------------------------------------.
1001 | yydefault -- do the default action for the current state. |
1002 `-----------------------------------------------------------*/
1004 yyn
= yydefact
[yystate
];
1010 /*-----------------------------.
1011 | yyreduce -- Do a reduction. |
1012 `-----------------------------*/
1014 /* yyn is the number of a rule to reduce with. */
1017 /* If YYLEN is nonzero, implement the default value of the action:
1020 Otherwise, the following line sets YYVAL to the semantic value of
1021 the lookahead token. This behavior is undocumented and Bison
1022 users should not rely upon it. Assigning to YYVAL
1023 unconditionally makes the parser a bit smaller, and it avoids a
1024 GCC warning that YYVAL may be used uninitialized. */
1025 yyval
= yyvsp
[1-yylen
];
1028 /* Similarly for the default location. Let the user run additional
1029 commands if for instance locations are ranges. */
1030 yyloc
= yylsp
[1-yylen
];
1031 YYLLOC_DEFAULT (yyloc
, (yylsp
- yylen
), yylen
);
1035 /* We have to keep this `#if YYDEBUG', since we use variables which
1036 are defined only if `YYDEBUG' is set. */
1041 YYFPRINTF (stderr
, "Reducing via rule %d (line %d), ",
1044 /* Print the symbols being reduced, and their result. */
1045 for (yyi
= yyprhs
[yyn
]; yyrhs
[yyi
] > 0; yyi
++)
1046 YYFPRINTF (stderr
, "%s ", yytname
[yyrhs
[yyi
]]);
1047 YYFPRINTF (stderr
, " -> %s\n", yytname
[yyr1
[yyn
]]);
1054 #line 131 "parse-gram.y"
1055 { LOCATION_RESET (yylloc
); }
1058 #line 133 "parse-gram.y"
1060 yycontrol
->errcode
= 0;
1061 epilogue_set (yyvsp
[0].string
, yylsp
[0].first_line
);
1065 #line 147 "parse-gram.y"
1067 prologue_augment (yyvsp
[0].string
, yylsp
[0].first_line
);
1071 #line 150 "parse-gram.y"
1075 #line 151 "parse-gram.y"
1076 { muscle_insert (yyvsp
[-1].string
, yyvsp
[0].string
); }
1079 #line 152 "parse-gram.y"
1080 { defines_flag
= 1; }
1083 #line 153 "parse-gram.y"
1084 { error_verbose
= 1; }
1087 #line 154 "parse-gram.y"
1088 { expected_conflicts
= yyvsp
[0].integer
; }
1091 #line 155 "parse-gram.y"
1092 { spec_file_prefix
= yyvsp
[0].string
; }
1095 #line 156 "parse-gram.y"
1096 { locations_flag
= 1; }
1099 #line 157 "parse-gram.y"
1100 { spec_name_prefix
= yyvsp
[0].string
; }
1103 #line 158 "parse-gram.y"
1104 { no_lines_flag
= 1; }
1107 #line 159 "parse-gram.y"
1108 { spec_outfile
= yyvsp
[0].string
; }
1111 #line 160 "parse-gram.y"
1112 { pure_parser
= 1; }
1115 #line 161 "parse-gram.y"
1116 { skeleton
= yyvsp
[0].string
; }
1119 #line 162 "parse-gram.y"
1120 { token_table_flag
= 1; }
1123 #line 163 "parse-gram.y"
1124 { report_flag
= 1; }
1127 #line 164 "parse-gram.y"
1131 #line 169 "parse-gram.y"
1132 { current_class
= nterm_sym
; }
1135 #line 170 "parse-gram.y"
1137 current_class
= unknown_sym
;
1138 current_type
= NULL
;
1142 #line 175 "parse-gram.y"
1144 grammar_start_symbol_set (yyvsp
[0].symbol
);
1148 #line 178 "parse-gram.y"
1149 { current_class
= token_sym
; }
1152 #line 179 "parse-gram.y"
1154 current_class
= unknown_sym
;
1155 current_type
= NULL
;
1159 #line 183 "parse-gram.y"
1160 {current_type
= yyvsp
[0].string
; }
1163 #line 184 "parse-gram.y"
1165 current_type
= NULL
;
1169 #line 188 "parse-gram.y"
1172 MUSCLE_INSERT_INT ("stype_line", yylsp
[-1].first_line
);
1173 muscle_insert ("stype", yyvsp
[-1].string
);
1177 #line 197 "parse-gram.y"
1178 { current_assoc
= yyvsp
[-1].assoc
; ++current_prec
; }
1181 #line 199 "parse-gram.y"
1182 { current_assoc
= non_assoc
; current_type
= NULL
; }
1185 #line 203 "parse-gram.y"
1186 { yyval
.assoc
= left_assoc
; }
1189 #line 204 "parse-gram.y"
1190 { yyval
.assoc
= right_assoc
; }
1193 #line 205 "parse-gram.y"
1194 { yyval
.assoc
= non_assoc
; }
1197 #line 209 "parse-gram.y"
1198 { current_type
= NULL
;}
1201 #line 210 "parse-gram.y"
1202 { current_type
= yyvsp
[0].string
; }
1205 #line 215 "parse-gram.y"
1206 { symbol_type_set (yyvsp
[0].symbol
, current_type
); }
1209 #line 216 "parse-gram.y"
1210 { symbol_type_set (yyvsp
[0].symbol
, current_type
); }
1213 #line 222 "parse-gram.y"
1215 symbol_type_set (yyvsp
[0].symbol
, current_type
);
1216 symbol_precedence_set (yyvsp
[0].symbol
, current_prec
, current_assoc
);
1220 #line 227 "parse-gram.y"
1222 symbol_type_set (yyvsp
[0].symbol
, current_type
);
1223 symbol_precedence_set (yyvsp
[0].symbol
, current_prec
, current_assoc
);
1227 #line 237 "parse-gram.y"
1229 current_type
= yyvsp
[0].string
;
1233 #line 241 "parse-gram.y"
1235 symbol_class_set (yyvsp
[0].symbol
, current_class
);
1236 symbol_type_set (yyvsp
[0].symbol
, current_type
);
1240 #line 246 "parse-gram.y"
1242 symbol_class_set (yyvsp
[-1].symbol
, current_class
);
1243 symbol_type_set (yyvsp
[-1].symbol
, current_type
);
1244 symbol_user_token_number_set (yyvsp
[-1].symbol
, yyvsp
[0].integer
);
1248 #line 252 "parse-gram.y"
1250 symbol_class_set (yyvsp
[-1].symbol
, current_class
);
1251 symbol_type_set (yyvsp
[-1].symbol
, current_type
);
1252 symbol_make_alias (yyvsp
[-1].symbol
, yyvsp
[0].symbol
);
1256 #line 258 "parse-gram.y"
1258 symbol_class_set (yyvsp
[-2].symbol
, current_class
);
1259 symbol_type_set (yyvsp
[-2].symbol
, current_type
);
1260 symbol_user_token_number_set (yyvsp
[-2].symbol
, yyvsp
[-1].integer
);
1261 symbol_make_alias (yyvsp
[-2].symbol
, yyvsp
[0].symbol
);
1265 #line 269 "parse-gram.y"
1269 #line 271 "parse-gram.y"
1273 #line 280 "parse-gram.y"
1274 { current_lhs
= yyvsp
[-1].symbol
; }
1277 #line 281 "parse-gram.y"
1281 #line 285 "parse-gram.y"
1282 { grammar_rule_end (); }
1285 #line 286 "parse-gram.y"
1286 { grammar_rule_end (); }
1289 #line 291 "parse-gram.y"
1290 { grammar_rule_begin (current_lhs
); }
1293 #line 293 "parse-gram.y"
1294 { grammar_current_rule_symbol_append (yyvsp
[0].symbol
); }
1297 #line 295 "parse-gram.y"
1298 { grammar_current_rule_action_append (yyvsp
[0].string
, yylsp
[0].first_line
); }
1301 #line 297 "parse-gram.y"
1302 { grammar_current_rule_prec_set (yyvsp
[0].symbol
); }
1305 #line 301 "parse-gram.y"
1306 { yyval
.symbol
= yyvsp
[0].symbol
; }
1309 #line 302 "parse-gram.y"
1310 { yyval
.symbol
= yyvsp
[0].symbol
; }
1313 #line 303 "parse-gram.y"
1314 { yyval
.symbol
= getsym (yyvsp
[0].string
); }
1317 #line 308 "parse-gram.y"
1318 { yyval
.string
= yyvsp
[0].string
; }
1321 #line 314 "parse-gram.y"
1323 yyval
.symbol
= getsym (yyvsp
[0].string
);
1324 symbol_class_set (yyval
.symbol
, token_sym
);
1328 #line 323 "parse-gram.y"
1330 yyval
.string
= yyvsp
[0].string
+ 1;
1331 yyval
.string
[strlen (yyval
.string
) - 1] = '\0';
1335 #line 331 "parse-gram.y"
1337 yyval
.string
= xstrdup ("");
1341 #line 335 "parse-gram.y"
1343 yyval
.string
= yyvsp
[0].string
;
1348 #line 705 "/usr/share/bison/bison.simple"
1360 short *yyssp1
= yyss
- 1;
1361 YYFPRINTF (stderr
, "state stack now");
1362 while (yyssp1
!= yyssp
)
1363 YYFPRINTF (stderr
, " %d", *++yyssp1
);
1364 YYFPRINTF (stderr
, "\n");
1373 /* Now `shift' the result of the reduction. Determine what state
1374 that goes to, based on the state we popped back to and the rule
1375 number reduced by. */
1379 yystate
= yypgoto
[yyn
- YYNTBASE
] + *yyssp
;
1380 if (yystate
>= 0 && yystate
<= YYLAST
&& yycheck
[yystate
] == *yyssp
)
1381 yystate
= yytable
[yystate
];
1383 yystate
= yydefgoto
[yyn
- YYNTBASE
];
1388 /*------------------------------------.
1389 | yyerrlab -- here on detecting error |
1390 `------------------------------------*/
1392 /* If not already recovering from an error, report this error. */
1397 #ifdef YYERROR_VERBOSE
1398 yyn
= yypact
[yystate
];
1400 if (yyn
> YYFLAG
&& yyn
< YYLAST
)
1402 YYSIZE_T yysize
= 0;
1407 /* Start YYX at -YYN if negative to avoid negative indexes in
1409 for (yyx
= yyn
< 0 ? -yyn
: 0;
1410 yyx
< (int) (sizeof (yytname
) / sizeof (char *)); yyx
++)
1411 if (yycheck
[yyx
+ yyn
] == yyx
)
1412 yysize
+= yystrlen (yytname
[yyx
]) + 15, yycount
++;
1413 yysize
+= yystrlen ("parse error, unexpected ") + 1;
1414 yysize
+= yystrlen (yytname
[YYTRANSLATE (yychar
)]);
1415 yymsg
= (char *) YYSTACK_ALLOC (yysize
);
1418 char *yyp
= yystpcpy (yymsg
, "parse error, unexpected ");
1419 yyp
= yystpcpy (yyp
, yytname
[YYTRANSLATE (yychar
)]);
1424 for (yyx
= yyn
< 0 ? -yyn
: 0;
1425 yyx
< (int) (sizeof (yytname
) / sizeof (char *));
1427 if (yycheck
[yyx
+ yyn
] == yyx
)
1429 const char *yyq
= ! yycount
? ", expecting " : " or ";
1430 yyp
= yystpcpy (yyp
, yyq
);
1431 yyp
= yystpcpy (yyp
, yytname
[yyx
]);
1436 YYSTACK_FREE (yymsg
);
1439 yyerror ("parse error; also virtual memory exhausted");
1442 #endif /* defined (YYERROR_VERBOSE) */
1443 yyerror ("parse error");
1448 /*--------------------------------------------------.
1449 | yyerrlab1 -- error raised explicitly by an action |
1450 `--------------------------------------------------*/
1452 if (yyerrstatus
== 3)
1454 /* If just tried and failed to reuse lookahead token after an
1455 error, discard it. */
1457 /* return failure if at end of input */
1458 if (yychar
== YYEOF
)
1460 YYDPRINTF ((stderr
, "Discarding token %d (%s).\n",
1461 yychar
, yytname
[yychar1
]));
1465 /* Else will try to reuse lookahead token after shifting the error
1468 yyerrstatus
= 3; /* Each real token shifted decrements this */
1473 /*-------------------------------------------------------------------.
1474 | yyerrdefault -- current state does not do anything special for the |
1476 `-------------------------------------------------------------------*/
1479 /* This is wrong; only states that explicitly want error tokens
1480 should shift them. */
1482 /* If its default is to accept any token, ok. Otherwise pop it. */
1483 yyn
= yydefact
[yystate
];
1489 /*---------------------------------------------------------------.
1490 | yyerrpop -- pop the current state because it cannot handle the |
1492 `---------------------------------------------------------------*/
1505 short *yyssp1
= yyss
- 1;
1506 YYFPRINTF (stderr
, "Error: state stack now");
1507 while (yyssp1
!= yyssp
)
1508 YYFPRINTF (stderr
, " %d", *++yyssp1
);
1509 YYFPRINTF (stderr
, "\n");
1517 yyn
= yypact
[yystate
];
1522 if (yyn
< 0 || yyn
> YYLAST
|| yycheck
[yyn
] != YYTERROR
)
1539 YYDPRINTF ((stderr
, "Shifting error token, "));
1550 /*-------------------------------------.
1551 | yyacceptlab -- YYACCEPT comes here. |
1552 `-------------------------------------*/
1557 /*-----------------------------------.
1558 | yyabortlab -- YYABORT comes here. |
1559 `-----------------------------------*/
1564 /*---------------------------------------------.
1565 | yyoverflowab -- parser overflow comes here. |
1566 `---------------------------------------------*/
1568 yyerror ("parser stack overflow");
1575 YYSTACK_FREE (yyss
);
1579 #line 344 "parse-gram.y"
1581 /*------------------------------------------------------------------.
1582 | When debugging the parser, display tokens' locations and values. |
1583 `------------------------------------------------------------------*/
1586 yyprint (FILE *file
,
1587 const yyltype
*loc
, int type
, const yystype
*value
)
1590 LOCATION_PRINT (file
, *loc
);
1595 fprintf (file
, " = '%s'", value
->string
);
1599 fprintf (file
, " = %s", value
->symbol
->tag
);
1603 fprintf (file
, " = %d", value
->integer
);
1607 fprintf (file
, " = \"%s\"", value
->string
);
1611 fprintf (file
, " = <%s>", value
->string
);
1617 fprintf (file
, " = {{ %s }}", value
->string
);
1623 gram_error (gram_control_t
*control ATTRIBUTE_UNUSED
,
1624 yyltype
*yylloc
, const char *msg
)
1626 LOCATION_PRINT (stderr
, *yylloc
);
1627 fprintf (stderr
, ": %s\n", msg
);