1 /* A Bison parser, made by GNU Bison 2.3a+. */
3 /* Skeleton implementation for Bison's Yacc-like parsers in C
5 Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006
6 Free Software Foundation, Inc.
8 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
10 the Free Software Foundation; either version 2, or (at your option)
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 51 Franklin Street, Fifth Floor,
21 Boston, MA 02110-1301, USA. */
23 /* As a special exception, you may create a larger work that contains
24 part or all of the Bison parser skeleton and distribute that work
25 under terms of your choice, so long as that work isn't itself a
26 parser generator using the skeleton or a modified version thereof
27 as a parser skeleton. Alternatively, if you modify or redistribute
28 the parser skeleton itself, you may (at your option) remove this
29 special exception, which will cause the skeleton and the resulting
30 Bison output files to be licensed under the GNU General Public
31 License without this special exception.
33 This special exception was added by the Free Software Foundation in
34 version 2.2 of Bison. */
36 /* C LALR(1) parser skeleton written by Richard Stallman, by
37 simplifying the original so-called "semantic" parser. */
39 /* All symbols defined below should begin with yy or YY, to avoid
40 infringing on user name space. This should be done even for local
41 variables, as they might otherwise be expanded by user macros.
42 There are some unavoidable exceptions within include files to
43 define necessary library symbols; they are noted "INFRINGES ON
44 USER NAME SPACE" below. */
46 /* Identify Bison output. */
50 #define YYBISON_VERSION "2.3a+"
53 #define YYSKELETON_NAME "yacc.c"
61 /* Using locations. */
62 #define YYLSP_NEEDED 1
64 /* Substitute the variable and function names. */
65 #define yyparse gram_parse
66 #define yylex gram_lex
67 #define yyerror gram_error
68 #define yylval gram_lval
69 #define yychar gram_char
70 #define yydebug gram_debug
71 #define yynerrs gram_nerrs
72 #define yylloc gram_lloc
74 /* Copy the first part of user declarations. */
76 /* Line 164 of yacc.c */
77 #line 1 "parse-gram.y"
78 /* Bison Grammar Parser -*- C -*-
80 Copyright (C) 2002, 2003, 2004, 2005, 2006 Free Software Foundation, Inc.
82 This file is part of Bison, the GNU Compiler Compiler.
84 This program is free software; you can redistribute it and/or modify
85 it under the terms of the GNU General Public License as published by
86 the Free Software Foundation; either version 2 of the License, or
87 (at your option) any later version.
89 This program is distributed in the hope that it will be useful,
90 but WITHOUT ANY WARRANTY; without even the implied warranty of
91 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
92 GNU General Public License for more details.
94 You should have received a copy of the GNU General Public License
95 along with this program; if not, write to the Free Software
96 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
103 #include <strverscmp.h>
105 #include "complain.h"
106 #include "conflicts.h"
110 #include "muscle_tab.h"
111 #include "quotearg.h"
114 #include "scan-gram.h"
115 #include "scan-code.h"
117 #define YYLLOC_DEFAULT(Current, Rhs, N) (Current) = lloc_default (Rhs, N)
118 static YYLTYPE
lloc_default (YYLTYPE
const *, int);
120 #define YY_LOCATION_PRINT(File, Loc) \
121 location_print (File, Loc)
123 static void version_check (location
const *loc
, char const *version
);
125 /* Request detailed syntax error messages, and pass them to GRAM_ERROR.
126 FIXME: depends on the undocumented availability of YYLLOC. */
128 #define yyerror(Msg) \
129 gram_error (&yylloc, Msg)
130 static void gram_error (location
const *, char const *);
132 static char const *char_name (char);
134 /** Add a lex-param or a parse-param.
136 * \param type \a lex_param or \a parse_param
137 * \param decl the formal argument
138 * \param loc the location in the source.
140 static void add_param (char const *type
, char *decl
, location loc
);
143 static symbol_class current_class
= unknown_sym
;
144 static uniqstr current_type
= NULL
;
145 static symbol
*current_lhs
;
146 static location current_lhs_location
;
147 static int current_prec
= 0;
149 #define YYTYPE_INT16 int_fast16_t
150 #define YYTYPE_INT8 int_fast8_t
151 #define YYTYPE_UINT16 uint_fast16_t
152 #define YYTYPE_UINT8 uint_fast8_t
155 /* Line 164 of yacc.c */
156 #line 157 "parse-gram.c"
158 /* Enabling traces. */
163 /* Enabling verbose error messages. */
164 #ifdef YYERROR_VERBOSE
165 # undef YYERROR_VERBOSE
166 # define YYERROR_VERBOSE 1
168 # define YYERROR_VERBOSE 1
171 /* Enabling the token table. */
172 #ifndef YYTOKEN_TABLE
173 # define YYTOKEN_TABLE 0
180 /* Put the tokens into the symbol table, so that GDB and other debuggers
189 PERCENT_DESTRUCTOR
= 263,
190 PERCENT_PRINTER
= 264,
193 PERCENT_NONASSOC
= 267,
198 PERCENT_CODE_TOP
= 272,
200 PERCENT_DEFAULT_PREC
= 274,
201 PERCENT_DEFINE
= 275,
202 PERCENT_DEFINES
= 276,
203 PERCENT_ERROR_VERBOSE
= 277,
204 PERCENT_EXPECT
= 278,
205 PERCENT_EXPECT_RR
= 279,
206 PERCENT_FILE_PREFIX
= 280,
207 PERCENT_GLR_PARSER
= 281,
208 PERCENT_INITIAL_ACTION
= 282,
209 PERCENT_LEX_PARAM
= 283,
210 PERCENT_LOCATIONS
= 284,
211 PERCENT_NAME_PREFIX
= 285,
212 PERCENT_NO_DEFAULT_PREC
= 286,
213 PERCENT_NO_LINES
= 287,
214 PERCENT_NONDETERMINISTIC_PARSER
= 288,
215 PERCENT_OUTPUT
= 289,
216 PERCENT_PARSE_PARAM
= 290,
217 PERCENT_PROVIDES
= 291,
218 PERCENT_PURE_PARSER
= 292,
219 PERCENT_PUSH_PARSER
= 293,
220 PERCENT_REQUIRE
= 294,
221 PERCENT_REQUIRES
= 295,
222 PERCENT_SKELETON
= 296,
224 PERCENT_TOKEN_TABLE
= 298,
225 PERCENT_VERBOSE
= 299,
233 PERCENT_PERCENT
= 307,
247 #define PERCENT_TOKEN 260
248 #define PERCENT_NTERM 261
249 #define PERCENT_TYPE 262
250 #define PERCENT_DESTRUCTOR 263
251 #define PERCENT_PRINTER 264
252 #define PERCENT_LEFT 265
253 #define PERCENT_RIGHT 266
254 #define PERCENT_NONASSOC 267
255 #define PERCENT_PREC 268
256 #define PERCENT_DPREC 269
257 #define PERCENT_MERGE 270
258 #define PERCENT_CODE 271
259 #define PERCENT_CODE_TOP 272
260 #define PERCENT_DEBUG 273
261 #define PERCENT_DEFAULT_PREC 274
262 #define PERCENT_DEFINE 275
263 #define PERCENT_DEFINES 276
264 #define PERCENT_ERROR_VERBOSE 277
265 #define PERCENT_EXPECT 278
266 #define PERCENT_EXPECT_RR 279
267 #define PERCENT_FILE_PREFIX 280
268 #define PERCENT_GLR_PARSER 281
269 #define PERCENT_INITIAL_ACTION 282
270 #define PERCENT_LEX_PARAM 283
271 #define PERCENT_LOCATIONS 284
272 #define PERCENT_NAME_PREFIX 285
273 #define PERCENT_NO_DEFAULT_PREC 286
274 #define PERCENT_NO_LINES 287
275 #define PERCENT_NONDETERMINISTIC_PARSER 288
276 #define PERCENT_OUTPUT 289
277 #define PERCENT_PARSE_PARAM 290
278 #define PERCENT_PROVIDES 291
279 #define PERCENT_PURE_PARSER 292
280 #define PERCENT_PUSH_PARSER 293
281 #define PERCENT_REQUIRE 294
282 #define PERCENT_REQUIRES 295
283 #define PERCENT_SKELETON 296
284 #define PERCENT_START 297
285 #define PERCENT_TOKEN_TABLE 298
286 #define PERCENT_VERBOSE 299
287 #define PERCENT_YACC 300
288 #define BRACED_CODE 301
294 #define PERCENT_PERCENT 307
297 #define SEMICOLON 310
299 #define TYPE_TAG_ANY 312
300 #define TYPE_TAG_NONE 313
301 #define PERCENT_UNION 314
306 #if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED
307 typedef union YYSTYPE
309 /* Line 198 of yacc.c */
310 #line 97 "parse-gram.y"
319 unsigned char character
;
322 /* Line 198 of yacc.c */
323 #line 324 "parse-gram.c"
325 # define YYSTYPE_IS_TRIVIAL 1
326 # define yystype YYSTYPE /* obsolescent; will be withdrawn */
327 # define YYSTYPE_IS_DECLARED 1
330 #if ! defined YYLTYPE && ! defined YYLTYPE_IS_DECLARED
331 typedef struct YYLTYPE
338 # define yyltype YYLTYPE /* obsolescent; will be withdrawn */
339 # define YYLTYPE_IS_DECLARED 1
340 # define YYLTYPE_IS_TRIVIAL 1
344 /* Copy the second part of user declarations. */
347 /* Line 221 of yacc.c */
348 #line 349 "parse-gram.c"
355 typedef YYTYPE_UINT8 yytype_uint8
;
357 typedef unsigned char yytype_uint8
;
361 typedef YYTYPE_INT8 yytype_int8
;
362 #elif (defined __STDC__ || defined __C99__FUNC__ \
363 || defined __cplusplus || defined _MSC_VER)
364 typedef signed char yytype_int8
;
366 typedef short int yytype_int8
;
370 typedef YYTYPE_UINT16 yytype_uint16
;
372 typedef unsigned short int yytype_uint16
;
376 typedef YYTYPE_INT16 yytype_int16
;
378 typedef short int yytype_int16
;
382 # ifdef __SIZE_TYPE__
383 # define YYSIZE_T __SIZE_TYPE__
384 # elif defined size_t
385 # define YYSIZE_T size_t
386 # elif ! defined YYSIZE_T && (defined __STDC__ || defined __C99__FUNC__ \
387 || defined __cplusplus || defined _MSC_VER)
388 # include <stddef.h> /* INFRINGES ON USER NAME SPACE */
389 # define YYSIZE_T size_t
391 # define YYSIZE_T unsigned int
395 #define YYSIZE_MAXIMUM ((YYSIZE_T) -1)
400 # include <libintl.h> /* INFRINGES ON USER NAME SPACE */
401 # define YY_(msgid) dgettext ("bison-runtime", msgid)
405 # define YY_(msgid) msgid
409 /* Suppress unused-variable warnings by "using" E. */
410 #if ! defined lint || defined __GNUC__
411 # define YYUSE(e) ((void) (e))
413 # define YYUSE(e) /* empty */
416 /* Identity function, used to suppress warnings about constant conditions. */
420 #if (defined __STDC__ || defined __C99__FUNC__ \
421 || defined __cplusplus || defined _MSC_VER)
434 #if ! defined yyoverflow || YYERROR_VERBOSE
436 /* The parser invokes alloca or malloc; define the necessary symbols. */
438 # ifdef YYSTACK_USE_ALLOCA
439 # if YYSTACK_USE_ALLOCA
441 # define YYSTACK_ALLOC __builtin_alloca
442 # elif defined __BUILTIN_VA_ARG_INCR
443 # include <alloca.h> /* INFRINGES ON USER NAME SPACE */
445 # define YYSTACK_ALLOC __alloca
446 # elif defined _MSC_VER
447 # include <malloc.h> /* INFRINGES ON USER NAME SPACE */
448 # define alloca _alloca
450 # define YYSTACK_ALLOC alloca
451 # if ! defined _ALLOCA_H && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \
452 || defined __cplusplus || defined _MSC_VER)
453 # include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
462 # ifdef YYSTACK_ALLOC
463 /* Pacify GCC's `empty if-body' warning. */
464 # define YYSTACK_FREE(Ptr) do { /* empty */; } while (YYID (0))
465 # ifndef YYSTACK_ALLOC_MAXIMUM
466 /* The OS might guarantee only one guard page at the bottom of the stack,
467 and a page size can be as small as 4096 bytes. So we cannot safely
468 invoke alloca (N) if N exceeds 4096. Use a slightly smaller number
469 to allow for a few compiler-allocated temporary stack slots. */
470 # define YYSTACK_ALLOC_MAXIMUM 4032 /* reasonable circa 2006 */
473 # define YYSTACK_ALLOC YYMALLOC
474 # define YYSTACK_FREE YYFREE
475 # ifndef YYSTACK_ALLOC_MAXIMUM
476 # define YYSTACK_ALLOC_MAXIMUM YYSIZE_MAXIMUM
478 # if (defined __cplusplus && ! defined _STDLIB_H \
479 && ! ((defined YYMALLOC || defined malloc) \
480 && (defined YYFREE || defined free)))
481 # include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
487 # define YYMALLOC malloc
488 # if ! defined malloc && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \
489 || defined __cplusplus || defined _MSC_VER)
490 void *malloc (YYSIZE_T
); /* INFRINGES ON USER NAME SPACE */
495 # if ! defined free && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \
496 || defined __cplusplus || defined _MSC_VER)
497 void free (void *); /* INFRINGES ON USER NAME SPACE */
501 #endif /* ! defined yyoverflow || YYERROR_VERBOSE */
504 #if (! defined yyoverflow \
505 && (! defined __cplusplus \
506 || (defined YYLTYPE_IS_TRIVIAL && YYLTYPE_IS_TRIVIAL \
507 && defined YYSTYPE_IS_TRIVIAL && YYSTYPE_IS_TRIVIAL)))
509 /* A type that is properly aligned for any stack member. */
517 /* The size of the maximum gap between one aligned stack and the next. */
518 # define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1)
520 /* The size of an array large to enough to hold all stacks, each with
522 # define YYSTACK_BYTES(N) \
523 ((N) * (sizeof (yytype_int16) + sizeof (YYSTYPE) + sizeof (YYLTYPE)) \
524 + 2 * YYSTACK_GAP_MAXIMUM)
526 /* Copy COUNT objects from FROM to TO. The source and destination do
529 # if defined __GNUC__ && 1 < __GNUC__
530 # define YYCOPY(To, From, Count) \
531 __builtin_memcpy (To, From, (Count) * sizeof (*(From)))
533 # define YYCOPY(To, From, Count) \
537 for (yyi = 0; yyi < (Count); yyi++) \
538 (To)[yyi] = (From)[yyi]; \
544 /* Relocate STACK from its old location to the new one. The
545 local variables YYSIZE and YYSTACKSIZE give the old and new number of
546 elements in the stack, and YYPTR gives the new location of the
547 stack. Advance YYPTR to a properly aligned location for the next
549 # define YYSTACK_RELOCATE(Stack) \
552 YYSIZE_T yynewbytes; \
553 YYCOPY (&yyptr->Stack, Stack, yysize); \
554 Stack = &yyptr->Stack; \
555 yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \
556 yyptr += yynewbytes / sizeof (*yyptr); \
562 /* YYFINAL -- State number of the termination state. */
564 /* YYLAST -- Last index in YYTABLE. */
567 /* YYNTOKENS -- Number of terminals. */
569 /* YYNNTS -- Number of nonterminals. */
571 /* YYNRULES -- Number of rules. */
573 /* YYNRULES -- Number of states. */
574 #define YYNSTATES 142
576 /* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
578 #define YYMAXUTOK 314
580 #define YYTRANSLATE(YYX) \
581 ((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK)
583 /* YYTRANSLATE[YYLEX] -- Bison symbol number corresponding to YYLEX. */
584 static const yytype_uint8 yytranslate
[] =
586 0, 2, 2, 2, 2, 2, 2, 2, 2, 2,
587 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
588 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
589 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
590 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
591 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
592 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
593 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
594 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
595 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
596 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
597 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
598 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
599 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
600 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
601 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
602 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
603 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
604 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
605 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
606 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
607 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
608 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
609 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
610 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
611 2, 2, 2, 2, 2, 2, 1, 2, 3, 4,
612 5, 6, 7, 8, 9, 10, 11, 12, 13, 14,
613 15, 16, 17, 18, 19, 20, 21, 22, 23, 24,
614 25, 26, 27, 28, 29, 30, 31, 32, 33, 34,
615 35, 36, 37, 38, 39, 40, 41, 42, 43, 44,
616 45, 46, 47, 48, 49, 50, 51, 52, 53, 54,
621 /* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in
623 static const yytype_uint16 yyprhs
[] =
625 0, 0, 3, 8, 9, 12, 14, 16, 18, 22,
626 24, 27, 29, 32, 35, 38, 42, 44, 47, 50,
627 52, 55, 59, 61, 63, 66, 70, 73, 75, 77,
628 80, 83, 85, 87, 89, 91, 93, 95, 98, 102,
629 106, 108, 110, 113, 116, 119, 122, 123, 125, 129,
630 130, 134, 135, 139, 143, 147, 149, 151, 153, 154,
631 156, 158, 161, 163, 166, 168, 170, 172, 174, 176,
632 178, 181, 184, 188, 190, 193, 195, 198, 200, 203,
633 206, 207, 211, 213, 217, 220, 221, 224, 227, 231,
634 235, 239, 241, 243, 244, 246, 248, 250, 252, 254,
638 /* YYRHS -- A `-1'-separated list of the rules' RHS. */
639 static const yytype_int8 yyrhs
[] =
641 61, 0, -1, 62, 52, 77, 90, -1, -1, 62,
642 63, -1, 64, -1, 54, -1, 18, -1, 20, 3,
643 84, -1, 21, -1, 21, 3, -1, 22, -1, 23,
644 4, -1, 24, 4, -1, 25, 3, -1, 25, 49,
645 3, -1, 26, -1, 27, 46, -1, 28, 46, -1,
646 29, -1, 30, 3, -1, 30, 49, 3, -1, 32,
647 -1, 33, -1, 34, 3, -1, 34, 49, 3, -1,
648 35, 46, -1, 37, -1, 38, -1, 39, 3, -1,
649 41, 3, -1, 43, -1, 44, -1, 45, -1, 55,
650 -1, 69, -1, 66, -1, 42, 88, -1, 8, 46,
651 73, -1, 9, 46, 73, -1, 19, -1, 31, -1,
652 16, 85, -1, 17, 85, -1, 36, 85, -1, 40,
653 85, -1, -1, 50, -1, 59, 65, 46, -1, -1,
654 6, 67, 76, -1, -1, 5, 68, 76, -1, 7,
655 56, 72, -1, 70, 71, 72, -1, 10, -1, 11,
656 -1, 12, -1, -1, 56, -1, 88, -1, 72, 88,
657 -1, 74, -1, 73, 74, -1, 88, -1, 56, -1,
658 57, -1, 58, -1, 56, -1, 86, -1, 86, 4,
659 -1, 86, 89, -1, 86, 4, 89, -1, 75, -1,
660 76, 75, -1, 78, -1, 77, 78, -1, 79, -1,
661 64, 55, -1, 1, 55, -1, -1, 87, 80, 81,
662 -1, 82, -1, 81, 53, 82, -1, 81, 55, -1,
663 -1, 82, 88, -1, 82, 46, -1, 82, 13, 88,
664 -1, 82, 14, 4, -1, 82, 15, 56, -1, 3,
665 -1, 85, -1, -1, 83, -1, 46, -1, 50, -1,
666 47, -1, 51, -1, 86, -1, 89, -1, 3, -1,
670 /* YYRLINE[YYN] -- source line where rule number YYN was defined. */
671 static const yytype_uint16 yyrline
[] =
673 0, 210, 210, 218, 220, 224, 225, 226, 227, 228,
674 229, 234, 235, 236, 237, 238, 239, 244, 248, 249,
675 250, 251, 252, 253, 254, 255, 256, 257, 258, 259,
676 260, 261, 262, 263, 264, 268, 269, 270, 274, 282,
677 290, 294, 298, 299, 300, 301, 312, 313, 317, 345,
678 345, 350, 350, 355, 366, 381, 382, 383, 387, 388,
679 393, 395, 400, 401, 405, 406, 407, 408, 413, 418,
680 423, 429, 435, 446, 447, 456, 457, 463, 464, 465,
681 472, 472, 476, 477, 478, 483, 484, 486, 488, 490,
682 492, 502, 503, 509, 513, 518, 534, 536, 545, 550,
687 #if YYDEBUG || YYERROR_VERBOSE || YYTOKEN_TABLE
688 /* YYTNAME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM.
689 First, the terminals, then, starting at YYNTOKENS, nonterminals. */
690 static const char *const yytname
[] =
692 "\"end of file\"", "error", "$undefined", "\"string\"", "\"integer\"",
693 "\"%token\"", "\"%nterm\"", "\"%type\"", "\"%destructor\"",
694 "\"%printer\"", "\"%left\"", "\"%right\"", "\"%nonassoc\"", "\"%prec\"",
695 "\"%dprec\"", "\"%merge\"", "\"%code\"", "\"%code-top\"", "\"%debug\"",
696 "\"%default-prec\"", "\"%define\"", "\"%defines\"", "\"%error-verbose\"",
697 "\"%expect\"", "\"%expect-rr\"", "\"%file-prefix\"", "\"%glr-parser\"",
698 "\"%initial-action\"", "\"%lex-param\"", "\"%locations\"",
699 "\"%name-prefix\"", "\"%no-default-prec\"", "\"%no-lines\"",
700 "\"%nondeterministic-parser\"", "\"%output\"", "\"%parse-param\"",
701 "\"%provides\"", "\"%pure-parser\"", "\"%push-parser\"", "\"%require\"",
702 "\"%requires\"", "\"%skeleton\"", "\"%start\"", "\"%token-table\"",
703 "\"%verbose\"", "\"%yacc\"", "\"{...}\"", "\"char\"", "\"epilogue\"",
704 "\"=\"", "\"identifier\"", "\"identifier:\"", "\"%%\"", "\"|\"",
705 "\"%{...%}\"", "\";\"", "\"type\"", "\"<*>\"", "\"<>\"", "\"%union\"",
706 "$accept", "input", "prologue_declarations", "prologue_declaration",
707 "grammar_declaration", "union_name", "symbol_declaration", "$@1", "$@2",
708 "precedence_declaration", "precedence_declarator", "type.opt",
709 "symbols.1", "generic_symlist", "generic_symlist_item", "symbol_def",
710 "symbol_defs.1", "grammar", "rules_or_grammar_declaration", "rules",
711 "$@3", "rhses.1", "rhs", "content", "content.opt", "braceless", "id",
712 "id_colon", "symbol", "string_as_id", "epilogue.opt", 0
717 /* YYTOKNUM[YYLEX-NUM] -- Internal token number corresponding to
719 static const yytype_uint16 yytoknum
[] =
721 0, 256, 257, 258, 259, 260, 261, 262, 263, 264,
722 265, 266, 267, 268, 269, 270, 271, 272, 273, 274,
723 275, 276, 277, 278, 279, 280, 281, 282, 283, 284,
724 285, 286, 287, 288, 289, 290, 291, 292, 293, 294,
725 295, 296, 297, 298, 299, 300, 301, 302, 303, 304,
726 305, 306, 307, 308, 309, 310, 311, 312, 313, 314
730 /* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */
731 static const yytype_uint8 yyr1
[] =
733 0, 60, 61, 62, 62, 63, 63, 63, 63, 63,
734 63, 63, 63, 63, 63, 63, 63, 63, 63, 63,
735 63, 63, 63, 63, 63, 63, 63, 63, 63, 63,
736 63, 63, 63, 63, 63, 64, 64, 64, 64, 64,
737 64, 64, 64, 64, 64, 64, 65, 65, 64, 67,
738 66, 68, 66, 66, 69, 70, 70, 70, 71, 71,
739 72, 72, 73, 73, 74, 74, 74, 74, 75, 75,
740 75, 75, 75, 76, 76, 77, 77, 78, 78, 78,
741 80, 79, 81, 81, 81, 82, 82, 82, 82, 82,
742 82, 83, 83, 84, 84, 85, 86, 86, 87, 88,
746 /* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
747 static const yytype_uint8 yyr2
[] =
749 0, 2, 4, 0, 2, 1, 1, 1, 3, 1,
750 2, 1, 2, 2, 2, 3, 1, 2, 2, 1,
751 2, 3, 1, 1, 2, 3, 2, 1, 1, 2,
752 2, 1, 1, 1, 1, 1, 1, 2, 3, 3,
753 1, 1, 2, 2, 2, 2, 0, 1, 3, 0,
754 3, 0, 3, 3, 3, 1, 1, 1, 0, 1,
755 1, 2, 1, 2, 1, 1, 1, 1, 1, 1,
756 2, 2, 3, 1, 2, 1, 2, 1, 2, 2,
757 0, 3, 1, 3, 2, 0, 2, 2, 3, 3,
758 3, 1, 1, 0, 1, 1, 1, 1, 1, 1,
762 /* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state
763 STATE-NUM when YYTABLE doesn't specify something else to do. Zero
764 means the default is an error. */
765 static const yytype_uint8 yydefact
[] =
767 3, 0, 0, 1, 51, 49, 0, 0, 0, 55,
768 56, 57, 0, 0, 7, 40, 0, 9, 11, 0,
769 0, 0, 16, 0, 0, 19, 0, 41, 22, 23,
770 0, 0, 0, 27, 28, 0, 0, 0, 0, 31,
771 32, 33, 0, 6, 34, 46, 4, 5, 36, 35,
772 58, 0, 0, 0, 0, 0, 95, 42, 43, 93,
773 10, 12, 13, 14, 0, 17, 18, 20, 0, 24,
774 0, 26, 44, 29, 45, 30, 101, 97, 96, 99,
775 37, 100, 0, 98, 0, 0, 75, 77, 80, 47,
776 0, 59, 0, 68, 73, 52, 69, 50, 53, 60,
777 65, 66, 67, 38, 62, 64, 39, 91, 94, 8,
778 92, 15, 21, 25, 79, 78, 0, 76, 2, 85,
779 48, 54, 74, 70, 71, 61, 63, 103, 81, 82,
780 72, 85, 84, 0, 0, 0, 87, 86, 83, 88,
784 /* YYDEFGOTO[NTERM-NUM]. */
785 static const yytype_int16 yydefgoto
[] =
787 -1, 1, 2, 46, 84, 90, 48, 52, 51, 49,
788 50, 92, 98, 103, 104, 94, 95, 85, 86, 87,
789 119, 128, 129, 108, 109, 57, 79, 88, 105, 81,
793 /* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
795 #define YYPACT_NINF -97
796 static const yytype_int8 yypact
[] =
798 -97, 3, 123, -97, -97, -97, -42, -6, -5, -97,
799 -97, -97, -3, -3, -97, -97, 41, 55, -97, 57,
800 60, 1, -97, 36, 40, -97, 10, -97, -97, -97,
801 23, 44, -3, -97, -97, 85, -3, 90, -2, -97,
802 -97, -97, 68, -97, -97, 46, -97, -97, -97, -97,
803 38, 42, 42, -2, -1, -1, -97, -97, -97, 35,
804 -97, -97, -97, -97, 94, -97, -97, -97, 98, -97,
805 99, -97, -97, -97, -97, -97, -97, -97, -97, -97,
806 -97, -97, 48, -97, 50, 11, -97, -97, -97, -97,
807 61, -97, -2, -97, -97, 42, 5, 42, -2, -97,
808 -97, -97, -97, -1, -97, -97, -1, -97, -97, -97,
809 -97, -97, -97, -97, -97, -97, 58, -97, -97, -97,
810 -97, -2, -97, 109, -97, -97, -97, -97, -22, 21,
811 -97, -97, -97, -2, 110, 59, -97, -97, 21, -97,
815 /* YYPGOTO[NTERM-NUM]. */
816 static const yytype_int8 yypgoto
[] =
818 -97, -97, -97, -97, 111, -97, -97, -97, -97, -97,
819 -97, -97, 24, 62, -96, -58, 66, -97, 37, -97,
820 -97, -97, -11, -97, -97, -7, 14, -97, -38, -91,
824 /* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If
825 positive, shift that token. If negative, reduce the rule which
826 number is the opposite. If zero, do what YYDEFACT says.
827 If YYTABLE_NINF, syntax error. */
828 #define YYTABLE_NINF -103
829 static const yytype_int16 yytable
[] =
831 80, 76, 76, 3, 63, 124, 58, 126, 76, 123,
832 126, -102, 82, 67, 53, 99, 4, 5, 6, 7,
833 8, 9, 10, 11, 76, 72, 69, 12, 13, 74,
834 15, 131, 130, 132, 133, 134, 135, 122, 107, 122,
835 54, 55, 27, 56, 59, 77, 77, 32, 78, 78,
836 64, 36, 110, 38, 99, 100, 101, 102, 60, 68,
837 125, 61, 83, 116, 62, 96, 96, 136, 77, 82,
838 45, 78, 70, 4, 5, 6, 7, 8, 9, 10,
839 11, 56, 65, 125, 12, 13, 66, 15, 73, 77,
840 71, 137, 78, 75, 91, 139, 89, 111, 93, 27,
841 137, 112, 113, 114, 32, 115, 127, 120, 36, 96,
842 38, 96, 76, 47, 140, 141, 121, 106, 97, 83,
843 138, 0, 117, 0, 0, 0, 0, 45, 4, 5,
844 6, 7, 8, 9, 10, 11, 0, 0, 0, 12,
845 13, 14, 15, 16, 17, 18, 19, 20, 21, 22,
846 23, 24, 25, 26, 27, 28, 29, 30, 31, 32,
847 33, 34, 35, 36, 37, 38, 39, 40, 41, 0,
848 0, 0, 0, 0, 0, 42, 0, 43, 44, 0,
852 static const yytype_int16 yycheck
[] =
854 38, 3, 3, 0, 3, 96, 13, 103, 3, 4,
855 106, 0, 1, 3, 56, 53, 5, 6, 7, 8,
856 9, 10, 11, 12, 3, 32, 3, 16, 17, 36,
857 19, 53, 123, 55, 13, 14, 15, 95, 3, 97,
858 46, 46, 31, 46, 3, 47, 47, 36, 50, 50,
859 49, 40, 59, 42, 92, 56, 57, 58, 3, 49,
860 98, 4, 51, 52, 4, 51, 52, 46, 47, 1,
861 59, 50, 49, 5, 6, 7, 8, 9, 10, 11,
862 12, 46, 46, 121, 16, 17, 46, 19, 3, 47,
863 46, 129, 50, 3, 56, 133, 50, 3, 56, 31,
864 138, 3, 3, 55, 36, 55, 48, 46, 40, 95,
865 42, 97, 3, 2, 4, 56, 92, 55, 52, 51,
866 131, -1, 85, -1, -1, -1, -1, 59, 5, 6,
867 7, 8, 9, 10, 11, 12, -1, -1, -1, 16,
868 17, 18, 19, 20, 21, 22, 23, 24, 25, 26,
869 27, 28, 29, 30, 31, 32, 33, 34, 35, 36,
870 37, 38, 39, 40, 41, 42, 43, 44, 45, -1,
871 -1, -1, -1, -1, -1, 52, -1, 54, 55, -1,
875 /* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
876 symbol of state STATE-NUM. */
877 static const yytype_uint8 yystos
[] =
879 0, 61, 62, 0, 5, 6, 7, 8, 9, 10,
880 11, 12, 16, 17, 18, 19, 20, 21, 22, 23,
881 24, 25, 26, 27, 28, 29, 30, 31, 32, 33,
882 34, 35, 36, 37, 38, 39, 40, 41, 42, 43,
883 44, 45, 52, 54, 55, 59, 63, 64, 66, 69,
884 70, 68, 67, 56, 46, 46, 46, 85, 85, 3,
885 3, 4, 4, 3, 49, 46, 46, 3, 49, 3,
886 49, 46, 85, 3, 85, 3, 3, 47, 50, 86,
887 88, 89, 1, 51, 64, 77, 78, 79, 87, 50,
888 65, 56, 71, 56, 75, 76, 86, 76, 72, 88,
889 56, 57, 58, 73, 74, 88, 73, 3, 83, 84,
890 85, 3, 3, 3, 55, 55, 52, 78, 90, 80,
891 46, 72, 75, 4, 89, 88, 74, 48, 81, 82,
892 89, 53, 55, 13, 14, 15, 46, 88, 82, 88,
896 #define yyerrok (yyerrstatus = 0)
897 #define yyclearin (yychar = YYEMPTY)
901 #define YYACCEPT goto yyacceptlab
902 #define YYABORT goto yyabortlab
903 #define YYERROR goto yyerrorlab
906 /* Like YYERROR except do call yyerror. This remains here temporarily
907 to ease the transition to the new meaning of YYERROR, for GCC.
908 Once GCC version 2 has supplanted version 1, this can go. */
910 #define YYFAIL goto yyerrlab
912 #define YYRECOVERING() (!!yyerrstatus)
914 #define YYBACKUP(Token, Value) \
916 if (yychar == YYEMPTY && yylen == 1) \
920 yytoken = YYTRANSLATE (yychar); \
926 yyerror (YY_("syntax error: cannot back up")); \
933 #define YYERRCODE 256
936 /* YYLLOC_DEFAULT -- Set CURRENT to span from RHS[1] to RHS[N].
937 If N is 0, then set CURRENT to the empty location which ends
938 the previous symbol: RHS[0] (always defined). */
940 #define YYRHSLOC(Rhs, K) ((Rhs)[K])
941 #ifndef YYLLOC_DEFAULT
942 # define YYLLOC_DEFAULT(Current, Rhs, N) \
946 (Current).first_line = YYRHSLOC (Rhs, 1).first_line; \
947 (Current).first_column = YYRHSLOC (Rhs, 1).first_column; \
948 (Current).last_line = YYRHSLOC (Rhs, N).last_line; \
949 (Current).last_column = YYRHSLOC (Rhs, N).last_column; \
953 (Current).first_line = (Current).last_line = \
954 YYRHSLOC (Rhs, 0).last_line; \
955 (Current).first_column = (Current).last_column = \
956 YYRHSLOC (Rhs, 0).last_column; \
962 /* YY_LOCATION_PRINT -- Print the location on the stream.
963 This macro was not mandated originally: define only if we know
964 we won't break user code: when these are the locations we know. */
966 #ifndef YY_LOCATION_PRINT
967 # if YYLTYPE_IS_TRIVIAL
968 # define YY_LOCATION_PRINT(File, Loc) \
969 fprintf (File, "%d.%d-%d.%d", \
970 (Loc).first_line, (Loc).first_column, \
971 (Loc).last_line, (Loc).last_column)
973 # define YY_LOCATION_PRINT(File, Loc) ((void) 0)
978 /* YYLEX -- calling `yylex' with the right arguments. */
981 # define YYLEX yylex (&yylval, &yylloc, YYLEX_PARAM)
983 # define YYLEX yylex (&yylval, &yylloc)
986 /* Enable debugging if requested. */
990 # include <stdio.h> /* INFRINGES ON USER NAME SPACE */
991 # define YYFPRINTF fprintf
994 # define YYDPRINTF(Args) \
1000 # define YY_SYMBOL_PRINT(Title, Type, Value, Location) \
1004 YYFPRINTF (stderr, "%s ", Title); \
1005 yy_symbol_print (stderr, \
1006 Type, Value, Location); \
1007 YYFPRINTF (stderr, "\n"); \
1012 /*--------------------------------.
1013 | Print this symbol on YYOUTPUT. |
1014 `--------------------------------*/
1017 #if (defined __STDC__ || defined __C99__FUNC__ \
1018 || defined __cplusplus || defined _MSC_VER)
1020 yy_symbol_value_print (FILE *yyoutput
, int yytype
, YYSTYPE
const * const yyvaluep
, YYLTYPE
const * const yylocationp
)
1023 yy_symbol_value_print (yyoutput
, yytype
, yyvaluep
, yylocationp
)
1026 YYSTYPE
const * const yyvaluep
;
1027 YYLTYPE
const * const yylocationp
;
1032 YYUSE (yylocationp
);
1034 if (yytype
< YYNTOKENS
)
1035 YYPRINT (yyoutput
, yytoknum
[yytype
], *yyvaluep
);
1041 case 3: /* "\"string\"" */
1043 /* Line 670 of yacc.c */
1044 #line 188 "parse-gram.y"
1045 { fputs (quotearg_style (c_quoting_style
, (yyvaluep
->chars
)), stderr
); };
1047 /* Line 670 of yacc.c */
1048 #line 1049 "parse-gram.c"
1050 case 4: /* "\"integer\"" */
1052 /* Line 670 of yacc.c */
1053 #line 199 "parse-gram.y"
1054 { fprintf (stderr
, "%d", (yyvaluep
->integer
)); };
1056 /* Line 670 of yacc.c */
1057 #line 1058 "parse-gram.c"
1059 case 46: /* "\"{...}\"" */
1061 /* Line 670 of yacc.c */
1062 #line 190 "parse-gram.y"
1063 { fprintf (stderr
, "{\n%s\n}", (yyvaluep
->code
)); };
1065 /* Line 670 of yacc.c */
1066 #line 1067 "parse-gram.c"
1068 case 47: /* "\"char\"" */
1070 /* Line 670 of yacc.c */
1071 #line 182 "parse-gram.y"
1072 { fputs (char_name ((yyvaluep
->character
)), stderr
); };
1074 /* Line 670 of yacc.c */
1075 #line 1076 "parse-gram.c"
1077 case 48: /* "\"epilogue\"" */
1079 /* Line 670 of yacc.c */
1080 #line 190 "parse-gram.y"
1081 { fprintf (stderr
, "{\n%s\n}", (yyvaluep
->chars
)); };
1083 /* Line 670 of yacc.c */
1084 #line 1085 "parse-gram.c"
1086 case 50: /* "\"identifier\"" */
1088 /* Line 670 of yacc.c */
1089 #line 195 "parse-gram.y"
1090 { fputs ((yyvaluep
->uniqstr
), stderr
); };
1092 /* Line 670 of yacc.c */
1093 #line 1094 "parse-gram.c"
1095 case 51: /* "\"identifier:\"" */
1097 /* Line 670 of yacc.c */
1098 #line 196 "parse-gram.y"
1099 { fprintf (stderr
, "%s:", (yyvaluep
->uniqstr
)); };
1101 /* Line 670 of yacc.c */
1102 #line 1103 "parse-gram.c"
1104 case 54: /* "\"%{...%}\"" */
1106 /* Line 670 of yacc.c */
1107 #line 190 "parse-gram.y"
1108 { fprintf (stderr
, "{\n%s\n}", (yyvaluep
->chars
)); };
1110 /* Line 670 of yacc.c */
1111 #line 1112 "parse-gram.c"
1113 case 56: /* "\"type\"" */
1115 /* Line 670 of yacc.c */
1116 #line 194 "parse-gram.y"
1117 { fprintf (stderr
, "<%s>", (yyvaluep
->uniqstr
)); };
1119 /* Line 670 of yacc.c */
1120 #line 1121 "parse-gram.c"
1122 case 83: /* "content" */
1124 /* Line 670 of yacc.c */
1125 #line 190 "parse-gram.y"
1126 { fprintf (stderr
, "{\n%s\n}", (yyvaluep
->chars
)); };
1128 /* Line 670 of yacc.c */
1129 #line 1130 "parse-gram.c"
1131 case 84: /* "content.opt" */
1133 /* Line 670 of yacc.c */
1134 #line 190 "parse-gram.y"
1135 { fprintf (stderr
, "{\n%s\n}", (yyvaluep
->chars
)); };
1137 /* Line 670 of yacc.c */
1138 #line 1139 "parse-gram.c"
1140 case 85: /* "braceless" */
1142 /* Line 670 of yacc.c */
1143 #line 190 "parse-gram.y"
1144 { fprintf (stderr
, "{\n%s\n}", (yyvaluep
->chars
)); };
1146 /* Line 670 of yacc.c */
1147 #line 1148 "parse-gram.c"
1151 /* Line 670 of yacc.c */
1152 #line 202 "parse-gram.y"
1153 { fprintf (stderr
, "%s", (yyvaluep
->symbol
)->tag
); };
1155 /* Line 670 of yacc.c */
1156 #line 1157 "parse-gram.c"
1158 case 87: /* "id_colon" */
1160 /* Line 670 of yacc.c */
1161 #line 203 "parse-gram.y"
1162 { fprintf (stderr
, "%s:", (yyvaluep
->symbol
)->tag
); };
1164 /* Line 670 of yacc.c */
1165 #line 1166 "parse-gram.c"
1167 case 88: /* "symbol" */
1169 /* Line 670 of yacc.c */
1170 #line 202 "parse-gram.y"
1171 { fprintf (stderr
, "%s", (yyvaluep
->symbol
)->tag
); };
1173 /* Line 670 of yacc.c */
1174 #line 1175 "parse-gram.c"
1176 case 89: /* "string_as_id" */
1178 /* Line 670 of yacc.c */
1179 #line 202 "parse-gram.y"
1180 { fprintf (stderr
, "%s", (yyvaluep
->symbol
)->tag
); };
1182 /* Line 670 of yacc.c */
1183 #line 1184 "parse-gram.c"
1191 /*--------------------------------.
1192 | Print this symbol on YYOUTPUT. |
1193 `--------------------------------*/
1195 #if (defined __STDC__ || defined __C99__FUNC__ \
1196 || defined __cplusplus || defined _MSC_VER)
1198 yy_symbol_print (FILE *yyoutput
, int yytype
, YYSTYPE
const * const yyvaluep
, YYLTYPE
const * const yylocationp
)
1201 yy_symbol_print (yyoutput
, yytype
, yyvaluep
, yylocationp
)
1204 YYSTYPE
const * const yyvaluep
;
1205 YYLTYPE
const * const yylocationp
;
1208 if (yytype
< YYNTOKENS
)
1209 YYFPRINTF (yyoutput
, "token %s (", yytname
[yytype
]);
1211 YYFPRINTF (yyoutput
, "nterm %s (", yytname
[yytype
]);
1213 YY_LOCATION_PRINT (yyoutput
, *yylocationp
);
1214 YYFPRINTF (yyoutput
, ": ");
1215 yy_symbol_value_print (yyoutput
, yytype
, yyvaluep
, yylocationp
);
1216 YYFPRINTF (yyoutput
, ")");
1219 /*------------------------------------------------------------------.
1220 | yy_stack_print -- Print the state stack from its BOTTOM up to its |
1222 `------------------------------------------------------------------*/
1224 #if (defined __STDC__ || defined __C99__FUNC__ \
1225 || defined __cplusplus || defined _MSC_VER)
1227 yy_stack_print (yytype_int16
*yybottom
, yytype_int16
*yytop
)
1230 yy_stack_print (yybottom
, yytop
)
1231 yytype_int16
*yybottom
;
1232 yytype_int16
*yytop
;
1235 YYFPRINTF (stderr
, "Stack now");
1236 for (; yybottom
<= yytop
; yybottom
++)
1238 int yybot
= *yybottom
;
1239 YYFPRINTF (stderr
, " %d", yybot
);
1241 YYFPRINTF (stderr
, "\n");
1244 # define YY_STACK_PRINT(Bottom, Top) \
1247 yy_stack_print ((Bottom), (Top)); \
1251 /*------------------------------------------------.
1252 | Report that the YYRULE is going to be reduced. |
1253 `------------------------------------------------*/
1255 #if (defined __STDC__ || defined __C99__FUNC__ \
1256 || defined __cplusplus || defined _MSC_VER)
1258 yy_reduce_print (YYSTYPE
*yyvsp
, YYLTYPE
*yylsp
, int yyrule
)
1261 yy_reduce_print (yyvsp
, yylsp
, yyrule
)
1267 int yynrhs
= yyr2
[yyrule
];
1269 unsigned long int yylno
= yyrline
[yyrule
];
1270 YYFPRINTF (stderr
, "Reducing stack by rule %d (line %lu):\n",
1272 /* The symbols being reduced. */
1273 for (yyi
= 0; yyi
< yynrhs
; yyi
++)
1275 fprintf (stderr
, " $%d = ", yyi
+ 1);
1276 yy_symbol_print (stderr
, yyrhs
[yyprhs
[yyrule
] + yyi
],
1277 &(yyvsp
[(yyi
+ 1) - (yynrhs
)])
1278 , &(yylsp
[(yyi
+ 1) - (yynrhs
)]) );
1279 fprintf (stderr
, "\n");
1283 # define YY_REDUCE_PRINT(Rule) \
1286 yy_reduce_print (yyvsp, yylsp, Rule); \
1289 /* Nonzero means print parse trace. It is left uninitialized so that
1290 multiple parsers can coexist. */
1292 #else /* !YYDEBUG */
1293 # define YYDPRINTF(Args)
1294 # define YY_SYMBOL_PRINT(Title, Type, Value, Location)
1295 # define YY_STACK_PRINT(Bottom, Top)
1296 # define YY_REDUCE_PRINT(Rule)
1297 #endif /* !YYDEBUG */
1300 /* YYINITDEPTH -- initial size of the parser's stacks. */
1302 # define YYINITDEPTH 200
1305 /* YYMAXDEPTH -- maximum size the stacks can grow to (effective only
1306 if the built-in stack extension method is used).
1308 Do not make this value too large; the results are undefined if
1309 YYSTACK_ALLOC_MAXIMUM < YYSTACK_BYTES (YYMAXDEPTH)
1310 evaluated with infinite-precision integer arithmetic. */
1313 # define YYMAXDEPTH 10000
1321 # if defined __GLIBC__ && defined _STRING_H
1322 # define yystrlen strlen
1324 /* Return the length of YYSTR. */
1325 #if (defined __STDC__ || defined __C99__FUNC__ \
1326 || defined __cplusplus || defined _MSC_VER)
1328 yystrlen (const char *yystr
)
1336 for (yylen
= 0; yystr
[yylen
]; yylen
++)
1344 # if defined __GLIBC__ && defined _STRING_H && defined _GNU_SOURCE
1345 # define yystpcpy stpcpy
1347 /* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in
1349 #if (defined __STDC__ || defined __C99__FUNC__ \
1350 || defined __cplusplus || defined _MSC_VER)
1352 yystpcpy (char *yydest
, const char *yysrc
)
1355 yystpcpy (yydest
, yysrc
)
1361 const char *yys
= yysrc
;
1363 while ((*yyd
++ = *yys
++) != '\0')
1372 /* Copy to YYRES the contents of YYSTR after stripping away unnecessary
1373 quotes and backslashes, so that it's suitable for yyerror. The
1374 heuristic is that double-quoting is unnecessary unless the string
1375 contains an apostrophe, a comma, or backslash (other than
1376 backslash-backslash). YYSTR is taken from yytname. If YYRES is
1377 null, do not copy; instead, return the length of what the result
1380 yytnamerr (char *yyres
, const char *yystr
)
1385 char const *yyp
= yystr
;
1392 goto do_not_strip_quotes
;
1396 goto do_not_strip_quotes
;
1409 do_not_strip_quotes
: ;
1413 return yystrlen (yystr
);
1415 return yystpcpy (yyres
, yystr
) - yyres
;
1419 /* Copy into YYRESULT an error message about the unexpected token
1420 YYCHAR while in state YYSTATE. Return the number of bytes copied,
1421 including the terminating null byte. If YYRESULT is null, do not
1422 copy anything; just return the number of bytes that would be
1423 copied. As a special case, return 0 if an ordinary "syntax error"
1424 message will do. Return YYSIZE_MAXIMUM if overflow occurs during
1425 size calculation. */
1427 yysyntax_error (char *yyresult
, int yystate
, int yychar
)
1429 int yyn
= yypact
[yystate
];
1431 if (! (YYPACT_NINF
< yyn
&& yyn
<= YYLAST
))
1435 int yytype
= YYTRANSLATE (yychar
);
1436 YYSIZE_T yysize0
= yytnamerr (0, yytname
[yytype
]);
1437 YYSIZE_T yysize
= yysize0
;
1439 int yysize_overflow
= 0;
1440 enum { YYERROR_VERBOSE_ARGS_MAXIMUM
= 5 };
1441 char const *yyarg
[YYERROR_VERBOSE_ARGS_MAXIMUM
];
1445 /* This is so xgettext sees the translatable formats that are
1446 constructed on the fly. */
1447 YY_("syntax error, unexpected %s");
1448 YY_("syntax error, unexpected %s, expecting %s");
1449 YY_("syntax error, unexpected %s, expecting %s or %s");
1450 YY_("syntax error, unexpected %s, expecting %s or %s or %s");
1451 YY_("syntax error, unexpected %s, expecting %s or %s or %s or %s");
1455 static char const yyunexpected
[] = "syntax error, unexpected %s";
1456 static char const yyexpecting
[] = ", expecting %s";
1457 static char const yyor
[] = " or %s";
1458 char yyformat
[sizeof yyunexpected
1459 + sizeof yyexpecting
- 1
1460 + ((YYERROR_VERBOSE_ARGS_MAXIMUM
- 2)
1461 * (sizeof yyor
- 1))];
1462 char const *yyprefix
= yyexpecting
;
1464 /* Start YYX at -YYN if negative to avoid negative indexes in
1466 int yyxbegin
= yyn
< 0 ? -yyn
: 0;
1468 /* Stay within bounds of both yycheck and yytname. */
1469 int yychecklim
= YYLAST
- yyn
+ 1;
1470 int yyxend
= yychecklim
< YYNTOKENS
? yychecklim
: YYNTOKENS
;
1473 yyarg
[0] = yytname
[yytype
];
1474 yyfmt
= yystpcpy (yyformat
, yyunexpected
);
1476 for (yyx
= yyxbegin
; yyx
< yyxend
; ++yyx
)
1477 if (yycheck
[yyx
+ yyn
] == yyx
&& yyx
!= YYTERROR
)
1479 if (yycount
== YYERROR_VERBOSE_ARGS_MAXIMUM
)
1483 yyformat
[sizeof yyunexpected
- 1] = '\0';
1486 yyarg
[yycount
++] = yytname
[yyx
];
1487 yysize1
= yysize
+ yytnamerr (0, yytname
[yyx
]);
1488 yysize_overflow
|= (yysize1
< yysize
);
1490 yyfmt
= yystpcpy (yyfmt
, yyprefix
);
1494 yyf
= YY_(yyformat
);
1495 yysize1
= yysize
+ yystrlen (yyf
);
1496 yysize_overflow
|= (yysize1
< yysize
);
1499 if (yysize_overflow
)
1500 return YYSIZE_MAXIMUM
;
1504 /* Avoid sprintf, as that infringes on the user's name space.
1505 Don't have undefined behavior even if the translation
1506 produced a string with the wrong number of "%s"s. */
1507 char *yyp
= yyresult
;
1509 while ((*yyp
= *yyf
) != '\0')
1511 if (*yyp
== '%' && yyf
[1] == 's' && yyi
< yycount
)
1513 yyp
+= yytnamerr (yyp
, yyarg
[yyi
++]);
1526 #endif /* YYERROR_VERBOSE */
1529 /*-----------------------------------------------.
1530 | Release the memory associated to this symbol. |
1531 `-----------------------------------------------*/
1534 #if (defined __STDC__ || defined __C99__FUNC__ \
1535 || defined __cplusplus || defined _MSC_VER)
1537 yydestruct (const char *yymsg
, int yytype
, YYSTYPE
*yyvaluep
, YYLTYPE
*yylocationp
)
1540 yydestruct (yymsg
, yytype
, yyvaluep
, yylocationp
)
1544 YYLTYPE
*yylocationp
;
1548 YYUSE (yylocationp
);
1552 YY_SYMBOL_PRINT (yymsg
, yytype
, yyvaluep
, yylocationp
);
1563 /* Prevent warnings from -Wmissing-prototypes. */
1565 #ifdef YYPARSE_PARAM
1566 #if defined __STDC__ || defined __cplusplus
1567 int yyparse (void *YYPARSE_PARAM
);
1571 #else /* ! YYPARSE_PARAM */
1572 #if defined __STDC__ || defined __cplusplus
1577 #endif /* ! YYPARSE_PARAM */
1588 #ifdef YYPARSE_PARAM
1589 #if (defined __STDC__ || defined __C99__FUNC__ \
1590 || defined __cplusplus || defined _MSC_VER)
1592 yyparse (void *YYPARSE_PARAM
)
1595 yyparse (YYPARSE_PARAM
)
1596 void *YYPARSE_PARAM
;
1598 #else /* ! YYPARSE_PARAM */
1599 #if (defined __STDC__ || defined __C99__FUNC__ \
1600 || defined __cplusplus || defined _MSC_VER)
1610 /* The lookahead symbol. */
1613 /* The semantic value of the lookahead symbol. */
1616 /* Number of syntax errors so far. */
1618 /* Location data for the lookahead symbol. */
1624 /* Number of tokens to shift before error messages enabled. */
1626 /* Lookahead token as an internal (translated) token number. */
1629 /* Buffer for error messages, and its allocated size. */
1631 char *yymsg
= yymsgbuf
;
1632 YYSIZE_T yymsg_alloc
= sizeof yymsgbuf
;
1635 /* Three stacks and their tools:
1636 `yyss': related to states,
1637 `yyvs': related to semantic values,
1638 `yyls': related to locations.
1640 Refer to the stacks thru separate pointers, to allow yyoverflow
1641 to reallocate them elsewhere. */
1643 /* The state stack. */
1644 yytype_int16 yyssa
[YYINITDEPTH
];
1645 yytype_int16
*yyss
= yyssa
;
1646 yytype_int16
*yyssp
;
1648 /* The semantic value stack. */
1649 YYSTYPE yyvsa
[YYINITDEPTH
];
1650 YYSTYPE
*yyvs
= yyvsa
;
1653 /* The location stack. */
1654 YYLTYPE yylsa
[YYINITDEPTH
];
1655 YYLTYPE
*yyls
= yylsa
;
1657 /* The locations where the error started and ended. */
1658 YYLTYPE yyerror_range
[2];
1660 #define YYPOPSTACK(N) (yyvsp -= (N), yyssp -= (N), yylsp -= (N))
1662 YYSIZE_T yystacksize
= YYINITDEPTH
;
1664 /* The variables used to return semantic value and location from the
1669 /* The number of symbols on the RHS of the reduced rule.
1670 Keep to zero when no symbol should be popped. */
1673 YYDPRINTF ((stderr
, "Starting parse\n"));
1678 yychar
= YYEMPTY
; /* Cause a token to be read. */
1680 /* Initialize stack pointers.
1681 Waste one element of value and location stack
1682 so that they stay on the same level as the state stack.
1683 The wasted elements are never initialized. */
1688 #if YYLTYPE_IS_TRIVIAL
1689 /* Initialize the default location before parsing starts. */
1690 yylloc
.first_line
= yylloc
.last_line
= 1;
1691 yylloc
.first_column
= yylloc
.last_column
= 1;
1695 /* User initialization code. */
1697 /* Line 1082 of yacc.c */
1698 #line 89 "parse-gram.y"
1700 /* Bison's grammar can initial empty locations, hence a default
1701 location is needed. */
1702 boundary_set (&yylloc
.start
, current_file
, 1, 1);
1703 boundary_set (&yylloc
.end
, current_file
, 1, 1);
1706 /* Line 1082 of yacc.c */
1707 #line 1708 "parse-gram.c"
1711 /*------------------------------------------------------------.
1712 | yynewstate -- Push a new state, which is found in yystate. |
1713 `------------------------------------------------------------*/
1715 /* In all cases, when you get here, the value and location stacks
1716 have just been pushed. So pushing a state here evens the stacks. */
1722 if (yyss
+ yystacksize
- 1 <= yyssp
)
1724 /* Get the current used size of the three stacks, in elements. */
1725 YYSIZE_T yysize
= yyssp
- yyss
+ 1;
1729 /* Give user a chance to reallocate the stack. Use copies of
1730 these so that the &'s don't force the real ones into
1732 YYSTYPE
*yyvs1
= yyvs
;
1733 yytype_int16
*yyss1
= yyss
;
1734 YYLTYPE
*yyls1
= yyls
;
1736 /* Each stack pointer address is followed by the size of the
1737 data in use in that stack, in bytes. This used to be a
1738 conditional around just the two extra args, but that might
1739 be undefined if yyoverflow is a macro. */
1740 yyoverflow (YY_("memory exhausted"),
1741 &yyss1
, yysize
* sizeof (*yyssp
),
1742 &yyvs1
, yysize
* sizeof (*yyvsp
),
1743 &yyls1
, yysize
* sizeof (*yylsp
),
1749 #else /* no yyoverflow */
1750 # ifndef YYSTACK_RELOCATE
1751 goto yyexhaustedlab
;
1753 /* Extend the stack our own way. */
1754 if (YYMAXDEPTH
<= yystacksize
)
1755 goto yyexhaustedlab
;
1757 if (YYMAXDEPTH
< yystacksize
)
1758 yystacksize
= YYMAXDEPTH
;
1761 yytype_int16
*yyss1
= yyss
;
1762 union yyalloc
*yyptr
=
1763 (union yyalloc
*) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize
));
1765 goto yyexhaustedlab
;
1766 YYSTACK_RELOCATE (yyss
);
1767 YYSTACK_RELOCATE (yyvs
);
1768 YYSTACK_RELOCATE (yyls
);
1769 # undef YYSTACK_RELOCATE
1771 YYSTACK_FREE (yyss1
);
1774 #endif /* no yyoverflow */
1776 yyssp
= yyss
+ yysize
- 1;
1777 yyvsp
= yyvs
+ yysize
- 1;
1778 yylsp
= yyls
+ yysize
- 1;
1780 YYDPRINTF ((stderr
, "Stack size increased to %lu\n",
1781 (unsigned long int) yystacksize
));
1783 if (yyss
+ yystacksize
- 1 <= yyssp
)
1787 YYDPRINTF ((stderr
, "Entering state %d\n", yystate
));
1789 if (yystate
== YYFINAL
)
1799 /* Do appropriate processing given the current state. Read a
1800 lookahead token if we need one and don't already have one. */
1802 /* First try to decide what to do without reference to lookahead token. */
1803 yyn
= yypact
[yystate
];
1804 if (yyn
== YYPACT_NINF
)
1807 /* Not known => get a lookahead token if don't already have one. */
1809 /* YYCHAR is either YYEMPTY or YYEOF or a valid lookahead symbol. */
1810 if (yychar
== YYEMPTY
)
1812 YYDPRINTF ((stderr
, "Reading a token: "));
1816 if (yychar
<= YYEOF
)
1818 yychar
= yytoken
= YYEOF
;
1819 YYDPRINTF ((stderr
, "Now at end of input.\n"));
1823 yytoken
= YYTRANSLATE (yychar
);
1824 YY_SYMBOL_PRINT ("Next token is", yytoken
, &yylval
, &yylloc
);
1827 /* If the proper action on seeing token YYTOKEN is to reduce or to
1828 detect an error, take that action. */
1830 if (yyn
< 0 || YYLAST
< yyn
|| yycheck
[yyn
] != yytoken
)
1835 if (yyn
== 0 || yyn
== YYTABLE_NINF
)
1841 /* Count tokens shifted since error; after three, turn off error
1846 /* Shift the lookahead token. */
1847 YY_SYMBOL_PRINT ("Shifting", yytoken
, &yylval
, &yylloc
);
1849 /* Discard the shifted token. */
1858 /*-----------------------------------------------------------.
1859 | yydefault -- do the default action for the current state. |
1860 `-----------------------------------------------------------*/
1862 yyn
= yydefact
[yystate
];
1868 /*-----------------------------.
1869 | yyreduce -- Do a reduction. |
1870 `-----------------------------*/
1872 /* yyn is the number of a rule to reduce with. */
1875 /* If YYLEN is nonzero, implement the default value of the action:
1878 Otherwise, the following line sets YYVAL to garbage.
1879 This behavior is undocumented and Bison
1880 users should not rely upon it. Assigning to YYVAL
1881 unconditionally makes the parser a bit smaller, and it avoids a
1882 GCC warning that YYVAL may be used uninitialized. */
1883 yyval
= yyvsp
[1-yylen
];
1885 /* Default location. */
1886 YYLLOC_DEFAULT (yyloc
, (yylsp
- yylen
), yylen
);
1887 YY_REDUCE_PRINT (yyn
);
1892 /* Line 1269 of yacc.c */
1893 #line 225 "parse-gram.y"
1894 { prologue_augment (translate_code ((yyvsp
[(1) - (1)].chars
), (yylsp
[(1) - (1)])), (yylsp
[(1) - (1)]), union_seen
); }
1899 /* Line 1269 of yacc.c */
1900 #line 226 "parse-gram.y"
1901 { debug_flag
= true; }
1906 /* Line 1269 of yacc.c */
1907 #line 227 "parse-gram.y"
1908 { muscle_insert ((yyvsp
[(2) - (3)].chars
), (yyvsp
[(3) - (3)].chars
)); }
1913 /* Line 1269 of yacc.c */
1914 #line 228 "parse-gram.y"
1915 { defines_flag
= true; }
1920 /* Line 1269 of yacc.c */
1921 #line 230 "parse-gram.y"
1923 defines_flag
= true;
1924 spec_defines_file
= xstrdup ((yyvsp
[(2) - (2)].chars
));
1930 /* Line 1269 of yacc.c */
1931 #line 234 "parse-gram.y"
1932 { error_verbose
= true; }
1937 /* Line 1269 of yacc.c */
1938 #line 235 "parse-gram.y"
1939 { expected_sr_conflicts
= (yyvsp
[(2) - (2)].integer
); }
1944 /* Line 1269 of yacc.c */
1945 #line 236 "parse-gram.y"
1946 { expected_rr_conflicts
= (yyvsp
[(2) - (2)].integer
); }
1951 /* Line 1269 of yacc.c */
1952 #line 237 "parse-gram.y"
1953 { spec_file_prefix
= (yyvsp
[(2) - (2)].chars
); }
1958 /* Line 1269 of yacc.c */
1959 #line 238 "parse-gram.y"
1960 { spec_file_prefix
= (yyvsp
[(3) - (3)].chars
); }
1965 /* Line 1269 of yacc.c */
1966 #line 240 "parse-gram.y"
1968 nondeterministic_parser
= true;
1975 /* Line 1269 of yacc.c */
1976 #line 245 "parse-gram.y"
1978 muscle_code_grow ("initial_action", translate_symbol_action ((yyvsp
[(2) - (2)].code
), (yylsp
[(2) - (2)])), (yylsp
[(2) - (2)]));
1984 /* Line 1269 of yacc.c */
1985 #line 248 "parse-gram.y"
1986 { add_param ("lex_param", (yyvsp
[(2) - (2)].code
), (yylsp
[(2) - (2)])); }
1991 /* Line 1269 of yacc.c */
1992 #line 249 "parse-gram.y"
1993 { locations_flag
= true; }
1998 /* Line 1269 of yacc.c */
1999 #line 250 "parse-gram.y"
2000 { spec_name_prefix
= (yyvsp
[(2) - (2)].chars
); }
2005 /* Line 1269 of yacc.c */
2006 #line 251 "parse-gram.y"
2007 { spec_name_prefix
= (yyvsp
[(3) - (3)].chars
); }
2012 /* Line 1269 of yacc.c */
2013 #line 252 "parse-gram.y"
2014 { no_lines_flag
= true; }
2019 /* Line 1269 of yacc.c */
2020 #line 253 "parse-gram.y"
2021 { nondeterministic_parser
= true; }
2026 /* Line 1269 of yacc.c */
2027 #line 254 "parse-gram.y"
2028 { spec_outfile
= (yyvsp
[(2) - (2)].chars
); }
2033 /* Line 1269 of yacc.c */
2034 #line 255 "parse-gram.y"
2035 { spec_outfile
= (yyvsp
[(3) - (3)].chars
); }
2040 /* Line 1269 of yacc.c */
2041 #line 256 "parse-gram.y"
2042 { add_param ("parse_param", (yyvsp
[(2) - (2)].code
), (yylsp
[(2) - (2)])); }
2047 /* Line 1269 of yacc.c */
2048 #line 257 "parse-gram.y"
2049 { pure_parser
= true; }
2054 /* Line 1269 of yacc.c */
2055 #line 258 "parse-gram.y"
2056 { push_parser
= true; }
2061 /* Line 1269 of yacc.c */
2062 #line 259 "parse-gram.y"
2063 { version_check (&(yylsp
[(2) - (2)]), (yyvsp
[(2) - (2)].chars
)); }
2068 /* Line 1269 of yacc.c */
2069 #line 260 "parse-gram.y"
2070 { skeleton
= (yyvsp
[(2) - (2)].chars
); }
2075 /* Line 1269 of yacc.c */
2076 #line 261 "parse-gram.y"
2077 { token_table_flag
= true; }
2082 /* Line 1269 of yacc.c */
2083 #line 262 "parse-gram.y"
2084 { report_flag
= report_states
; }
2089 /* Line 1269 of yacc.c */
2090 #line 263 "parse-gram.y"
2091 { yacc_flag
= true; }
2096 /* Line 1269 of yacc.c */
2097 #line 271 "parse-gram.y"
2099 grammar_start_symbol_set ((yyvsp
[(2) - (2)].symbol
), (yylsp
[(2) - (2)]));
2105 /* Line 1269 of yacc.c */
2106 #line 275 "parse-gram.y"
2109 const char *action
= translate_symbol_action ((yyvsp
[(2) - (3)].code
), (yylsp
[(2) - (3)]));
2110 for (list
= (yyvsp
[(3) - (3)].list
); list
; list
= list
->next
)
2111 symbol_list_destructor_set (list
, action
, (yylsp
[(2) - (3)]));
2112 symbol_list_free ((yyvsp
[(3) - (3)].list
));
2118 /* Line 1269 of yacc.c */
2119 #line 283 "parse-gram.y"
2122 const char *action
= translate_symbol_action ((yyvsp
[(2) - (3)].code
), (yylsp
[(2) - (3)]));
2123 for (list
= (yyvsp
[(3) - (3)].list
); list
; list
= list
->next
)
2124 symbol_list_printer_set (list
, action
, (yylsp
[(2) - (3)]));
2125 symbol_list_free ((yyvsp
[(3) - (3)].list
));
2131 /* Line 1269 of yacc.c */
2132 #line 291 "parse-gram.y"
2134 default_prec
= true;
2140 /* Line 1269 of yacc.c */
2141 #line 295 "parse-gram.y"
2143 default_prec
= false;
2149 /* Line 1269 of yacc.c */
2150 #line 298 "parse-gram.y"
2151 { prologue_augment ((yyvsp
[(2) - (2)].chars
), (yylsp
[(2) - (2)]), true); }
2156 /* Line 1269 of yacc.c */
2157 #line 299 "parse-gram.y"
2158 { prologue_augment ((yyvsp
[(2) - (2)].chars
), (yylsp
[(2) - (2)]), false); }
2163 /* Line 1269 of yacc.c */
2164 #line 300 "parse-gram.y"
2165 { muscle_code_grow ("provides", (yyvsp
[(2) - (2)].chars
), (yylsp
[(2) - (2)])); }
2170 /* Line 1269 of yacc.c */
2171 #line 301 "parse-gram.y"
2172 { muscle_code_grow ("requires", (yyvsp
[(2) - (2)].chars
), (yylsp
[(2) - (2)])); }
2177 /* Line 1269 of yacc.c */
2178 #line 312 "parse-gram.y"
2184 /* Line 1269 of yacc.c */
2185 #line 313 "parse-gram.y"
2186 { muscle_code_grow ("union_name", (yyvsp
[(1) - (1)].uniqstr
), (yylsp
[(1) - (1)])); }
2191 /* Line 1269 of yacc.c */
2192 #line 318 "parse-gram.y"
2194 char const *body
= (yyvsp
[(3) - (3)].code
);
2196 /* Concatenate the %union bodies. If this is the first %union, make sure
2197 the synchronization line appears after the opening '{' so as not to
2198 confuse Doxygen. Otherwise, turn the previous %union's trailing '}'
2199 into '\n', and omit the new %union's leading '{'. */
2202 muscle_grow ("stype", "{", "");
2206 char *code
= muscle_find ("stype");
2207 code
[strlen (code
) - 1] = '\n';
2212 muscle_code_grow ("stype", body
, (yylsp
[(3) - (3)]));
2218 /* Line 1269 of yacc.c */
2219 #line 345 "parse-gram.y"
2220 { current_class
= nterm_sym
; }
2225 /* Line 1269 of yacc.c */
2226 #line 346 "parse-gram.y"
2228 current_class
= unknown_sym
;
2229 current_type
= NULL
;
2235 /* Line 1269 of yacc.c */
2236 #line 350 "parse-gram.y"
2237 { current_class
= token_sym
; }
2242 /* Line 1269 of yacc.c */
2243 #line 351 "parse-gram.y"
2245 current_class
= unknown_sym
;
2246 current_type
= NULL
;
2252 /* Line 1269 of yacc.c */
2253 #line 356 "parse-gram.y"
2257 for (list
= (yyvsp
[(3) - (3)].list
); list
; list
= list
->next
)
2258 symbol_type_set (list
->content
.sym
, (yyvsp
[(2) - (3)].uniqstr
), (yylsp
[(2) - (3)]));
2259 symbol_list_free ((yyvsp
[(3) - (3)].list
));
2265 /* Line 1269 of yacc.c */
2266 #line 367 "parse-gram.y"
2270 for (list
= (yyvsp
[(3) - (3)].list
); list
; list
= list
->next
)
2272 symbol_type_set (list
->content
.sym
, current_type
, (yylsp
[(2) - (3)]));
2273 symbol_precedence_set (list
->content
.sym
, current_prec
, (yyvsp
[(1) - (3)].assoc
), (yylsp
[(1) - (3)]));
2275 symbol_list_free ((yyvsp
[(3) - (3)].list
));
2276 current_type
= NULL
;
2282 /* Line 1269 of yacc.c */
2283 #line 381 "parse-gram.y"
2284 { (yyval
.assoc
) = left_assoc
; }
2289 /* Line 1269 of yacc.c */
2290 #line 382 "parse-gram.y"
2291 { (yyval
.assoc
) = right_assoc
; }
2296 /* Line 1269 of yacc.c */
2297 #line 383 "parse-gram.y"
2298 { (yyval
.assoc
) = non_assoc
; }
2303 /* Line 1269 of yacc.c */
2304 #line 387 "parse-gram.y"
2305 { current_type
= NULL
; }
2310 /* Line 1269 of yacc.c */
2311 #line 388 "parse-gram.y"
2312 { current_type
= (yyvsp
[(1) - (1)].uniqstr
); tag_seen
= true; }
2317 /* Line 1269 of yacc.c */
2318 #line 394 "parse-gram.y"
2319 { (yyval
.list
) = symbol_list_sym_new ((yyvsp
[(1) - (1)].symbol
), (yylsp
[(1) - (1)])); }
2324 /* Line 1269 of yacc.c */
2325 #line 396 "parse-gram.y"
2326 { (yyval
.list
) = symbol_list_prepend ((yyvsp
[(1) - (2)].list
), symbol_list_sym_new ((yyvsp
[(2) - (2)].symbol
), (yylsp
[(2) - (2)]))); }
2331 /* Line 1269 of yacc.c */
2332 #line 400 "parse-gram.y"
2333 { (yyval
.list
) = (yyvsp
[(1) - (1)].list
); }
2338 /* Line 1269 of yacc.c */
2339 #line 401 "parse-gram.y"
2340 { (yyval
.list
) = symbol_list_prepend ((yyvsp
[(1) - (2)].list
), (yyvsp
[(2) - (2)].list
)); }
2345 /* Line 1269 of yacc.c */
2346 #line 405 "parse-gram.y"
2347 { (yyval
.list
) = symbol_list_sym_new ((yyvsp
[(1) - (1)].symbol
), (yylsp
[(1) - (1)])); }
2352 /* Line 1269 of yacc.c */
2353 #line 406 "parse-gram.y"
2354 { (yyval
.list
) = symbol_list_type_new ((yyvsp
[(1) - (1)].uniqstr
), (yylsp
[(1) - (1)])); }
2359 /* Line 1269 of yacc.c */
2360 #line 407 "parse-gram.y"
2361 { (yyval
.list
) = symbol_list_default_tagged_new ((yylsp
[(1) - (1)])); }
2366 /* Line 1269 of yacc.c */
2367 #line 408 "parse-gram.y"
2368 { (yyval
.list
) = symbol_list_default_tagless_new ((yylsp
[(1) - (1)])); }
2373 /* Line 1269 of yacc.c */
2374 #line 414 "parse-gram.y"
2376 current_type
= (yyvsp
[(1) - (1)].uniqstr
);
2383 /* Line 1269 of yacc.c */
2384 #line 419 "parse-gram.y"
2386 symbol_class_set ((yyvsp
[(1) - (1)].symbol
), current_class
, (yylsp
[(1) - (1)]), true);
2387 symbol_type_set ((yyvsp
[(1) - (1)].symbol
), current_type
, (yylsp
[(1) - (1)]));
2393 /* Line 1269 of yacc.c */
2394 #line 424 "parse-gram.y"
2396 symbol_class_set ((yyvsp
[(1) - (2)].symbol
), current_class
, (yylsp
[(1) - (2)]), true);
2397 symbol_type_set ((yyvsp
[(1) - (2)].symbol
), current_type
, (yylsp
[(1) - (2)]));
2398 symbol_user_token_number_set ((yyvsp
[(1) - (2)].symbol
), (yyvsp
[(2) - (2)].integer
), (yylsp
[(2) - (2)]));
2404 /* Line 1269 of yacc.c */
2405 #line 430 "parse-gram.y"
2407 symbol_class_set ((yyvsp
[(1) - (2)].symbol
), current_class
, (yylsp
[(1) - (2)]), true);
2408 symbol_type_set ((yyvsp
[(1) - (2)].symbol
), current_type
, (yylsp
[(1) - (2)]));
2409 symbol_make_alias ((yyvsp
[(1) - (2)].symbol
), (yyvsp
[(2) - (2)].symbol
), (yyloc
));
2415 /* Line 1269 of yacc.c */
2416 #line 436 "parse-gram.y"
2418 symbol_class_set ((yyvsp
[(1) - (3)].symbol
), current_class
, (yylsp
[(1) - (3)]), true);
2419 symbol_type_set ((yyvsp
[(1) - (3)].symbol
), current_type
, (yylsp
[(1) - (3)]));
2420 symbol_user_token_number_set ((yyvsp
[(1) - (3)].symbol
), (yyvsp
[(2) - (3)].integer
), (yylsp
[(2) - (3)]));
2421 symbol_make_alias ((yyvsp
[(1) - (3)].symbol
), (yyvsp
[(3) - (3)].symbol
), (yyloc
));
2427 /* Line 1269 of yacc.c */
2428 #line 466 "parse-gram.y"
2436 /* Line 1269 of yacc.c */
2437 #line 472 "parse-gram.y"
2438 { current_lhs
= (yyvsp
[(1) - (1)].symbol
); current_lhs_location
= (yylsp
[(1) - (1)]); }
2443 /* Line 1269 of yacc.c */
2444 #line 476 "parse-gram.y"
2445 { grammar_current_rule_end ((yylsp
[(1) - (1)])); }
2450 /* Line 1269 of yacc.c */
2451 #line 477 "parse-gram.y"
2452 { grammar_current_rule_end ((yylsp
[(3) - (3)])); }
2457 /* Line 1269 of yacc.c */
2458 #line 483 "parse-gram.y"
2459 { grammar_current_rule_begin (current_lhs
, current_lhs_location
); }
2464 /* Line 1269 of yacc.c */
2465 #line 485 "parse-gram.y"
2466 { grammar_current_rule_symbol_append ((yyvsp
[(2) - (2)].symbol
), (yylsp
[(2) - (2)])); }
2471 /* Line 1269 of yacc.c */
2472 #line 487 "parse-gram.y"
2473 { grammar_current_rule_action_append ((yyvsp
[(2) - (2)].code
), (yylsp
[(2) - (2)])); }
2478 /* Line 1269 of yacc.c */
2479 #line 489 "parse-gram.y"
2480 { grammar_current_rule_prec_set ((yyvsp
[(3) - (3)].symbol
), (yylsp
[(3) - (3)])); }
2485 /* Line 1269 of yacc.c */
2486 #line 491 "parse-gram.y"
2487 { grammar_current_rule_dprec_set ((yyvsp
[(3) - (3)].integer
), (yylsp
[(3) - (3)])); }
2492 /* Line 1269 of yacc.c */
2493 #line 493 "parse-gram.y"
2494 { grammar_current_rule_merge_set ((yyvsp
[(3) - (3)].uniqstr
), (yylsp
[(3) - (3)])); }
2499 /* Line 1269 of yacc.c */
2500 #line 509 "parse-gram.y"
2502 static char one
[] = "1";
2503 (yyval
.chars
) = one
;
2509 /* Line 1269 of yacc.c */
2510 #line 519 "parse-gram.y"
2512 (yyvsp
[(1) - (1)].code
)[strlen ((yyvsp
[(1) - (1)].code
)) - 1] = '\n';
2513 (yyval
.chars
) = translate_code ((yyvsp
[(1) - (1)].code
) + 1, (yylsp
[(1) - (1)]));
2519 /* Line 1269 of yacc.c */
2520 #line 535 "parse-gram.y"
2521 { (yyval
.symbol
) = symbol_from_uniqstr ((yyvsp
[(1) - (1)].uniqstr
), (yylsp
[(1) - (1)])); }
2526 /* Line 1269 of yacc.c */
2527 #line 537 "parse-gram.y"
2529 (yyval
.symbol
) = symbol_get (char_name ((yyvsp
[(1) - (1)].character
)), (yylsp
[(1) - (1)]));
2530 symbol_class_set ((yyval
.symbol
), token_sym
, (yylsp
[(1) - (1)]), false);
2531 symbol_user_token_number_set ((yyval
.symbol
), (yyvsp
[(1) - (1)].character
), (yylsp
[(1) - (1)]));
2537 /* Line 1269 of yacc.c */
2538 #line 545 "parse-gram.y"
2539 { (yyval
.symbol
) = symbol_from_uniqstr ((yyvsp
[(1) - (1)].uniqstr
), (yylsp
[(1) - (1)])); }
2544 /* Line 1269 of yacc.c */
2545 #line 557 "parse-gram.y"
2547 (yyval
.symbol
) = symbol_get (quotearg_style (c_quoting_style
, (yyvsp
[(1) - (1)].chars
)), (yylsp
[(1) - (1)]));
2548 symbol_class_set ((yyval
.symbol
), token_sym
, (yylsp
[(1) - (1)]), false);
2554 /* Line 1269 of yacc.c */
2555 #line 566 "parse-gram.y"
2557 muscle_code_grow ("epilogue", translate_code ((yyvsp
[(2) - (2)].chars
), (yylsp
[(2) - (2)])), (yylsp
[(2) - (2)]));
2558 gram_scanner_last_string_free ();
2564 /* Line 1269 of yacc.c */
2565 #line 2566 "parse-gram.c"
2568 YY_SYMBOL_PRINT ("-> $$ =", yyr1
[yyn
], &yyval
, &yyloc
);
2572 YY_STACK_PRINT (yyss
, yyssp
);
2577 /* Now `shift' the result of the reduction. Determine what state
2578 that goes to, based on the state we popped back to and the rule
2579 number reduced by. */
2583 yystate
= yypgoto
[yyn
- YYNTOKENS
] + *yyssp
;
2584 if (0 <= yystate
&& yystate
<= YYLAST
&& yycheck
[yystate
] == *yyssp
)
2585 yystate
= yytable
[yystate
];
2587 yystate
= yydefgoto
[yyn
- YYNTOKENS
];
2592 /*------------------------------------.
2593 | yyerrlab -- here on detecting error |
2594 `------------------------------------*/
2596 /* If not already recovering from an error, report this error. */
2600 #if ! YYERROR_VERBOSE
2601 yyerror (YY_("syntax error"));
2604 YYSIZE_T yysize
= yysyntax_error (0, yystate
, yychar
);
2605 if (yymsg_alloc
< yysize
&& yymsg_alloc
< YYSTACK_ALLOC_MAXIMUM
)
2607 YYSIZE_T yyalloc
= 2 * yysize
;
2608 if (! (yysize
<= yyalloc
&& yyalloc
<= YYSTACK_ALLOC_MAXIMUM
))
2609 yyalloc
= YYSTACK_ALLOC_MAXIMUM
;
2610 if (yymsg
!= yymsgbuf
)
2611 YYSTACK_FREE (yymsg
);
2612 yymsg
= (char *) YYSTACK_ALLOC (yyalloc
);
2614 yymsg_alloc
= yyalloc
;
2618 yymsg_alloc
= sizeof yymsgbuf
;
2622 if (0 < yysize
&& yysize
<= yymsg_alloc
)
2624 (void) yysyntax_error (yymsg
, yystate
, yychar
);
2629 yyerror (YY_("syntax error"));
2631 goto yyexhaustedlab
;
2637 yyerror_range
[0] = yylloc
;
2639 if (yyerrstatus
== 3)
2641 /* If just tried and failed to reuse lookahead token after an
2642 error, discard it. */
2644 if (yychar
<= YYEOF
)
2646 /* Return failure if at end of input. */
2647 if (yychar
== YYEOF
)
2652 yydestruct ("Error: discarding",
2653 yytoken
, &yylval
, &yylloc
);
2658 /* Else will try to reuse lookahead token after shifting the error
2663 /*---------------------------------------------------.
2664 | yyerrorlab -- error raised explicitly by YYERROR. |
2665 `---------------------------------------------------*/
2668 /* Pacify compilers like GCC when the user code never invokes
2669 YYERROR and the label yyerrorlab therefore never appears in user
2671 if (/*CONSTCOND*/ 0)
2674 yyerror_range
[0] = yylsp
[1-yylen
];
2675 /* Do not reclaim the symbols of the rule which action triggered
2679 YY_STACK_PRINT (yyss
, yyssp
);
2684 /*-------------------------------------------------------------.
2685 | yyerrlab1 -- common code for both syntax error and YYERROR. |
2686 `-------------------------------------------------------------*/
2688 yyerrstatus
= 3; /* Each real token shifted decrements this. */
2692 yyn
= yypact
[yystate
];
2693 if (yyn
!= YYPACT_NINF
)
2696 if (0 <= yyn
&& yyn
<= YYLAST
&& yycheck
[yyn
] == YYTERROR
)
2704 /* Pop the current state because it cannot handle the error token. */
2708 yyerror_range
[0] = *yylsp
;
2709 yydestruct ("Error: popping",
2710 yystos
[yystate
], yyvsp
, yylsp
);
2713 YY_STACK_PRINT (yyss
, yyssp
);
2718 yyerror_range
[1] = yylloc
;
2719 /* Using YYLLOC is tempting, but would change the location of
2720 the lookahead. YYLOC is available though. */
2721 YYLLOC_DEFAULT (yyloc
, (yyerror_range
- 1), 2);
2724 /* Shift the error token. */
2725 YY_SYMBOL_PRINT ("Shifting", yystos
[yyn
], yyvsp
, yylsp
);
2731 /*-------------------------------------.
2732 | yyacceptlab -- YYACCEPT comes here. |
2733 `-------------------------------------*/
2738 /*-----------------------------------.
2739 | yyabortlab -- YYABORT comes here. |
2740 `-----------------------------------*/
2746 /*-------------------------------------------------.
2747 | yyexhaustedlab -- memory exhaustion comes here. |
2748 `-------------------------------------------------*/
2750 yyerror (YY_("memory exhausted"));
2756 if (yychar
!= YYEMPTY
)
2757 yydestruct ("Cleanup: discarding lookahead",
2758 yytoken
, &yylval
, &yylloc
);
2759 /* Do not reclaim the symbols of the rule which action triggered
2760 this YYABORT or YYACCEPT. */
2762 YY_STACK_PRINT (yyss
, yyssp
);
2763 while (yyssp
!= yyss
)
2765 yydestruct ("Cleanup: popping",
2766 yystos
[*yyssp
], yyvsp
, yylsp
);
2771 YYSTACK_FREE (yyss
);
2774 if (yymsg
!= yymsgbuf
)
2775 YYSTACK_FREE (yymsg
);
2777 /* Make sure YYID is used. */
2778 return YYID (yyresult
);
2783 /* Line 1486 of yacc.c */
2784 #line 572 "parse-gram.y"
2788 /* Return the location of the left-hand side of a rule whose
2789 right-hand side is RHS[1] ... RHS[N]. Ignore empty nonterminals in
2790 the right-hand side, and return an empty location equal to the end
2791 boundary of RHS[0] if the right-hand side is empty. */
2794 lloc_default (YYLTYPE
const *rhs
, int n
)
2799 /* SGI MIPSpro 7.4.1m miscompiles "loc.start = loc.end = rhs[n].end;".
2800 The bug is fixed in 7.4.2m, but play it safe for now. */
2801 loc
.start
= rhs
[n
].end
;
2802 loc
.end
= rhs
[n
].end
;
2804 /* Ignore empty nonterminals the start of the the right-hand side.
2805 Do not bother to ignore them at the end of the right-hand side,
2806 since empty nonterminals have the same end as their predecessors. */
2807 for (i
= 1; i
<= n
; i
++)
2808 if (! equal_boundaries (rhs
[i
].start
, rhs
[i
].end
))
2810 loc
.start
= rhs
[i
].start
;
2818 /* Add a lex-param or a parse-param (depending on TYPE) with
2819 declaration DECL and location LOC. */
2822 add_param (char const *type
, char *decl
, location loc
)
2824 static char const alphanum
[26 + 26 + 1 + 10] =
2825 "abcdefghijklmnopqrstuvwxyz"
2826 "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
2829 char const *name_start
= NULL
;
2832 /* Stop on last actual character. */
2833 for (p
= decl
; p
[1]; p
++)
2835 || ! memchr (alphanum
, p
[-1], sizeof alphanum
))
2836 && memchr (alphanum
, p
[0], sizeof alphanum
- 10))
2839 /* Strip the surrounding '{' and '}', and any blanks just inside
2841 while (*--p
== ' ' || *p
== '\t')
2844 while (*++decl
== ' ' || *decl
== '\t')
2848 complain_at (loc
, _("missing identifier in parameter declaration"));
2855 memchr (alphanum
, name_start
[name_len
], sizeof alphanum
);
2859 name
= xmalloc (name_len
+ 1);
2860 memcpy (name
, name_start
, name_len
);
2861 name
[name_len
] = '\0';
2862 muscle_pair_list_grow (type
, decl
, name
);
2866 gram_scanner_last_string_free ();
2871 version_check (location
const *loc
, char const *version
)
2873 if (strverscmp (version
, PACKAGE_VERSION
) > 0)
2875 complain_at (*loc
, "require bison %s, but have %s",
2876 version
, PACKAGE_VERSION
);
2882 gram_error (location
const *loc
, char const *msg
)
2884 complain_at (*loc
, "%s", msg
);
2888 token_name (int type
)
2890 return yytname
[YYTRANSLATE (type
)];
2901 buf
[0] = '\''; buf
[1] = c
; buf
[2] = '\''; buf
[3] = '\0';
2902 return quotearg_style (escape_quoting_style
, buf
);