-/* A Bison parser, made by GNU Bison 2.4.388-53f03. */
+/* A Bison parser, made by GNU Bison 2.4.483-4ad39-dirty. */
/* Implementation for Bison's Yacc-like parsers in C
- Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006,
- 2007, 2008, 2009 Free Software Foundation, Inc.
+ Copyright (C) 1984, 1989-1990, 2000-2010 Free Software Foundation, Inc.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
#define YYBISON 1
/* Bison version. */
-#define YYBISON_VERSION "2.4.388-53f03"
+#define YYBISON_VERSION "2.4.483-4ad39-dirty"
/* Skeleton name. */
#define YYSKELETON_NAME "yacc.c"
#define yylloc gram_lloc
/* Copy the first part of user declarations. */
-/* Line 191 of yacc.c */
-#line 1 "parse-gram.y"
+/* Line 252 of yacc.c */
+#line 1 "src/parse-gram.y"
/* Bison Grammar Parser -*- C -*-
- Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 Free Software
- Foundation, Inc.
+ Copyright (C) 2002-2010 Free Software Foundation, Inc.
This file is part of Bison, the GNU Compiler Compiler.
static char const *char_name (char);
-/** Add a lex-param or a parse-param.
- *
- * \param type \a lex_param or \a parse_param
- * \param decl the formal argument
- * \param loc the location in the source.
- */
-static void add_param (char const *type, char *decl, location loc);
-
-
-static symbol_class current_class = unknown_sym;
-static uniqstr current_type = NULL;
-static symbol *current_lhs;
-static location current_lhs_location;
-static named_ref *current_lhs_named_ref;
-static int current_prec = 0;
-
-#define YYTYPE_INT16 int_fast16_t
-#define YYTYPE_INT8 int_fast8_t
-#define YYTYPE_UINT16 uint_fast16_t
-#define YYTYPE_UINT8 uint_fast8_t
-
-/* Line 191 of yacc.c */
-#line 154 "src/parse-gram.c"
+/* Line 252 of yacc.c */
+#line 131 "src/parse-gram.c"
/* Enabling traces. */
#ifndef YYDEBUG
# define YYTOKEN_TABLE 0
#endif
+/* "%code requires" blocks. */
+/* Line 272 of yacc.c */
+#line 201 "src/parse-gram.y"
+
+# ifndef PARAM_TYPE
+# define PARAM_TYPE
+ typedef enum
+ {
+ param_none = 0,
+ param_lex = 1 << 0,
+ param_parse = 1 << 1,
+ param_both = param_lex | param_parse
+ } param_type;
+# endif
+
+
+/* Line 272 of yacc.c */
+#line 168 "src/parse-gram.c"
/* Tokens. */
#ifndef YYTOKENTYPE
PERCENT_GLR_PARSER = 281,
PERCENT_INITIAL_ACTION = 282,
PERCENT_LANGUAGE = 283,
- PERCENT_LEX_PARAM = 284,
- PERCENT_NAME_PREFIX = 285,
- PERCENT_NO_DEFAULT_PREC = 286,
- PERCENT_NO_LINES = 287,
- PERCENT_NONDETERMINISTIC_PARSER = 288,
- PERCENT_OUTPUT = 289,
- PERCENT_PARSE_PARAM = 290,
- PERCENT_REQUIRE = 291,
- PERCENT_SKELETON = 292,
- PERCENT_START = 293,
- PERCENT_TOKEN_TABLE = 294,
- PERCENT_VERBOSE = 295,
- PERCENT_YACC = 296,
- BRACED_CODE = 297,
- CHAR = 298,
- EPILOGUE = 299,
- EQUAL = 300,
- ID = 301,
- ID_COLON = 302,
- PERCENT_PERCENT = 303,
- PIPE = 304,
- PROLOGUE = 305,
- SEMICOLON = 306,
- TAG = 307,
- TAG_ANY = 308,
- TAG_NONE = 309,
- BRACKETED_ID = 310,
- PERCENT_UNION = 311
+ PERCENT_NAME_PREFIX = 284,
+ PERCENT_NO_DEFAULT_PREC = 285,
+ PERCENT_NO_LINES = 286,
+ PERCENT_NONDETERMINISTIC_PARSER = 287,
+ PERCENT_OUTPUT = 288,
+ PERCENT_REQUIRE = 289,
+ PERCENT_SKELETON = 290,
+ PERCENT_START = 291,
+ PERCENT_TOKEN_TABLE = 292,
+ PERCENT_VERBOSE = 293,
+ PERCENT_YACC = 294,
+ BRACED_CODE = 295,
+ BRACKETED_ID = 296,
+ CHAR = 297,
+ EPILOGUE = 298,
+ EQUAL = 299,
+ ID = 300,
+ ID_COLON = 301,
+ PERCENT_PERCENT = 302,
+ PIPE = 303,
+ PROLOGUE = 304,
+ SEMICOLON = 305,
+ TAG = 306,
+ TAG_ANY = 307,
+ TAG_NONE = 308,
+ PERCENT_PARAM = 309,
+ PERCENT_UNION = 310
};
#endif
/* Tokens. */
#define PERCENT_GLR_PARSER 281
#define PERCENT_INITIAL_ACTION 282
#define PERCENT_LANGUAGE 283
-#define PERCENT_LEX_PARAM 284
-#define PERCENT_NAME_PREFIX 285
-#define PERCENT_NO_DEFAULT_PREC 286
-#define PERCENT_NO_LINES 287
-#define PERCENT_NONDETERMINISTIC_PARSER 288
-#define PERCENT_OUTPUT 289
-#define PERCENT_PARSE_PARAM 290
-#define PERCENT_REQUIRE 291
-#define PERCENT_SKELETON 292
-#define PERCENT_START 293
-#define PERCENT_TOKEN_TABLE 294
-#define PERCENT_VERBOSE 295
-#define PERCENT_YACC 296
-#define BRACED_CODE 297
-#define CHAR 298
-#define EPILOGUE 299
-#define EQUAL 300
-#define ID 301
-#define ID_COLON 302
-#define PERCENT_PERCENT 303
-#define PIPE 304
-#define PROLOGUE 305
-#define SEMICOLON 306
-#define TAG 307
-#define TAG_ANY 308
-#define TAG_NONE 309
-#define BRACKETED_ID 310
-#define PERCENT_UNION 311
+#define PERCENT_NAME_PREFIX 284
+#define PERCENT_NO_DEFAULT_PREC 285
+#define PERCENT_NO_LINES 286
+#define PERCENT_NONDETERMINISTIC_PARSER 287
+#define PERCENT_OUTPUT 288
+#define PERCENT_REQUIRE 289
+#define PERCENT_SKELETON 290
+#define PERCENT_START 291
+#define PERCENT_TOKEN_TABLE 292
+#define PERCENT_VERBOSE 293
+#define PERCENT_YACC 294
+#define BRACED_CODE 295
+#define BRACKETED_ID 296
+#define CHAR 297
+#define EPILOGUE 298
+#define EQUAL 299
+#define ID 300
+#define ID_COLON 301
+#define PERCENT_PERCENT 302
+#define PIPE 303
+#define PROLOGUE 304
+#define SEMICOLON 305
+#define TAG 306
+#define TAG_ANY 307
+#define TAG_NONE 308
+#define PERCENT_PARAM 309
+#define PERCENT_UNION 310
#if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED
typedef union YYSTYPE
{
-/* Line 216 of yacc.c */
-#line 94 "parse-gram.y"
+/* Line 277 of yacc.c */
+#line 87 "src/parse-gram.y"
+ assoc assoc;
+ char *code;
+ char const *chars;
+ int integer;
+ named_ref *named_ref;
symbol *symbol;
symbol_list *list;
- int integer;
- char const *chars;
- char *code;
- assoc assoc;
uniqstr uniqstr;
unsigned char character;
- named_ref *named_ref;
+
+/* Line 277 of yacc.c */
+#line 225 "src/parse-gram.y"
+
+ param_type param;
-/* Line 216 of yacc.c */
-#line 316 "src/parse-gram.c"
+/* Line 277 of yacc.c */
+#line 314 "src/parse-gram.c"
} YYSTYPE;
# define YYSTYPE_IS_TRIVIAL 1
# define yystype YYSTYPE /* obsolescent; will be withdrawn */
/* Copy the second part of user declarations. */
-/* Line 266 of yacc.c */
-#line 340 "src/parse-gram.c"
+/* Line 327 of yacc.c */
+#line 338 "src/parse-gram.c"
+/* Unqualified %code blocks. */
+/* Line 328 of yacc.c */
+#line 55 "src/parse-gram.y"
+
+ static int current_prec = 0;
+ static location current_lhs_location;
+ static named_ref *current_lhs_named_ref;
+ static symbol *current_lhs;
+ static symbol_class current_class = unknown_sym;
+ static uniqstr current_type = NULL;
+
+ #define YYTYPE_INT16 int_fast16_t
+ #define YYTYPE_INT8 int_fast8_t
+ #define YYTYPE_UINT16 uint_fast16_t
+ #define YYTYPE_UINT8 uint_fast8_t
+
+/* Line 328 of yacc.c */
+#line 214 "src/parse-gram.y"
+
+ /** Add a lex-param and/or a parse-param.
+ *
+ * \param type where to push this formal argument.
+ * \param decl the formal argument. Destroyed.
+ * \param loc the location in the source.
+ */
+ static void add_param (param_type type, char *decl, location loc);
+ static param_type current_param = param_none;
+
+
+/* Line 328 of yacc.c */
+#line 369 "src/parse-gram.c"
#ifdef short
# undef short
#define YYSIZE_MAXIMUM ((YYSIZE_T) -1)
#ifndef YY_
-# if YYENABLE_NLS
+# if defined YYENABLE_NLS && YYENABLE_NLS
# if ENABLE_NLS
# include <libintl.h> /* INFRINGES ON USER NAME SPACE */
# define YY_(msgid) dgettext ("bison-runtime", msgid)
/* YYFINAL -- State number of the termination state. */
#define YYFINAL 3
/* YYLAST -- Last index in YYTABLE. */
-#define YYLAST 160
+#define YYLAST 162
/* YYNTOKENS -- Number of terminals. */
-#define YYNTOKENS 57
+#define YYNTOKENS 56
/* YYNNTS -- Number of nonterminals. */
-#define YYNNTS 34
+#define YYNNTS 36
/* YYNRULES -- Number of rules. */
-#define YYNRULES 106
+#define YYNRULES 109
/* YYNSTATES -- Number of states. */
-#define YYNSTATES 146
+#define YYNSTATES 148
/* YYTRANSLATE[YYX] -- Symbol number corresponding to YYX as returned
by yylex, with out-of-bounds checking. */
#define YYUNDEFTOK 2
-#define YYMAXUTOK 311
+#define YYMAXUTOK 310
#define YYTRANSLATE(YYX) \
((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK)
25, 26, 27, 28, 29, 30, 31, 32, 33, 34,
35, 36, 37, 38, 39, 40, 41, 42, 43, 44,
45, 46, 47, 48, 49, 50, 51, 52, 53, 54,
- 55, 56
+ 55
};
#if YYDEBUG
/* YYRLINEYYN -- Source line where rule number YYN was defined. */
static const yytype_uint16 yyrline[] =
{
- 0, 207, 207, 215, 217, 221, 222, 232, 236, 241,
- 242, 247, 252, 253, 254, 255, 256, 261, 270, 271,
- 272, 273, 274, 275, 276, 277, 278, 279, 280, 304,
- 305, 306, 307, 311, 312, 313, 317, 324, 331, 335,
- 339, 346, 361, 362, 366, 378, 378, 383, 383, 388,
- 399, 414, 415, 416, 417, 421, 422, 427, 429, 434,
- 435, 440, 442, 447, 448, 452, 453, 454, 455, 460,
- 465, 470, 476, 482, 493, 494, 503, 504, 510, 511,
- 512, 519, 519, 524, 525, 526, 531, 533, 535, 537,
- 539, 541, 546, 548, 559, 560, 565, 566, 575, 595,
- 597, 606, 611, 612, 617, 624, 626
+ 0, 250, 250, 258, 260, 264, 265, 275, 279, 284,
+ 285, 290, 295, 296, 297, 298, 299, 304, 313, 314,
+ 315, 316, 317, 318, 319, 320, 320, 321, 322, 346,
+ 347, 348, 349, 353, 354, 363, 364, 365, 369, 376,
+ 383, 387, 391, 398, 413, 414, 418, 430, 430, 435,
+ 435, 440, 451, 466, 467, 468, 469, 473, 474, 479,
+ 481, 486, 487, 492, 494, 499, 500, 504, 505, 506,
+ 507, 512, 517, 522, 528, 534, 545, 546, 555, 556,
+ 562, 563, 564, 571, 571, 576, 577, 578, 583, 585,
+ 587, 589, 591, 593, 598, 600, 611, 612, 617, 618,
+ 619, 628, 648, 650, 659, 664, 665, 670, 677, 679
};
#endif
"\"%default-prec\"", "\"%define\"", "\"%defines\"", "\"%error-verbose\"",
"\"%expect\"", "\"%expect-rr\"", "\"%<flag>\"", "\"%file-prefix\"",
"\"%glr-parser\"", "\"%initial-action\"", "\"%language\"",
- "\"%lex-param\"", "\"%name-prefix\"", "\"%no-default-prec\"",
- "\"%no-lines\"", "\"%nondeterministic-parser\"", "\"%output\"",
- "\"%parse-param\"", "\"%require\"", "\"%skeleton\"", "\"%start\"",
- "\"%token-table\"", "\"%verbose\"", "\"%yacc\"", "\"{...}\"", "\"char\"",
- "\"epilogue\"", "\"=\"", "\"identifier\"", "\"identifier:\"", "\"%%\"",
- "\"|\"", "\"%{...%}\"", "\";\"", "\"<tag>\"", "\"<*>\"", "\"<>\"",
- "\"[identifier]\"", "\"%union\"", "$accept", "input",
- "prologue_declarations", "prologue_declaration", "grammar_declaration",
- "union_name", "symbol_declaration", "$@1", "$@2",
+ "\"%name-prefix\"", "\"%no-default-prec\"", "\"%no-lines\"",
+ "\"%nondeterministic-parser\"", "\"%output\"", "\"%require\"",
+ "\"%skeleton\"", "\"%start\"", "\"%token-table\"", "\"%verbose\"",
+ "\"%yacc\"", "\"{...}\"", "\"[identifier]\"", "\"char\"", "\"epilogue\"",
+ "\"=\"", "\"identifier\"", "\"identifier:\"", "\"%%\"", "\"|\"",
+ "\"%{...%}\"", "\";\"", "\"<tag>\"", "\"<*>\"", "\"<>\"", "\"%param\"",
+ "\"%union\"", "$accept", "input", "prologue_declarations",
+ "prologue_declaration", "$@1", "params", "grammar_declaration",
+ "union_name", "symbol_declaration", "$@2", "$@3",
"precedence_declaration", "precedence_declarator", "tag.opt",
"symbols.prec", "symbol.prec", "symbols.1", "generic_symlist",
"generic_symlist_item", "symbol_def", "symbol_defs.1", "grammar",
- "rules_or_grammar_declaration", "rules", "$@3", "rhses.1", "rhs",
+ "rules_or_grammar_declaration", "rules", "$@4", "rhses.1", "rhs",
"named_ref.opt", "variable", "content.opt", "braceless", "id",
"id_colon", "symbol", "string_as_id", "epilogue.opt", 0
};
275, 276, 277, 278, 279, 280, 281, 282, 283, 284,
285, 286, 287, 288, 289, 290, 291, 292, 293, 294,
295, 296, 297, 298, 299, 300, 301, 302, 303, 304,
- 305, 306, 307, 308, 309, 310, 311
+ 305, 306, 307, 308, 309, 310
};
# endif
-#define YYPACT_NINF -53
+#define YYPACT_NINF -137
#define yypact_value_is_default(yystate) \
- ((yystate) == (-53))
+ ((yystate) == (-137))
-#define YYTABLE_NINF -106
+#define YYTABLE_NINF -109
#define yytable_value_is_error(yytable_value) \
- (YYID (0) \
- || ((yytable_value) == (0)))
+ YYID (0)
/* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
STATE-NUM. */
static const yytype_int16 yypact[] =
{
- -53, 5, 102, -53, -53, -53, -10, 8, 27, -53,
- -53, -53, -53, 18, -53, 32, 55, -53, 70, 77,
- -53, 17, -53, 43, 91, 53, 41, -53, -53, -53,
- 42, 54, 94, 96, 0, -53, -53, -53, 16, -53,
- -53, 56, -53, -53, -53, -53, 48, 30, 30, 0,
- 13, 13, -53, 61, -53, -53, -53, 101, -53, -53,
- -53, -53, 113, -53, -53, -53, -53, 114, -53, 115,
- -53, -53, -53, -53, -53, -53, -53, -53, -53, 93,
- -53, 95, 1, -53, -53, 50, -53, 61, -53, 0,
- -53, -53, 30, 33, 30, 0, -53, -53, -53, -53,
- 13, -53, -53, 13, -53, -53, -53, -53, -53, -53,
- -53, -53, 103, -53, -53, -53, -53, -53, 0, -53,
- 141, -53, 145, -53, -53, -53, -53, -53, -53, -53,
- -53, 39, 37, -53, -53, 0, 147, 97, 50, 50,
- 37, -53, -53, -53, -53, -53
+ -137, 20, 106, -137, -137, -137, 19, -1, 36, -137,
+ -137, -137, -137, 13, -137, 0, 79, -137, 89, 90,
+ -137, 41, -137, 55, 93, 46, -137, -137, -137, 47,
+ 94, 95, 35, -137, -137, -137, 16, -137, -137, -137,
+ 54, -137, -137, -137, -137, 49, 33, 33, 35, 12,
+ 12, -137, 61, -137, -137, -137, 29, -137, -137, -137,
+ -137, 100, -137, -137, -137, 101, -137, 103, -137, -137,
+ -137, -137, -137, -137, -137, -137, 57, -137, 58, 1,
+ -137, -137, 68, 80, -137, 61, -137, 35, -137, -137,
+ 33, 56, 33, 35, -137, -137, -137, -137, 12, -137,
+ -137, 12, -137, -137, -137, -137, -137, -137, -137, -137,
+ -137, 78, -137, -137, -137, -137, -137, 82, -137, 35,
+ -137, 142, -137, 144, -137, -137, -137, -137, -137, -137,
+ -137, -137, -137, 18, 27, -137, -137, 35, 145, 97,
+ 68, 68, 27, -137, -137, -137, -137, -137
};
/* YYDEFACT[S] -- default reduction number in state S. Performed when
is an error. */
static const yytype_uint8 yydefact[] =
{
- 3, 0, 0, 1, 47, 45, 0, 0, 0, 51,
- 52, 53, 54, 0, 38, 0, 9, 11, 0, 0,
- 7, 0, 16, 0, 0, 0, 0, 39, 22, 23,
- 0, 0, 0, 0, 0, 29, 30, 31, 0, 6,
- 32, 42, 4, 5, 34, 33, 55, 0, 0, 0,
- 0, 0, 98, 0, 40, 95, 94, 96, 10, 12,
- 13, 14, 0, 17, 18, 19, 20, 0, 24, 0,
- 26, 27, 28, 104, 100, 99, 102, 35, 103, 0,
- 101, 0, 0, 76, 78, 92, 43, 0, 56, 0,
- 69, 74, 48, 70, 46, 49, 61, 66, 67, 68,
- 36, 63, 65, 37, 41, 97, 8, 15, 21, 25,
- 80, 79, 0, 77, 2, 93, 81, 44, 50, 57,
- 59, 75, 71, 72, 62, 64, 106, 86, 58, 60,
- 73, 82, 83, 86, 85, 0, 0, 0, 92, 92,
- 84, 89, 90, 91, 88, 87
+ 3, 0, 0, 1, 49, 47, 0, 0, 0, 53,
+ 54, 55, 56, 0, 40, 0, 9, 11, 0, 0,
+ 7, 0, 16, 0, 0, 0, 41, 21, 22, 0,
+ 0, 0, 0, 29, 30, 31, 0, 6, 32, 25,
+ 44, 4, 5, 36, 35, 57, 0, 0, 0, 0,
+ 0, 101, 0, 42, 97, 96, 98, 10, 12, 13,
+ 14, 0, 17, 18, 19, 0, 23, 0, 27, 28,
+ 107, 103, 102, 105, 37, 106, 0, 104, 0, 0,
+ 78, 80, 94, 0, 45, 0, 58, 0, 71, 76,
+ 50, 72, 48, 51, 63, 68, 69, 70, 38, 65,
+ 67, 39, 43, 100, 99, 8, 15, 20, 24, 82,
+ 81, 0, 79, 2, 95, 83, 34, 26, 46, 52,
+ 59, 61, 77, 73, 74, 64, 66, 109, 88, 33,
+ 60, 62, 75, 84, 85, 88, 87, 0, 0, 0,
+ 94, 94, 86, 91, 92, 93, 90, 89
};
/* YYPGOTO[NTERM-NUM]. */
static const yytype_int16 yypgoto[] =
{
- -53, -53, -53, -53, 152, -53, -53, -53, -53, -53,
- -53, -53, -53, 38, -53, 104, -32, -3, 109, -53,
- 78, -53, -53, -53, 26, -46, -53, -53, -49, -17,
- -53, -34, -52, -53
+ -137, -137, -137, -137, -137, -137, 148, -137, -137, -137,
+ -137, -137, -137, -137, -137, 32, -137, 102, -9, -4,
+ 107, -137, 83, -137, -137, -137, 22, -136, -137, -137,
+ -12, -11, -137, -32, -40, -137
};
/* YYDEFGOTO[NTERM-NUM]. */
static const yytype_int16 yydefgoto[] =
{
- -1, 1, 2, 42, 81, 87, 44, 48, 47, 45,
- 46, 89, 118, 119, 95, 100, 101, 91, 92, 82,
- 83, 84, 127, 131, 132, 116, 57, 106, 54, 76,
- 85, 102, 78, 114
+ -1, 1, 2, 41, 83, 117, 78, 85, 43, 47,
+ 46, 44, 45, 87, 119, 120, 93, 98, 99, 89,
+ 90, 79, 80, 81, 128, 133, 134, 115, 56, 105,
+ 53, 73, 82, 100, 75, 113
};
/* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If
positive, shift that token. If negative, reduce the rule which
- number is the opposite. If zero or YYTABLE_NINF, syntax error. */
+ number is the opposite. If YYTABLE_NINF, syntax error. */
static const yytype_int16 yytable[] =
{
- 77, -105, 79, 73, 104, 3, 4, 5, 6, 7,
- 8, 9, 10, 11, 12, 96, 73, 79, 13, 14,
- 61, 4, 5, 6, 7, 8, 9, 10, 11, 12,
- 93, 93, 27, 13, 14, 55, 73, 122, 117, 34,
- 73, 123, 49, 74, 66, 68, 75, 27, 80, 112,
- 50, 135, 136, 137, 34, 120, 74, 41, 58, 75,
- 52, 124, 62, 80, 53, 97, 98, 99, 125, 51,
- 130, 125, 41, 74, 59, 93, 75, 93, 56, 138,
- 74, 60, 90, 75, 120, 63, 67, 69, 133, 121,
- 134, 121, 144, 145, 64, 65, 70, 71, 139, 72,
- 88, 141, 86, 52, 105, 115, 139, 4, 5, 6,
- 7, 8, 9, 10, 11, 12, 107, 108, 109, 13,
- 14, 15, 16, 17, 18, 19, 20, 21, 22, 23,
- 24, 25, 26, 27, 28, 29, 30, 31, 32, 33,
- 34, 35, 36, 37, 110, 129, 111, 126, 73, 143,
- 38, 142, 39, 40, 43, 103, 128, 94, 41, 140,
- 113
+ 74, -108, 76, 54, 146, 147, 4, 5, 6, 7,
+ 8, 9, 10, 11, 12, 70, 94, 76, 13, 14,
+ 3, 4, 5, 6, 7, 8, 9, 10, 11, 12,
+ 70, 26, 103, 13, 14, 91, 91, 32, 70, 49,
+ 102, 137, 138, 139, 60, 55, 26, 77, 111, 64,
+ 66, 124, 32, 51, 71, 121, 40, 72, 52, 70,
+ 123, 125, 77, 95, 96, 97, 135, 140, 136, 71,
+ 48, 40, 72, 118, 104, 71, 50, 71, 72, 91,
+ 72, 91, 57, 132, 88, 61, 122, 121, 122, 126,
+ 65, 67, 126, 58, 59, 62, 63, 68, 69, 84,
+ 86, 51, 141, 106, 107, 143, 108, 109, 110, 114,
+ 141, 4, 5, 6, 7, 8, 9, 10, 11, 12,
+ 116, 127, 129, 13, 14, 15, 16, 17, 18, 19,
+ 20, 21, 22, 23, 24, 25, 26, 27, 28, 29,
+ 30, 31, 32, 33, 34, 35, 131, 70, 145, 144,
+ 42, 130, 101, 36, 92, 37, 38, 142, 0, 0,
+ 39, 40, 112
};
-static const yytype_uint8 yycheck[] =
+static const yytype_int16 yycheck[] =
{
- 34, 0, 1, 3, 53, 0, 5, 6, 7, 8,
- 9, 10, 11, 12, 13, 49, 3, 1, 17, 18,
- 3, 5, 6, 7, 8, 9, 10, 11, 12, 13,
- 47, 48, 31, 17, 18, 3, 3, 4, 87, 38,
- 3, 93, 52, 43, 3, 3, 46, 31, 47, 48,
- 42, 14, 15, 16, 38, 89, 43, 56, 3, 46,
- 42, 95, 45, 47, 46, 52, 53, 54, 100, 42,
- 122, 103, 56, 43, 4, 92, 46, 94, 46, 42,
- 43, 4, 52, 46, 118, 42, 45, 45, 49, 92,
- 51, 94, 138, 139, 3, 42, 42, 3, 132, 3,
- 52, 135, 46, 42, 3, 55, 140, 5, 6, 7,
- 8, 9, 10, 11, 12, 13, 3, 3, 3, 17,
- 18, 19, 20, 21, 22, 23, 24, 25, 26, 27,
- 28, 29, 30, 31, 32, 33, 34, 35, 36, 37,
- 38, 39, 40, 41, 51, 4, 51, 44, 3, 52,
- 48, 4, 50, 51, 2, 51, 118, 48, 56, 133,
- 82
+ 32, 0, 1, 3, 140, 141, 5, 6, 7, 8,
+ 9, 10, 11, 12, 13, 3, 48, 1, 17, 18,
+ 0, 5, 6, 7, 8, 9, 10, 11, 12, 13,
+ 3, 30, 3, 17, 18, 46, 47, 36, 3, 40,
+ 52, 14, 15, 16, 3, 45, 30, 46, 47, 3,
+ 3, 91, 36, 40, 42, 87, 55, 45, 45, 3,
+ 4, 93, 46, 51, 52, 53, 48, 40, 50, 42,
+ 51, 55, 45, 85, 45, 42, 40, 42, 45, 90,
+ 45, 92, 3, 123, 51, 44, 90, 119, 92, 98,
+ 44, 44, 101, 4, 4, 40, 3, 3, 3, 45,
+ 51, 40, 134, 3, 3, 137, 3, 50, 50, 41,
+ 142, 5, 6, 7, 8, 9, 10, 11, 12, 13,
+ 40, 43, 40, 17, 18, 19, 20, 21, 22, 23,
+ 24, 25, 26, 27, 28, 29, 30, 31, 32, 33,
+ 34, 35, 36, 37, 38, 39, 4, 3, 51, 4,
+ 2, 119, 50, 47, 47, 49, 50, 135, -1, -1,
+ 54, 55, 79
};
/* STOS_[STATE-NUM] -- The (internal number of the) accessing
symbol of state STATE-NUM. */
static const yytype_uint8 yystos[] =
{
- 0, 58, 59, 0, 5, 6, 7, 8, 9, 10,
+ 0, 57, 58, 0, 5, 6, 7, 8, 9, 10,
11, 12, 13, 17, 18, 19, 20, 21, 22, 23,
24, 25, 26, 27, 28, 29, 30, 31, 32, 33,
- 34, 35, 36, 37, 38, 39, 40, 41, 48, 50,
- 51, 56, 60, 61, 63, 66, 67, 65, 64, 52,
- 42, 42, 42, 46, 85, 3, 46, 83, 3, 4,
- 4, 3, 45, 42, 3, 42, 3, 45, 3, 45,
- 42, 3, 3, 3, 43, 46, 86, 88, 89, 1,
- 47, 61, 76, 77, 78, 87, 46, 62, 52, 68,
- 52, 74, 75, 86, 75, 71, 88, 52, 53, 54,
- 72, 73, 88, 72, 85, 3, 84, 3, 3, 3,
- 51, 51, 48, 77, 90, 55, 82, 85, 69, 70,
- 88, 74, 4, 89, 88, 73, 44, 79, 70, 4,
- 89, 80, 81, 49, 51, 14, 15, 16, 42, 88,
- 81, 88, 4, 52, 82, 82
+ 34, 35, 36, 37, 38, 39, 47, 49, 50, 54,
+ 55, 59, 62, 64, 67, 68, 66, 65, 51, 40,
+ 40, 40, 45, 86, 3, 45, 84, 3, 4, 4,
+ 3, 44, 40, 3, 3, 44, 3, 44, 3, 3,
+ 3, 42, 45, 87, 89, 90, 1, 46, 62, 77,
+ 78, 79, 88, 60, 45, 63, 51, 69, 51, 75,
+ 76, 87, 76, 72, 89, 51, 52, 53, 73, 74,
+ 89, 73, 86, 3, 45, 85, 3, 3, 3, 50,
+ 50, 47, 78, 91, 41, 83, 40, 61, 86, 70,
+ 71, 89, 75, 4, 90, 89, 74, 43, 80, 40,
+ 71, 4, 90, 81, 82, 48, 50, 14, 15, 16,
+ 40, 89, 82, 89, 4, 51, 83, 83
};
/* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */
static const yytype_uint8 yyr1[] =
{
- 0, 57, 58, 59, 59, 60, 60, 60, 60, 60,
- 60, 60, 60, 60, 60, 60, 60, 60, 60, 60,
- 60, 60, 60, 60, 60, 60, 60, 60, 60, 60,
- 60, 60, 60, 61, 61, 61, 61, 61, 61, 61,
- 61, 61, 62, 62, 61, 64, 63, 65, 63, 63,
- 66, 67, 67, 67, 67, 68, 68, 69, 69, 70,
- 70, 71, 71, 72, 72, 73, 73, 73, 73, 74,
- 74, 74, 74, 74, 75, 75, 76, 76, 77, 77,
- 77, 79, 78, 80, 80, 80, 81, 81, 81, 81,
- 81, 81, 82, 82, 83, 83, 84, 84, 85, 86,
- 86, 87, 88, 88, 89, 90, 90
+ 0, 56, 57, 58, 58, 59, 59, 59, 59, 59,
+ 59, 59, 59, 59, 59, 59, 59, 59, 59, 59,
+ 59, 59, 59, 59, 59, 60, 59, 59, 59, 59,
+ 59, 59, 59, 61, 61, 62, 62, 62, 62, 62,
+ 62, 62, 62, 62, 63, 63, 62, 65, 64, 66,
+ 64, 64, 67, 68, 68, 68, 68, 69, 69, 70,
+ 70, 71, 71, 72, 72, 73, 73, 74, 74, 74,
+ 74, 75, 75, 75, 75, 75, 76, 76, 77, 77,
+ 78, 78, 78, 80, 79, 81, 81, 81, 82, 82,
+ 82, 82, 82, 82, 83, 83, 84, 84, 85, 85,
+ 85, 86, 87, 87, 88, 89, 89, 90, 91, 91
};
/* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
{
0, 2, 4, 0, 2, 1, 1, 1, 3, 1,
2, 1, 2, 2, 2, 3, 1, 2, 2, 2,
- 2, 3, 1, 1, 2, 3, 2, 2, 2, 1,
- 1, 1, 1, 1, 1, 2, 3, 3, 1, 1,
- 2, 3, 0, 1, 3, 0, 3, 0, 3, 3,
- 3, 1, 1, 1, 1, 0, 1, 1, 2, 1,
- 2, 1, 2, 1, 2, 1, 1, 1, 1, 1,
- 1, 2, 2, 3, 1, 2, 1, 2, 1, 2,
- 2, 0, 4, 1, 3, 2, 0, 3, 3, 3,
- 3, 3, 0, 1, 1, 1, 0, 1, 1, 1,
- 1, 1, 1, 1, 1, 0, 2
+ 3, 1, 1, 2, 3, 0, 3, 2, 2, 1,
+ 1, 1, 1, 2, 1, 1, 1, 2, 3, 3,
+ 1, 1, 2, 3, 0, 1, 3, 0, 3, 0,
+ 3, 3, 3, 1, 1, 1, 1, 0, 1, 1,
+ 2, 1, 2, 1, 2, 1, 2, 1, 1, 1,
+ 1, 1, 1, 2, 2, 3, 1, 2, 1, 2,
+ 1, 2, 2, 0, 4, 1, 3, 2, 0, 3,
+ 3, 3, 3, 3, 0, 1, 1, 1, 0, 1,
+ 1, 1, 1, 1, 1, 1, 1, 1, 0, 2
};
/* Like YYERROR except do call yyerror. This remains here temporarily
to ease the transition to the new meaning of YYERROR, for GCC.
- Once GCC version 2 has supplanted version 1, this can go. */
+ Once GCC version 2 has supplanted version 1, this can go. However,
+ YYFAIL appears to be in use. Nevertheless, it is formally deprecated
+ in Bison 2.4.2's NEWS entry, where a plan to phase it out is
+ discussed. */
#define YYFAIL goto yyerrlab
+#if defined YYFAIL
+ /* This is here to suppress warnings from the GCC cpp's
+ -Wunused-macros. Normally we don't worry about that warning, but
+ some users do, and we want to make it easy for users to remove
+ YYFAIL uses, which will produce warnings from Bison 2.5. */
+#endif
#define YYRECOVERING() (!!yyerrstatus)
{ \
yychar = (Token); \
yylval = (Value); \
- yytoken = YYTRANSLATE (yychar); \
YYPOPSTACK (1); \
goto yybackup; \
} \
we won't break user code: when these are the locations we know. */
#ifndef YY_LOCATION_PRINT
-# if YYLTYPE_IS_TRIVIAL
+# if defined YYLTYPE_IS_TRIVIAL && YYLTYPE_IS_TRIVIAL
# define YY_LOCATION_PRINT(File, Loc) \
fprintf (File, "%d.%d-%d.%d", \
(Loc).first_line, (Loc).first_column, \
{
case 3: // "string"
-/* Line 654 of yacc.c */
-#line 183 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 174 "src/parse-gram.y"
{ fputs (quotearg_style (c_quoting_style, ((*yyvaluep).chars)), stderr); }
-/* Line 654 of yacc.c */
-#line 998 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1034 "src/parse-gram.c"
break;
case 4: // "integer"
-/* Line 654 of yacc.c */
-#line 196 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 187 "src/parse-gram.y"
{ fprintf (stderr, "%d", ((*yyvaluep).integer)); }
-/* Line 654 of yacc.c */
-#line 1007 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1043 "src/parse-gram.c"
break;
case 24: // "%<flag>"
-/* Line 654 of yacc.c */
-#line 192 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 183 "src/parse-gram.y"
{ fprintf (stderr, "%%%s", ((*yyvaluep).uniqstr)); }
-/* Line 654 of yacc.c */
-#line 1016 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1052 "src/parse-gram.c"
break;
- case 42: // "{...}"
+ case 40: // "{...}"
-/* Line 654 of yacc.c */
-#line 185 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 176 "src/parse-gram.y"
{ fprintf (stderr, "{\n%s\n}", ((*yyvaluep).code)); }
-/* Line 654 of yacc.c */
-#line 1025 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1061 "src/parse-gram.c"
+ break;
+
+ case 41: // "[identifier]"
+
+/* Line 729 of yacc.c */
+#line 181 "src/parse-gram.y"
+ { fprintf (stderr, "[%s]", ((*yyvaluep).uniqstr)); }
+/* Line 729 of yacc.c */
+#line 1070 "src/parse-gram.c"
break;
- case 43: // "char"
+ case 42: // "char"
-/* Line 654 of yacc.c */
-#line 177 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 168 "src/parse-gram.y"
{ fputs (char_name (((*yyvaluep).character)), stderr); }
-/* Line 654 of yacc.c */
-#line 1034 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1079 "src/parse-gram.c"
break;
- case 44: // "epilogue"
+ case 43: // "epilogue"
-/* Line 654 of yacc.c */
-#line 185 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 176 "src/parse-gram.y"
{ fprintf (stderr, "{\n%s\n}", ((*yyvaluep).chars)); }
-/* Line 654 of yacc.c */
-#line 1043 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1088 "src/parse-gram.c"
break;
- case 46: // "identifier"
+ case 45: // "identifier"
-/* Line 654 of yacc.c */
-#line 190 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 180 "src/parse-gram.y"
{ fputs (((*yyvaluep).uniqstr), stderr); }
-/* Line 654 of yacc.c */
-#line 1052 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1097 "src/parse-gram.c"
break;
- case 47: // "identifier:"
+ case 46: // "identifier:"
-/* Line 654 of yacc.c */
-#line 191 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 182 "src/parse-gram.y"
{ fprintf (stderr, "%s:", ((*yyvaluep).uniqstr)); }
-/* Line 654 of yacc.c */
-#line 1061 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1106 "src/parse-gram.c"
break;
- case 50: // "%{...%}"
+ case 49: // "%{...%}"
-/* Line 654 of yacc.c */
-#line 185 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 176 "src/parse-gram.y"
{ fprintf (stderr, "{\n%s\n}", ((*yyvaluep).chars)); }
-/* Line 654 of yacc.c */
-#line 1070 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1115 "src/parse-gram.c"
break;
- case 52: // "<tag>"
+ case 51: // "<tag>"
-/* Line 654 of yacc.c */
-#line 193 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 184 "src/parse-gram.y"
{ fprintf (stderr, "<%s>", ((*yyvaluep).uniqstr)); }
-/* Line 654 of yacc.c */
-#line 1079 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1124 "src/parse-gram.c"
+ break;
+
+ case 54: // "%param"
+
+/* Line 729 of yacc.c */
+#line 230 "src/parse-gram.y"
+ {
+ switch (((*yyvaluep).param))
+ {
+#define CASE(In, Out) \
+ case param_ ## In: fputs ("%" #Out, stderr); break
+ CASE(lex, lex-param);
+ CASE(parse, parse-param);
+ CASE(both, param);
+#undef CASE
+ case param_none: aver (false); break;
+ }
+}
+/* Line 729 of yacc.c */
+#line 1144 "src/parse-gram.c"
+ break;
+
+ case 71: // symbol.prec
+
+/* Line 729 of yacc.c */
+#line 190 "src/parse-gram.y"
+ { fprintf (stderr, "%s", ((*yyvaluep).symbol)->tag); }
+/* Line 729 of yacc.c */
+#line 1153 "src/parse-gram.c"
break;
- case 83: // variable
+ case 84: // variable
-/* Line 654 of yacc.c */
-#line 190 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 180 "src/parse-gram.y"
{ fputs (((*yyvaluep).uniqstr), stderr); }
-/* Line 654 of yacc.c */
-#line 1088 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1162 "src/parse-gram.c"
break;
- case 84: // content.opt
+ case 85: // content.opt
-/* Line 654 of yacc.c */
-#line 185 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 176 "src/parse-gram.y"
{ fprintf (stderr, "{\n%s\n}", ((*yyvaluep).chars)); }
-/* Line 654 of yacc.c */
-#line 1097 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1171 "src/parse-gram.c"
break;
- case 85: // braceless
+ case 86: // braceless
-/* Line 654 of yacc.c */
-#line 185 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 176 "src/parse-gram.y"
{ fprintf (stderr, "{\n%s\n}", ((*yyvaluep).chars)); }
-/* Line 654 of yacc.c */
-#line 1106 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1180 "src/parse-gram.c"
break;
- case 86: // id
+ case 87: // id
-/* Line 654 of yacc.c */
-#line 199 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 190 "src/parse-gram.y"
{ fprintf (stderr, "%s", ((*yyvaluep).symbol)->tag); }
-/* Line 654 of yacc.c */
-#line 1115 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1189 "src/parse-gram.c"
break;
- case 87: // id_colon
+ case 88: // id_colon
-/* Line 654 of yacc.c */
-#line 200 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 191 "src/parse-gram.y"
{ fprintf (stderr, "%s:", ((*yyvaluep).symbol)->tag); }
-/* Line 654 of yacc.c */
-#line 1124 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1198 "src/parse-gram.c"
break;
- case 88: // symbol
+ case 89: // symbol
-/* Line 654 of yacc.c */
-#line 199 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 190 "src/parse-gram.y"
{ fprintf (stderr, "%s", ((*yyvaluep).symbol)->tag); }
-/* Line 654 of yacc.c */
-#line 1133 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1207 "src/parse-gram.c"
break;
- case 89: // string_as_id
+ case 90: // string_as_id
-/* Line 654 of yacc.c */
-#line 199 "parse-gram.y"
+/* Line 729 of yacc.c */
+#line 190 "src/parse-gram.y"
{ fprintf (stderr, "%s", ((*yyvaluep).symbol)->tag); }
-/* Line 654 of yacc.c */
-#line 1142 "src/parse-gram.c"
+/* Line 729 of yacc.c */
+#line 1216 "src/parse-gram.c"
break;
default:
}
# endif
-/* Copy into YYRESULT an error message about the unexpected token
- YYTOKEN while in state YYSTATE. Return the number of bytes copied,
- including the terminating null byte. If YYRESULT is null, do not
- copy anything; just return the number of bytes that would be
- copied. As a special case, return 0 if an ordinary "syntax error"
- message will do. Return YYSIZE_MAXIMUM if overflow occurs during
- size calculation. */
-static YYSIZE_T
-yysyntax_error (char *yyresult, int yystate, int yytoken)
+/* Copy into *YYMSG, which is of size *YYMSG_ALLOC, an error message
+ about the unexpected token YYTOKEN while in state YYSTATE.
+
+ Return 0 if *YYMSG was successfully written. Return 1 if an ordinary
+ "syntax error" message will suffice instead. Return 2 if *YYMSG is
+ not large enough to hold the message. In the last case, also set
+ *YYMSG_ALLOC to either (a) the required number of bytes or (b) zero
+ if the required number of bytes is too large to store. */
+static int
+yysyntax_error (YYSIZE_T *yymsg_alloc, char **yymsg,
+ int yystate, int yytoken)
{
int yyn = yypact[yystate];
if (! (YYPACT_NINF < yyn && yyn <= YYLAST))
- return 0;
+ return 1;
else
{
YYSIZE_T yysize0 = yytnamerr (0, yytname[yytoken]);
YYSIZE_T yysize = yysize0;
YYSIZE_T yysize1;
- int yysize_overflow = 0;
enum { YYERROR_VERBOSE_ARGS_MAXIMUM = 5 };
/* Internationalized format string. */
const char *yyformat = 0;
}
yyarg[yycount++] = yytname[yyx];
yysize1 = yysize + yytnamerr (0, yytname[yyx]);
- yysize_overflow |= (yysize1 < yysize);
+ if (! (yysize <= yysize1
+ && yysize1 <= YYSTACK_ALLOC_MAXIMUM))
+ {
+ /* Overflow. */
+ *yymsg_alloc = 0;
+ return 2;
+ }
yysize = yysize1;
}
- switch (yycount)
+ switch (yycount)
{
#define YYCASE_(N, S) \
case N: \
}
yysize1 = yysize + yystrlen (yyformat);
- yysize_overflow |= (yysize1 < yysize);
+ if (! (yysize <= yysize1 && yysize1 <= YYSTACK_ALLOC_MAXIMUM))
+ {
+ /* Overflow. */
+ *yymsg_alloc = 0;
+ return 2;
+ }
yysize = yysize1;
- if (yysize_overflow)
- return YYSIZE_MAXIMUM;
+ if (*yymsg_alloc < yysize)
+ {
+ *yymsg_alloc = 2 * yysize;
+ if (! (yysize <= *yymsg_alloc
+ && *yymsg_alloc <= YYSTACK_ALLOC_MAXIMUM))
+ *yymsg_alloc = YYSTACK_ALLOC_MAXIMUM;
+ return 2;
+ }
- if (yyresult)
- {
- /* Avoid sprintf, as that infringes on the user's name space.
- Don't have undefined behavior even if the translation
- produced a string with the wrong number of "%s"s. */
- char *yyp = yyresult;
- int yyi = 0;
- while ((*yyp = *yyformat) != '\0')
- if (*yyp == '%' && yyformat[1] == 's' && yyi < yycount)
- {
- yyp += yytnamerr (yyp, yyarg[yyi++]);
- yyformat += 2;
- }
- else
- {
- yyp++;
- yyformat++;
- }
- }
- return yysize;
+ /* Avoid sprintf, as that infringes on the user's name space.
+ Don't have undefined behavior even if the translation
+ produced a string with the wrong number of "%s"s. */
+ {
+ char *yyp = *yymsg;
+ int yyi = 0;
+ while ((*yyp = *yyformat) != '\0')
+ if (*yyp == '%' && yyformat[1] == 's' && yyi < yycount)
+ {
+ yyp += yytnamerr (yyp, yyarg[yyi++]);
+ yyformat += 2;
+ }
+ else
+ {
+ yyp++;
+ yyformat++;
+ }
+ }
+ return 0;
}
}
#endif /* YYERROR_VERBOSE */
}
}
+
/* Prevent warnings from -Wmissing-prototypes. */
#ifdef YYPARSE_PARAM
#if (defined __STDC__ || defined __C99__FUNC__ \
#endif /* ! YYPARSE_PARAM */
-
-
-
-/*-------------------------.
-| yyparse or yypush_parse. |
-`-------------------------*/
+/*----------.
+| yyparse. |
+`----------*/
#ifdef YYPARSE_PARAM
#if (defined __STDC__ || defined __C99__FUNC__ \
YYLTYPE *yylsp;
/* The locations where the error started and ended. */
- YYLTYPE yyerror_range[2];
+ YYLTYPE yyerror_range[3];
YYSIZE_T yystacksize;
yyvsp = yyvs;
yylsp = yyls;
-#if YYLTYPE_IS_TRIVIAL
+#if defined YYLTYPE_IS_TRIVIAL && YYLTYPE_IS_TRIVIAL
/* Initialize the default location before parsing starts. */
yylloc.first_line = yylloc.last_line = 1;
yylloc.first_column = yylloc.last_column = 1;
#endif
/* User initialization code. */
-/* Line 1176 of yacc.c */
-#line 86 "parse-gram.y"
+/* Line 1214 of yacc.c */
+#line 79 "src/parse-gram.y"
{
/* Bison's grammar can initial empty locations, hence a default
location is needed. */
boundary_set (&yylloc.start, current_file, 1, 1);
boundary_set (&yylloc.end, current_file, 1, 1);
}
-/* Line 1176 of yacc.c */
-#line 1666 "src/parse-gram.c"
+/* Line 1214 of yacc.c */
+#line 1755 "src/parse-gram.c"
yylsp[0] = yylloc;
goto yysetstate;
switch (yyn)
{
case 6:
-/* Line 1389 of yacc.c */
-#line 223 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 266 "src/parse-gram.y"
{
code_props plain_code;
code_props_plain_init (&plain_code, (yyvsp[0].chars), (yylsp[0]));
plain_code.code, (yylsp[0]));
code_scanner_last_string_free ();
}
-/* Line 1389 of yacc.c */
-#line 1864 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 1953 "src/parse-gram.c"
break;
case 7:
-/* Line 1389 of yacc.c */
-#line 233 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 276 "src/parse-gram.y"
{
muscle_percent_define_ensure ((yyvsp[0].uniqstr), (yylsp[0]), true);
}
-/* Line 1389 of yacc.c */
-#line 1874 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 1963 "src/parse-gram.c"
break;
case 8:
-/* Line 1389 of yacc.c */
-#line 237 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 280 "src/parse-gram.y"
{
muscle_percent_define_insert ((yyvsp[-1].uniqstr), (yylsp[-1]), (yyvsp[0].chars),
MUSCLE_PERCENT_DEFINE_GRAMMAR_FILE);
}
-/* Line 1389 of yacc.c */
-#line 1885 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 1974 "src/parse-gram.c"
break;
case 9:
-/* Line 1389 of yacc.c */
-#line 241 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 284 "src/parse-gram.y"
{ defines_flag = true; }
-/* Line 1389 of yacc.c */
-#line 1893 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 1982 "src/parse-gram.c"
break;
case 10:
-/* Line 1389 of yacc.c */
-#line 243 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 286 "src/parse-gram.y"
{
defines_flag = true;
spec_defines_file = xstrdup ((yyvsp[0].chars));
}
-/* Line 1389 of yacc.c */
-#line 1904 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 1993 "src/parse-gram.c"
break;
case 11:
-/* Line 1389 of yacc.c */
-#line 248 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 291 "src/parse-gram.y"
{
muscle_percent_define_insert ("parse.error", (yylsp[0]), "verbose",
MUSCLE_PERCENT_DEFINE_GRAMMAR_FILE);
}
-/* Line 1389 of yacc.c */
-#line 1915 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2004 "src/parse-gram.c"
break;
case 12:
-/* Line 1389 of yacc.c */
-#line 252 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 295 "src/parse-gram.y"
{ expected_sr_conflicts = (yyvsp[0].integer); }
-/* Line 1389 of yacc.c */
-#line 1923 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2012 "src/parse-gram.c"
break;
case 13:
-/* Line 1389 of yacc.c */
-#line 253 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 296 "src/parse-gram.y"
{ expected_rr_conflicts = (yyvsp[0].integer); }
-/* Line 1389 of yacc.c */
-#line 1931 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2020 "src/parse-gram.c"
break;
case 14:
-/* Line 1389 of yacc.c */
-#line 254 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 297 "src/parse-gram.y"
{ spec_file_prefix = (yyvsp[0].chars); }
-/* Line 1389 of yacc.c */
-#line 1939 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2028 "src/parse-gram.c"
break;
case 15:
-/* Line 1389 of yacc.c */
-#line 255 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 298 "src/parse-gram.y"
{ spec_file_prefix = (yyvsp[0].chars); }
-/* Line 1389 of yacc.c */
-#line 1947 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2036 "src/parse-gram.c"
break;
case 16:
-/* Line 1389 of yacc.c */
-#line 257 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 300 "src/parse-gram.y"
{
nondeterministic_parser = true;
glr_parser = true;
}
-/* Line 1389 of yacc.c */
-#line 1958 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2047 "src/parse-gram.c"
break;
case 17:
-/* Line 1389 of yacc.c */
-#line 262 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 305 "src/parse-gram.y"
{
code_props action;
code_props_symbol_action_init (&action, (yyvsp[0].code), (yylsp[0]));
muscle_code_grow ("initial_action", action.code, (yylsp[0]));
code_scanner_last_string_free ();
}
-/* Line 1389 of yacc.c */
-#line 1973 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2062 "src/parse-gram.c"
break;
case 18:
-/* Line 1389 of yacc.c */
-#line 270 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 313 "src/parse-gram.y"
{ language_argmatch ((yyvsp[0].chars), grammar_prio, (yylsp[-1])); }
-/* Line 1389 of yacc.c */
-#line 1981 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2070 "src/parse-gram.c"
break;
case 19:
-/* Line 1389 of yacc.c */
-#line 271 "parse-gram.y"
- { add_param ("lex_param", (yyvsp[0].code), (yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 1989 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 314 "src/parse-gram.y"
+ { spec_name_prefix = (yyvsp[0].chars); }
+/* Line 1427 of yacc.c */
+#line 2078 "src/parse-gram.c"
break;
case 20:
-/* Line 1389 of yacc.c */
-#line 272 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 315 "src/parse-gram.y"
{ spec_name_prefix = (yyvsp[0].chars); }
-/* Line 1389 of yacc.c */
-#line 1997 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2086 "src/parse-gram.c"
break;
case 21:
-/* Line 1389 of yacc.c */
-#line 273 "parse-gram.y"
- { spec_name_prefix = (yyvsp[0].chars); }
-/* Line 1389 of yacc.c */
-#line 2005 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 316 "src/parse-gram.y"
+ { no_lines_flag = true; }
+/* Line 1427 of yacc.c */
+#line 2094 "src/parse-gram.c"
break;
case 22:
-/* Line 1389 of yacc.c */
-#line 274 "parse-gram.y"
- { no_lines_flag = true; }
-/* Line 1389 of yacc.c */
-#line 2013 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 317 "src/parse-gram.y"
+ { nondeterministic_parser = true; }
+/* Line 1427 of yacc.c */
+#line 2102 "src/parse-gram.c"
break;
case 23:
-/* Line 1389 of yacc.c */
-#line 275 "parse-gram.y"
- { nondeterministic_parser = true; }
-/* Line 1389 of yacc.c */
-#line 2021 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 318 "src/parse-gram.y"
+ { spec_outfile = (yyvsp[0].chars); }
+/* Line 1427 of yacc.c */
+#line 2110 "src/parse-gram.c"
break;
case 24:
-/* Line 1389 of yacc.c */
-#line 276 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 319 "src/parse-gram.y"
{ spec_outfile = (yyvsp[0].chars); }
-/* Line 1389 of yacc.c */
-#line 2029 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2118 "src/parse-gram.c"
break;
case 25:
-/* Line 1389 of yacc.c */
-#line 277 "parse-gram.y"
- { spec_outfile = (yyvsp[0].chars); }
-/* Line 1389 of yacc.c */
-#line 2037 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 320 "src/parse-gram.y"
+ { current_param = (yyvsp[0].param); }
+/* Line 1427 of yacc.c */
+#line 2126 "src/parse-gram.c"
break;
case 26:
-/* Line 1389 of yacc.c */
-#line 278 "parse-gram.y"
- { add_param ("parse_param", (yyvsp[0].code), (yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2045 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 320 "src/parse-gram.y"
+ { current_param = param_none; }
+/* Line 1427 of yacc.c */
+#line 2134 "src/parse-gram.c"
break;
case 27:
-/* Line 1389 of yacc.c */
-#line 279 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 321 "src/parse-gram.y"
{ version_check (&(yylsp[0]), (yyvsp[0].chars)); }
-/* Line 1389 of yacc.c */
-#line 2053 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2142 "src/parse-gram.c"
break;
case 28:
-/* Line 1389 of yacc.c */
-#line 281 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 323 "src/parse-gram.y"
{
char const *skeleton_user = (yyvsp[0].chars);
if (strchr (skeleton_user, '/'))
}
skeleton_arg (skeleton_user, grammar_prio, (yylsp[-1]));
}
-/* Line 1389 of yacc.c */
-#line 2083 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2172 "src/parse-gram.c"
break;
case 29:
-/* Line 1389 of yacc.c */
-#line 304 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 346 "src/parse-gram.y"
{ token_table_flag = true; }
-/* Line 1389 of yacc.c */
-#line 2091 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2180 "src/parse-gram.c"
break;
case 30:
-/* Line 1389 of yacc.c */
-#line 305 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 347 "src/parse-gram.y"
{ report_flag |= report_states; }
-/* Line 1389 of yacc.c */
-#line 2099 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2188 "src/parse-gram.c"
break;
case 31:
-/* Line 1389 of yacc.c */
-#line 306 "parse-gram.y"
+/* Line 1427 of yacc.c */
+#line 348 "src/parse-gram.y"
{ yacc_flag = true; }
-/* Line 1389 of yacc.c */
-#line 2107 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2196 "src/parse-gram.c"
break;
- case 35:
-/* Line 1389 of yacc.c */
-#line 314 "parse-gram.y"
+ case 33:
+/* Line 1427 of yacc.c */
+#line 353 "src/parse-gram.y"
+ { add_param (current_param, (yyvsp[0].code), (yylsp[0])); }
+/* Line 1427 of yacc.c */
+#line 2204 "src/parse-gram.c"
+ break;
+
+ case 34:
+/* Line 1427 of yacc.c */
+#line 354 "src/parse-gram.y"
+ { add_param (current_param, (yyvsp[0].code), (yylsp[0])); }
+/* Line 1427 of yacc.c */
+#line 2212 "src/parse-gram.c"
+ break;
+
+ case 37:
+/* Line 1427 of yacc.c */
+#line 366 "src/parse-gram.y"
{
grammar_start_symbol_set ((yyvsp[0].symbol), (yylsp[0]));
}
-/* Line 1389 of yacc.c */
-#line 2117 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2222 "src/parse-gram.c"
break;
- case 36:
-/* Line 1389 of yacc.c */
-#line 318 "parse-gram.y"
+ case 38:
+/* Line 1427 of yacc.c */
+#line 370 "src/parse-gram.y"
{
symbol_list *list;
for (list = (yyvsp[0].list); list; list = list->next)
symbol_list_destructor_set (list, (yyvsp[-1].code), (yylsp[-1]));
symbol_list_free ((yyvsp[0].list));
}
-/* Line 1389 of yacc.c */
-#line 2130 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2235 "src/parse-gram.c"
break;
- case 37:
-/* Line 1389 of yacc.c */
-#line 325 "parse-gram.y"
+ case 39:
+/* Line 1427 of yacc.c */
+#line 377 "src/parse-gram.y"
{
symbol_list *list;
for (list = (yyvsp[0].list); list; list = list->next)
symbol_list_printer_set (list, (yyvsp[-1].code), (yylsp[-1]));
symbol_list_free ((yyvsp[0].list));
}
-/* Line 1389 of yacc.c */
-#line 2143 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2248 "src/parse-gram.c"
break;
- case 38:
-/* Line 1389 of yacc.c */
-#line 332 "parse-gram.y"
+ case 40:
+/* Line 1427 of yacc.c */
+#line 384 "src/parse-gram.y"
{
default_prec = true;
}
-/* Line 1389 of yacc.c */
-#line 2153 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2258 "src/parse-gram.c"
break;
- case 39:
-/* Line 1389 of yacc.c */
-#line 336 "parse-gram.y"
+ case 41:
+/* Line 1427 of yacc.c */
+#line 388 "src/parse-gram.y"
{
default_prec = false;
}
-/* Line 1389 of yacc.c */
-#line 2163 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2268 "src/parse-gram.c"
break;
- case 40:
-/* Line 1389 of yacc.c */
-#line 340 "parse-gram.y"
+ case 42:
+/* Line 1427 of yacc.c */
+#line 392 "src/parse-gram.y"
{
/* Do not invoke muscle_percent_code_grow here since it invokes
muscle_user_name_list_grow. */
muscle_code_grow ("percent_code()", (yyvsp[0].chars), (yylsp[0]));
code_scanner_last_string_free ();
}
-/* Line 1389 of yacc.c */
-#line 2176 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2281 "src/parse-gram.c"
break;
- case 41:
-/* Line 1389 of yacc.c */
-#line 347 "parse-gram.y"
+ case 43:
+/* Line 1427 of yacc.c */
+#line 399 "src/parse-gram.y"
{
muscle_percent_code_grow ((yyvsp[-1].uniqstr), (yylsp[-1]), (yyvsp[0].chars), (yylsp[0]));
code_scanner_last_string_free ();
}
-/* Line 1389 of yacc.c */
-#line 2187 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2292 "src/parse-gram.c"
break;
- case 42:
-/* Line 1389 of yacc.c */
-#line 361 "parse-gram.y"
+ case 44:
+/* Line 1427 of yacc.c */
+#line 413 "src/parse-gram.y"
{}
-/* Line 1389 of yacc.c */
-#line 2195 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2300 "src/parse-gram.c"
break;
- case 43:
-/* Line 1389 of yacc.c */
-#line 362 "parse-gram.y"
+ case 45:
+/* Line 1427 of yacc.c */
+#line 414 "src/parse-gram.y"
{ muscle_code_grow ("union_name", (yyvsp[0].uniqstr), (yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2203 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2308 "src/parse-gram.c"
break;
- case 44:
-/* Line 1389 of yacc.c */
-#line 367 "parse-gram.y"
+ case 46:
+/* Line 1427 of yacc.c */
+#line 419 "src/parse-gram.y"
{
union_seen = true;
muscle_code_grow ("stype", (yyvsp[0].chars), (yylsp[0]));
code_scanner_last_string_free ();
}
-/* Line 1389 of yacc.c */
-#line 2215 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2320 "src/parse-gram.c"
break;
- case 45:
-/* Line 1389 of yacc.c */
-#line 378 "parse-gram.y"
+ case 47:
+/* Line 1427 of yacc.c */
+#line 430 "src/parse-gram.y"
{ current_class = nterm_sym; }
-/* Line 1389 of yacc.c */
-#line 2223 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2328 "src/parse-gram.c"
break;
- case 46:
-/* Line 1389 of yacc.c */
-#line 379 "parse-gram.y"
+ case 48:
+/* Line 1427 of yacc.c */
+#line 431 "src/parse-gram.y"
{
current_class = unknown_sym;
current_type = NULL;
}
-/* Line 1389 of yacc.c */
-#line 2234 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2339 "src/parse-gram.c"
break;
- case 47:
-/* Line 1389 of yacc.c */
-#line 383 "parse-gram.y"
+ case 49:
+/* Line 1427 of yacc.c */
+#line 435 "src/parse-gram.y"
{ current_class = token_sym; }
-/* Line 1389 of yacc.c */
-#line 2242 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2347 "src/parse-gram.c"
break;
- case 48:
-/* Line 1389 of yacc.c */
-#line 384 "parse-gram.y"
+ case 50:
+/* Line 1427 of yacc.c */
+#line 436 "src/parse-gram.y"
{
current_class = unknown_sym;
current_type = NULL;
}
-/* Line 1389 of yacc.c */
-#line 2253 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2358 "src/parse-gram.c"
break;
- case 49:
-/* Line 1389 of yacc.c */
-#line 389 "parse-gram.y"
+ case 51:
+/* Line 1427 of yacc.c */
+#line 441 "src/parse-gram.y"
{
symbol_list *list;
tag_seen = true;
symbol_type_set (list->content.sym, (yyvsp[-1].uniqstr), (yylsp[-1]));
symbol_list_free ((yyvsp[0].list));
}
-/* Line 1389 of yacc.c */
-#line 2267 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2372 "src/parse-gram.c"
break;
- case 50:
-/* Line 1389 of yacc.c */
-#line 400 "parse-gram.y"
+ case 52:
+/* Line 1427 of yacc.c */
+#line 452 "src/parse-gram.y"
{
symbol_list *list;
++current_prec;
symbol_list_free ((yyvsp[0].list));
current_type = NULL;
}
-/* Line 1389 of yacc.c */
-#line 2285 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2390 "src/parse-gram.c"
break;
- case 51:
-/* Line 1389 of yacc.c */
-#line 414 "parse-gram.y"
+ case 53:
+/* Line 1427 of yacc.c */
+#line 466 "src/parse-gram.y"
{ (yyval.assoc) = left_assoc; }
-/* Line 1389 of yacc.c */
-#line 2293 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2398 "src/parse-gram.c"
break;
- case 52:
-/* Line 1389 of yacc.c */
-#line 415 "parse-gram.y"
+ case 54:
+/* Line 1427 of yacc.c */
+#line 467 "src/parse-gram.y"
{ (yyval.assoc) = right_assoc; }
-/* Line 1389 of yacc.c */
-#line 2301 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2406 "src/parse-gram.c"
break;
- case 53:
-/* Line 1389 of yacc.c */
-#line 416 "parse-gram.y"
+ case 55:
+/* Line 1427 of yacc.c */
+#line 468 "src/parse-gram.y"
{ (yyval.assoc) = non_assoc; }
-/* Line 1389 of yacc.c */
-#line 2309 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2414 "src/parse-gram.c"
break;
- case 54:
-/* Line 1389 of yacc.c */
-#line 417 "parse-gram.y"
+ case 56:
+/* Line 1427 of yacc.c */
+#line 469 "src/parse-gram.y"
{ (yyval.assoc) = precedence_assoc; }
-/* Line 1389 of yacc.c */
-#line 2317 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2422 "src/parse-gram.c"
break;
- case 55:
-/* Line 1389 of yacc.c */
-#line 421 "parse-gram.y"
+ case 57:
+/* Line 1427 of yacc.c */
+#line 473 "src/parse-gram.y"
{ current_type = NULL; }
-/* Line 1389 of yacc.c */
-#line 2325 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2430 "src/parse-gram.c"
break;
- case 56:
-/* Line 1389 of yacc.c */
-#line 422 "parse-gram.y"
+ case 58:
+/* Line 1427 of yacc.c */
+#line 474 "src/parse-gram.y"
{ current_type = (yyvsp[0].uniqstr); tag_seen = true; }
-/* Line 1389 of yacc.c */
-#line 2333 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2438 "src/parse-gram.c"
break;
- case 57:
-/* Line 1389 of yacc.c */
-#line 428 "parse-gram.y"
+ case 59:
+/* Line 1427 of yacc.c */
+#line 480 "src/parse-gram.y"
{ (yyval.list) = symbol_list_sym_new ((yyvsp[0].symbol), (yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2341 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2446 "src/parse-gram.c"
break;
- case 58:
-/* Line 1389 of yacc.c */
-#line 430 "parse-gram.y"
+ case 60:
+/* Line 1427 of yacc.c */
+#line 482 "src/parse-gram.y"
{ (yyval.list) = symbol_list_prepend ((yyvsp[-1].list), symbol_list_sym_new ((yyvsp[0].symbol), (yylsp[0]))); }
-/* Line 1389 of yacc.c */
-#line 2349 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2454 "src/parse-gram.c"
break;
- case 59:
-/* Line 1389 of yacc.c */
-#line 434 "parse-gram.y"
+ case 61:
+/* Line 1427 of yacc.c */
+#line 486 "src/parse-gram.y"
{ (yyval.symbol) = (yyvsp[0].symbol); }
-/* Line 1389 of yacc.c */
-#line 2357 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2462 "src/parse-gram.c"
break;
- case 60:
-/* Line 1389 of yacc.c */
-#line 435 "parse-gram.y"
+ case 62:
+/* Line 1427 of yacc.c */
+#line 487 "src/parse-gram.y"
{ (yyval.symbol) = (yyvsp[-1].symbol); symbol_user_token_number_set ((yyvsp[-1].symbol), (yyvsp[0].integer), (yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2365 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2470 "src/parse-gram.c"
break;
- case 61:
-/* Line 1389 of yacc.c */
-#line 441 "parse-gram.y"
+ case 63:
+/* Line 1427 of yacc.c */
+#line 493 "src/parse-gram.y"
{ (yyval.list) = symbol_list_sym_new ((yyvsp[0].symbol), (yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2373 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2478 "src/parse-gram.c"
break;
- case 62:
-/* Line 1389 of yacc.c */
-#line 443 "parse-gram.y"
+ case 64:
+/* Line 1427 of yacc.c */
+#line 495 "src/parse-gram.y"
{ (yyval.list) = symbol_list_prepend ((yyvsp[-1].list), symbol_list_sym_new ((yyvsp[0].symbol), (yylsp[0]))); }
-/* Line 1389 of yacc.c */
-#line 2381 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2486 "src/parse-gram.c"
break;
- case 63:
-/* Line 1389 of yacc.c */
-#line 447 "parse-gram.y"
+ case 65:
+/* Line 1427 of yacc.c */
+#line 499 "src/parse-gram.y"
{ (yyval.list) = (yyvsp[0].list); }
-/* Line 1389 of yacc.c */
-#line 2389 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2494 "src/parse-gram.c"
break;
- case 64:
-/* Line 1389 of yacc.c */
-#line 448 "parse-gram.y"
+ case 66:
+/* Line 1427 of yacc.c */
+#line 500 "src/parse-gram.y"
{ (yyval.list) = symbol_list_prepend ((yyvsp[-1].list), (yyvsp[0].list)); }
-/* Line 1389 of yacc.c */
-#line 2397 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2502 "src/parse-gram.c"
break;
- case 65:
-/* Line 1389 of yacc.c */
-#line 452 "parse-gram.y"
+ case 67:
+/* Line 1427 of yacc.c */
+#line 504 "src/parse-gram.y"
{ (yyval.list) = symbol_list_sym_new ((yyvsp[0].symbol), (yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2405 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2510 "src/parse-gram.c"
break;
- case 66:
-/* Line 1389 of yacc.c */
-#line 453 "parse-gram.y"
+ case 68:
+/* Line 1427 of yacc.c */
+#line 505 "src/parse-gram.y"
{ (yyval.list) = symbol_list_type_new ((yyvsp[0].uniqstr), (yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2413 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2518 "src/parse-gram.c"
break;
- case 67:
-/* Line 1389 of yacc.c */
-#line 454 "parse-gram.y"
+ case 69:
+/* Line 1427 of yacc.c */
+#line 506 "src/parse-gram.y"
{ (yyval.list) = symbol_list_default_tagged_new ((yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2421 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2526 "src/parse-gram.c"
break;
- case 68:
-/* Line 1389 of yacc.c */
-#line 455 "parse-gram.y"
+ case 70:
+/* Line 1427 of yacc.c */
+#line 507 "src/parse-gram.y"
{ (yyval.list) = symbol_list_default_tagless_new ((yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2429 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2534 "src/parse-gram.c"
break;
- case 69:
-/* Line 1389 of yacc.c */
-#line 461 "parse-gram.y"
+ case 71:
+/* Line 1427 of yacc.c */
+#line 513 "src/parse-gram.y"
{
current_type = (yyvsp[0].uniqstr);
tag_seen = true;
}
-/* Line 1389 of yacc.c */
-#line 2440 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2545 "src/parse-gram.c"
break;
- case 70:
-/* Line 1389 of yacc.c */
-#line 466 "parse-gram.y"
+ case 72:
+/* Line 1427 of yacc.c */
+#line 518 "src/parse-gram.y"
{
symbol_class_set ((yyvsp[0].symbol), current_class, (yylsp[0]), true);
symbol_type_set ((yyvsp[0].symbol), current_type, (yylsp[0]));
}
-/* Line 1389 of yacc.c */
-#line 2451 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2556 "src/parse-gram.c"
break;
- case 71:
-/* Line 1389 of yacc.c */
-#line 471 "parse-gram.y"
+ case 73:
+/* Line 1427 of yacc.c */
+#line 523 "src/parse-gram.y"
{
symbol_class_set ((yyvsp[-1].symbol), current_class, (yylsp[-1]), true);
symbol_type_set ((yyvsp[-1].symbol), current_type, (yylsp[-1]));
symbol_user_token_number_set ((yyvsp[-1].symbol), (yyvsp[0].integer), (yylsp[0]));
}
-/* Line 1389 of yacc.c */
-#line 2463 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2568 "src/parse-gram.c"
break;
- case 72:
-/* Line 1389 of yacc.c */
-#line 477 "parse-gram.y"
+ case 74:
+/* Line 1427 of yacc.c */
+#line 529 "src/parse-gram.y"
{
symbol_class_set ((yyvsp[-1].symbol), current_class, (yylsp[-1]), true);
symbol_type_set ((yyvsp[-1].symbol), current_type, (yylsp[-1]));
symbol_make_alias ((yyvsp[-1].symbol), (yyvsp[0].symbol), (yyloc));
}
-/* Line 1389 of yacc.c */
-#line 2475 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2580 "src/parse-gram.c"
break;
- case 73:
-/* Line 1389 of yacc.c */
-#line 483 "parse-gram.y"
+ case 75:
+/* Line 1427 of yacc.c */
+#line 535 "src/parse-gram.y"
{
symbol_class_set ((yyvsp[-2].symbol), current_class, (yylsp[-2]), true);
symbol_type_set ((yyvsp[-2].symbol), current_type, (yylsp[-2]));
symbol_user_token_number_set ((yyvsp[-2].symbol), (yyvsp[-1].integer), (yylsp[-1]));
symbol_make_alias ((yyvsp[-2].symbol), (yyvsp[0].symbol), (yyloc));
}
-/* Line 1389 of yacc.c */
-#line 2488 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2593 "src/parse-gram.c"
break;
- case 80:
-/* Line 1389 of yacc.c */
-#line 513 "parse-gram.y"
+ case 82:
+/* Line 1427 of yacc.c */
+#line 565 "src/parse-gram.y"
{
yyerrok;
}
-/* Line 1389 of yacc.c */
-#line 2498 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2603 "src/parse-gram.c"
break;
- case 81:
-/* Line 1389 of yacc.c */
-#line 519 "parse-gram.y"
+ case 83:
+/* Line 1427 of yacc.c */
+#line 571 "src/parse-gram.y"
{ current_lhs = (yyvsp[-1].symbol); current_lhs_location = (yylsp[-1]);
current_lhs_named_ref = (yyvsp[0].named_ref); }
-/* Line 1389 of yacc.c */
-#line 2507 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2612 "src/parse-gram.c"
break;
- case 83:
-/* Line 1389 of yacc.c */
-#line 524 "parse-gram.y"
+ case 85:
+/* Line 1427 of yacc.c */
+#line 576 "src/parse-gram.y"
{ grammar_current_rule_end ((yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2515 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2620 "src/parse-gram.c"
break;
- case 84:
-/* Line 1389 of yacc.c */
-#line 525 "parse-gram.y"
+ case 86:
+/* Line 1427 of yacc.c */
+#line 577 "src/parse-gram.y"
{ grammar_current_rule_end ((yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2523 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2628 "src/parse-gram.c"
break;
- case 86:
-/* Line 1389 of yacc.c */
-#line 531 "parse-gram.y"
+ case 88:
+/* Line 1427 of yacc.c */
+#line 583 "src/parse-gram.y"
{ grammar_current_rule_begin (current_lhs, current_lhs_location,
current_lhs_named_ref); }
-/* Line 1389 of yacc.c */
-#line 2532 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2637 "src/parse-gram.c"
break;
- case 87:
-/* Line 1389 of yacc.c */
-#line 534 "parse-gram.y"
+ case 89:
+/* Line 1427 of yacc.c */
+#line 586 "src/parse-gram.y"
{ grammar_current_rule_symbol_append ((yyvsp[-1].symbol), (yylsp[-1]), (yyvsp[0].named_ref)); }
-/* Line 1389 of yacc.c */
-#line 2540 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2645 "src/parse-gram.c"
break;
- case 88:
-/* Line 1389 of yacc.c */
-#line 536 "parse-gram.y"
+ case 90:
+/* Line 1427 of yacc.c */
+#line 588 "src/parse-gram.y"
{ grammar_current_rule_action_append ((yyvsp[-1].code), (yylsp[-1]), (yyvsp[0].named_ref)); }
-/* Line 1389 of yacc.c */
-#line 2548 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2653 "src/parse-gram.c"
break;
- case 89:
-/* Line 1389 of yacc.c */
-#line 538 "parse-gram.y"
+ case 91:
+/* Line 1427 of yacc.c */
+#line 590 "src/parse-gram.y"
{ grammar_current_rule_prec_set ((yyvsp[0].symbol), (yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2556 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2661 "src/parse-gram.c"
break;
- case 90:
-/* Line 1389 of yacc.c */
-#line 540 "parse-gram.y"
+ case 92:
+/* Line 1427 of yacc.c */
+#line 592 "src/parse-gram.y"
{ grammar_current_rule_dprec_set ((yyvsp[0].integer), (yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2564 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2669 "src/parse-gram.c"
break;
- case 91:
-/* Line 1389 of yacc.c */
-#line 542 "parse-gram.y"
+ case 93:
+/* Line 1427 of yacc.c */
+#line 594 "src/parse-gram.y"
{ grammar_current_rule_merge_set ((yyvsp[0].uniqstr), (yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2572 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2677 "src/parse-gram.c"
break;
- case 92:
-/* Line 1389 of yacc.c */
-#line 546 "parse-gram.y"
+ case 94:
+/* Line 1427 of yacc.c */
+#line 598 "src/parse-gram.y"
{ (yyval.named_ref) = 0; }
-/* Line 1389 of yacc.c */
-#line 2580 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2685 "src/parse-gram.c"
break;
- case 93:
-/* Line 1389 of yacc.c */
-#line 548 "parse-gram.y"
+ case 95:
+/* Line 1427 of yacc.c */
+#line 600 "src/parse-gram.y"
{ (yyval.named_ref) = named_ref_new((yyvsp[0].uniqstr), (yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2588 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2693 "src/parse-gram.c"
break;
- case 95:
-/* Line 1389 of yacc.c */
-#line 560 "parse-gram.y"
+ case 97:
+/* Line 1427 of yacc.c */
+#line 612 "src/parse-gram.y"
{ (yyval.uniqstr) = uniqstr_new ((yyvsp[0].chars)); }
-/* Line 1389 of yacc.c */
-#line 2596 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2701 "src/parse-gram.c"
break;
- case 96:
-/* Line 1389 of yacc.c */
-#line 565 "parse-gram.y"
+ case 98:
+/* Line 1427 of yacc.c */
+#line 617 "src/parse-gram.y"
{ (yyval.chars) = ""; }
-/* Line 1389 of yacc.c */
-#line 2604 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2709 "src/parse-gram.c"
break;
- case 98:
-/* Line 1389 of yacc.c */
-#line 576 "parse-gram.y"
+ case 99:
+/* Line 1427 of yacc.c */
+#line 618 "src/parse-gram.y"
+ { (yyval.chars) = (yyvsp[0].uniqstr); }
+/* Line 1427 of yacc.c */
+#line 2717 "src/parse-gram.c"
+ break;
+
+ case 101:
+/* Line 1427 of yacc.c */
+#line 629 "src/parse-gram.y"
{
code_props plain_code;
(yyvsp[0].code)[strlen ((yyvsp[0].code)) - 1] = '\n';
gram_scanner_last_string_free ();
(yyval.chars) = plain_code.code;
}
-/* Line 1389 of yacc.c */
-#line 2619 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2732 "src/parse-gram.c"
break;
- case 99:
-/* Line 1389 of yacc.c */
-#line 596 "parse-gram.y"
+ case 102:
+/* Line 1427 of yacc.c */
+#line 649 "src/parse-gram.y"
{ (yyval.symbol) = symbol_from_uniqstr ((yyvsp[0].uniqstr), (yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2627 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2740 "src/parse-gram.c"
break;
- case 100:
-/* Line 1389 of yacc.c */
-#line 598 "parse-gram.y"
+ case 103:
+/* Line 1427 of yacc.c */
+#line 651 "src/parse-gram.y"
{
(yyval.symbol) = symbol_get (char_name ((yyvsp[0].character)), (yylsp[0]));
symbol_class_set ((yyval.symbol), token_sym, (yylsp[0]), false);
symbol_user_token_number_set ((yyval.symbol), (yyvsp[0].character), (yylsp[0]));
}
-/* Line 1389 of yacc.c */
-#line 2639 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2752 "src/parse-gram.c"
break;
- case 101:
-/* Line 1389 of yacc.c */
-#line 606 "parse-gram.y"
+ case 104:
+/* Line 1427 of yacc.c */
+#line 659 "src/parse-gram.y"
{ (yyval.symbol) = symbol_from_uniqstr ((yyvsp[0].uniqstr), (yylsp[0])); }
-/* Line 1389 of yacc.c */
-#line 2647 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2760 "src/parse-gram.c"
break;
- case 104:
-/* Line 1389 of yacc.c */
-#line 618 "parse-gram.y"
+ case 107:
+/* Line 1427 of yacc.c */
+#line 671 "src/parse-gram.y"
{
(yyval.symbol) = symbol_get (quotearg_style (c_quoting_style, (yyvsp[0].chars)), (yylsp[0]));
symbol_class_set ((yyval.symbol), token_sym, (yylsp[0]), false);
}
-/* Line 1389 of yacc.c */
-#line 2658 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2771 "src/parse-gram.c"
break;
- case 106:
-/* Line 1389 of yacc.c */
-#line 627 "parse-gram.y"
+ case 109:
+/* Line 1427 of yacc.c */
+#line 680 "src/parse-gram.y"
{
code_props plain_code;
code_props_plain_init (&plain_code, (yyvsp[0].chars), (yylsp[0]));
muscle_code_grow ("epilogue", plain_code.code, (yylsp[0]));
code_scanner_last_string_free ();
}
-/* Line 1389 of yacc.c */
-#line 2673 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2786 "src/parse-gram.c"
break;
-/* Line 1389 of yacc.c */
-#line 2678 "src/parse-gram.c"
+/* Line 1427 of yacc.c */
+#line 2791 "src/parse-gram.c"
default: break;
}
+ /* User semantic actions sometimes alter yychar, and that requires
+ that yytoken be updated with the new translation. We take the
+ approach of translating immediately before every use of yytoken.
+ One alternative is translating here after every semantic action,
+ but that translation would be missed if the semantic action invokes
+ YYABORT, YYACCEPT, or YYERROR immediately after altering yychar or
+ if it invokes YYBACKUP. In the case of YYABORT or YYACCEPT, an
+ incorrect destructor might then be invoked immediately. In the
+ case of YYERROR or YYBACKUP, subsequent parser actions might lead
+ to an incorrect destructor call or verbose syntax error message
+ before the lookahead is translated. */
YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc);
YYPOPSTACK (yylen);
| yyerrlab -- here on detecting error |
`------------------------------------*/
yyerrlab:
+ /* Make sure we have latest lookahead translation. See comments at
+ user semantic actions for why this is necessary. */
+ yytoken = YYTRANSLATE (yychar);
+
/* If not already recovering from an error, report this error. */
if (!yyerrstatus)
{
#if ! YYERROR_VERBOSE
yyerror (YY_("syntax error"));
#else
- {
- YYSIZE_T yysize = yysyntax_error (0, yystate, yytoken);
- if (yymsg_alloc < yysize && yymsg_alloc < YYSTACK_ALLOC_MAXIMUM)
- {
- YYSIZE_T yyalloc = 2 * yysize;
- if (! (yysize <= yyalloc && yyalloc <= YYSTACK_ALLOC_MAXIMUM))
- yyalloc = YYSTACK_ALLOC_MAXIMUM;
- if (yymsg != yymsgbuf)
- YYSTACK_FREE (yymsg);
- yymsg = (char *) YYSTACK_ALLOC (yyalloc);
- if (yymsg)
- yymsg_alloc = yyalloc;
- else
- {
- yymsg = yymsgbuf;
- yymsg_alloc = sizeof yymsgbuf;
- }
- }
-
- if (0 < yysize && yysize <= yymsg_alloc)
- {
- (void) yysyntax_error (yymsg, yystate, yytoken);
- yyerror (yymsg);
- }
- else
- {
- yyerror (YY_("syntax error"));
- if (yysize != 0)
- goto yyexhaustedlab;
- }
- }
+ while (1)
+ {
+ int yysyntax_error_status =
+ yysyntax_error (&yymsg_alloc, &yymsg, yystate, yytoken);
+ if (yysyntax_error_status == 2 && 0 < yymsg_alloc)
+ {
+ if (yymsg != yymsgbuf)
+ YYSTACK_FREE (yymsg);
+ yymsg = (char *) YYSTACK_ALLOC (yymsg_alloc);
+ if (yymsg)
+ continue;
+ yymsg = yymsgbuf;
+ yymsg_alloc = sizeof yymsgbuf;
+ }
+ if (yysyntax_error_status == 0)
+ yyerror (yymsg);
+ else
+ yyerror (YY_("syntax error"));
+ if (yysyntax_error_status == 2)
+ goto yyexhaustedlab;
+ break;
+ }
#endif
}
- yyerror_range[0] = yylloc;
+ yyerror_range[1] = yylloc;
if (yyerrstatus == 3)
{
if (/*CONSTCOND*/ 0)
goto yyerrorlab;
- yyerror_range[0] = yylsp[1-yylen];
+ yyerror_range[1] = yylsp[1-yylen];
/* Do not reclaim the symbols of the rule which action triggered
this YYERROR. */
YYPOPSTACK (yylen);
if (yyssp == yyss)
YYABORT;
- yyerror_range[0] = *yylsp;
+ yyerror_range[1] = *yylsp;
yydestruct ("Error: popping",
yystos[yystate], yyvsp, yylsp);
YYPOPSTACK (1);
*++yyvsp = yylval;
- yyerror_range[1] = yylloc;
+ yyerror_range[2] = yylloc;
/* Using YYLLOC is tempting, but would change the location of
the lookahead. YYLOC is available though. */
- YYLLOC_DEFAULT (yyloc, (yyerror_range - 1), 2);
+ YYLLOC_DEFAULT (yyloc, yyerror_range, 2);
*++yylsp = yyloc;
/* Shift the error token. */
yyreturn:
if (yychar != YYEMPTY)
- yydestruct ("Cleanup: discarding lookahead",
- yytoken, &yylval, &yylloc);
+ {
+ /* Make sure we have latest lookahead translation. See comments at
+ user semantic actions for why this is necessary. */
+ yytoken = YYTRANSLATE (yychar);
+ yydestruct ("Cleanup: discarding lookahead",
+ yytoken, &yylval, &yylloc);
+ }
/* Do not reclaim the symbols of the rule which action triggered
this YYABORT or YYACCEPT. */
YYPOPSTACK (yylen);
return YYID (yyresult);
}
-/* Line 1608 of yacc.c */
-#line 637 "parse-gram.y"
+/* Line 1657 of yacc.c */
+#line 690 "src/parse-gram.y"
}
-/* Add a lex-param or a parse-param (depending on TYPE) with
- declaration DECL and location LOC. */
-
static void
-add_param (char const *type, char *decl, location loc)
+add_param (param_type type, char *decl, location loc)
{
static char const alphanum[26 + 26 + 1 + 10] =
"abcdefghijklmnopqrstuvwxyz"
"ABCDEFGHIJKLMNOPQRSTUVWXYZ"
"_"
"0123456789";
+
char const *name_start = NULL;
- char *p;
-
- /* Stop on last actual character. */
- for (p = decl; p[1]; p++)
- if ((p == decl
- || ! memchr (alphanum, p[-1], sizeof alphanum))
- && memchr (alphanum, p[0], sizeof alphanum - 10))
- name_start = p;
-
- /* Strip the surrounding '{' and '}', and any blanks just inside
- the braces. */
- while (*--p == ' ' || *p == '\t')
- continue;
- p[1] = '\0';
- while (*++decl == ' ' || *decl == '\t')
- continue;
+ {
+ char *p;
+ /* Stop on last actual character. */
+ for (p = decl; p[1]; p++)
+ if ((p == decl
+ || ! memchr (alphanum, p[-1], sizeof alphanum))
+ && memchr (alphanum, p[0], sizeof alphanum - 10))
+ name_start = p;
+
+ /* Strip the surrounding '{' and '}', and any blanks just inside
+ the braces. */
+ while (*--p == ' ' || *p == '\t')
+ continue;
+ p[1] = '\0';
+ while (*++decl == ' ' || *decl == '\t')
+ continue;
+ }
if (! name_start)
complain_at (loc, _("missing identifier in parameter declaration"));
name = xmalloc (name_len + 1);
memcpy (name, name_start, name_len);
name[name_len] = '\0';
- muscle_pair_list_grow (type, decl, name);
+ if (type & param_lex)
+ muscle_pair_list_grow ("lex_param", decl, name);
+ if (type & param_parse)
+ muscle_pair_list_grow ("parse_param", decl, name);
free (name);
}