]> git.saurik.com Git - bison.git/blobdiff - src/parse-gram.c
portability: use va_start and va_end in the same function.
[bison.git] / src / parse-gram.c
index 6425f22d8685d78765814a0e5c89e5575ee20ec3..be1de32a33e875895c9fa8192f30453df8b2bc78 100644 (file)
@@ -1,10 +1,9 @@
-
-/* A Bison parser, made by GNU Bison 2.3a+.  */
+/* A Bison parser, made by GNU Bison 2.4.1.50-3249.  */
 
 /* Skeleton implementation for Bison's Yacc-like parsers in C
    
-      Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006
-   Free Software Foundation, Inc.
+      Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006,
+   2009 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
@@ -46,7 +45,7 @@
 #define YYBISON 1
 
 /* Bison version.  */
-#define YYBISON_VERSION "2.3a+"
+#define YYBISON_VERSION "2.4.1.50-3249"
 
 /* Skeleton name.  */
 #define YYSKELETON_NAME "yacc.c"
 
 /* Copy the first part of user declarations.  */
 
-/* Line 189 of yacc.c  */
+/* Line 190 of yacc.c  */
 #line 1 "parse-gram.y"
 /* Bison Grammar Parser                             -*- C -*-
 
-   Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007, 2008 Free Software
-   Foundation, Inc.
+   Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007, 2008-2009 Free
+   Software Foundation, Inc.
 
    This file is part of Bison, the GNU Compiler Compiler.
 
 #include <config.h>
 #include "system.h"
 
-#include <strverscmp.h>
-
 #include "complain.h"
 #include "conflicts.h"
 #include "files.h"
@@ -152,8 +149,8 @@ static int current_prec = 0;
 #define YYTYPE_UINT8 uint_fast8_t
 
 
-/* Line 189 of yacc.c  */
-#line 157 "parse-gram.c"
+/* Line 190 of yacc.c  */
+#line 154 "parse-gram.c"
 
 /* Enabling traces.  */
 #ifndef YYDEBUG
@@ -301,8 +298,8 @@ static int current_prec = 0;
 typedef union YYSTYPE
 {
 
-/* Line 214 of yacc.c  */
-#line 94 "parse-gram.y"
+/* Line 215 of yacc.c  */
+#line 92 "parse-gram.y"
 
   symbol *symbol;
   symbol_list *list;
@@ -315,8 +312,8 @@ typedef union YYSTYPE
 
 
 
-/* Line 214 of yacc.c  */
-#line 320 "parse-gram.c"
+/* Line 215 of yacc.c  */
+#line 317 "parse-gram.c"
 } YYSTYPE;
 # define YYSTYPE_IS_TRIVIAL 1
 # define yystype YYSTYPE /* obsolescent; will be withdrawn */
@@ -340,8 +337,8 @@ typedef struct YYLTYPE
 /* Copy the second part of user declarations.  */
 
 
-/* Line 264 of yacc.c  */
-#line 345 "parse-gram.c"
+/* Line 265 of yacc.c  */
+#line 342 "parse-gram.c"
 
 #ifdef short
 # undef short
@@ -666,17 +663,17 @@ static const yytype_int8 yyrhs[] =
 /* YYRLINE[YYN] -- source line where rule number YYN was defined.  */
 static const yytype_uint16 yyrline[] =
 {
-       0,   204,   204,   212,   214,   218,   219,   229,   230,   234,
-     235,   240,   241,   242,   243,   244,   245,   250,   259,   260,
-     261,   262,   263,   264,   265,   266,   267,   268,   269,   282,
-     283,   307,   308,   309,   310,   314,   315,   316,   320,   327,
-     334,   338,   342,   349,   364,   365,   369,   381,   381,   386,
-     386,   391,   402,   417,   418,   419,   423,   424,   429,   431,
-     436,   437,   442,   444,   449,   450,   454,   455,   456,   457,
-     462,   467,   472,   478,   484,   495,   496,   505,   506,   512,
-     513,   514,   521,   521,   525,   526,   527,   532,   533,   535,
-     537,   539,   541,   551,   552,   558,   561,   570,   590,   592,
-     601,   606,   607,   612,   619,   621
+       0,   202,   202,   210,   212,   216,   217,   227,   228,   232,
+     233,   238,   239,   240,   241,   242,   243,   248,   257,   258,
+     259,   260,   261,   262,   263,   264,   265,   266,   267,   280,
+     281,   305,   306,   307,   308,   312,   313,   314,   318,   325,
+     332,   336,   340,   347,   362,   363,   367,   379,   379,   384,
+     384,   389,   400,   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,   523,   524,   525,   530,   531,   533,
+     535,   537,   539,   549,   550,   556,   559,   568,   588,   590,
+     599,   604,   605,   610,   617,   619
 };
 #endif
 
@@ -1031,147 +1028,147 @@ yy_symbol_value_print (yyoutput, yytype, yyvaluep, yylocationp)
     {
       case 3: /* "\"string\"" */
 
-/* Line 715 of yacc.c  */
-#line 182 "parse-gram.y"
+/* Line 716 of yacc.c  */
+#line 180 "parse-gram.y"
        { fputs (quotearg_style (c_quoting_style, (yyvaluep->chars)), stderr); };
 
-/* Line 715 of yacc.c  */
-#line 1040 "parse-gram.c"
+/* Line 716 of yacc.c  */
+#line 1037 "parse-gram.c"
        break;
       case 4: /* "\"integer\"" */
 
-/* Line 715 of yacc.c  */
-#line 193 "parse-gram.y"
+/* Line 716 of yacc.c  */
+#line 191 "parse-gram.y"
        { fprintf (stderr, "%d", (yyvaluep->integer)); };
 
-/* Line 715 of yacc.c  */
-#line 1049 "parse-gram.c"
+/* Line 716 of yacc.c  */
+#line 1046 "parse-gram.c"
        break;
       case 43: /* "\"{...}\"" */
 
-/* Line 715 of yacc.c  */
-#line 184 "parse-gram.y"
+/* Line 716 of yacc.c  */
+#line 182 "parse-gram.y"
        { fprintf (stderr, "{\n%s\n}", (yyvaluep->code)); };
 
-/* Line 715 of yacc.c  */
-#line 1058 "parse-gram.c"
+/* Line 716 of yacc.c  */
+#line 1055 "parse-gram.c"
        break;
       case 44: /* "\"char\"" */
 
-/* Line 715 of yacc.c  */
-#line 176 "parse-gram.y"
+/* Line 716 of yacc.c  */
+#line 174 "parse-gram.y"
        { fputs (char_name ((yyvaluep->character)), stderr); };
 
-/* Line 715 of yacc.c  */
-#line 1067 "parse-gram.c"
+/* Line 716 of yacc.c  */
+#line 1064 "parse-gram.c"
        break;
       case 45: /* "\"epilogue\"" */
 
-/* Line 715 of yacc.c  */
-#line 184 "parse-gram.y"
+/* Line 716 of yacc.c  */
+#line 182 "parse-gram.y"
        { fprintf (stderr, "{\n%s\n}", (yyvaluep->chars)); };
 
-/* Line 715 of yacc.c  */
-#line 1076 "parse-gram.c"
+/* Line 716 of yacc.c  */
+#line 1073 "parse-gram.c"
        break;
       case 47: /* "\"identifier\"" */
 
-/* Line 715 of yacc.c  */
-#line 189 "parse-gram.y"
+/* Line 716 of yacc.c  */
+#line 187 "parse-gram.y"
        { fputs ((yyvaluep->uniqstr), stderr); };
 
-/* Line 715 of yacc.c  */
-#line 1085 "parse-gram.c"
+/* Line 716 of yacc.c  */
+#line 1082 "parse-gram.c"
        break;
       case 48: /* "\"identifier:\"" */
 
-/* Line 715 of yacc.c  */
-#line 190 "parse-gram.y"
+/* Line 716 of yacc.c  */
+#line 188 "parse-gram.y"
        { fprintf (stderr, "%s:", (yyvaluep->uniqstr)); };
 
-/* Line 715 of yacc.c  */
-#line 1094 "parse-gram.c"
+/* Line 716 of yacc.c  */
+#line 1091 "parse-gram.c"
        break;
       case 51: /* "\"%{...%}\"" */
 
-/* Line 715 of yacc.c  */
-#line 184 "parse-gram.y"
+/* Line 716 of yacc.c  */
+#line 182 "parse-gram.y"
        { fprintf (stderr, "{\n%s\n}", (yyvaluep->chars)); };
 
-/* Line 715 of yacc.c  */
-#line 1103 "parse-gram.c"
+/* Line 716 of yacc.c  */
+#line 1100 "parse-gram.c"
        break;
       case 53: /* "\"type\"" */
 
-/* Line 715 of yacc.c  */
-#line 188 "parse-gram.y"
+/* Line 716 of yacc.c  */
+#line 186 "parse-gram.y"
        { fprintf (stderr, "<%s>", (yyvaluep->uniqstr)); };
 
-/* Line 715 of yacc.c  */
-#line 1112 "parse-gram.c"
+/* Line 716 of yacc.c  */
+#line 1109 "parse-gram.c"
        break;
       case 82: /* "variable" */
 
-/* Line 715 of yacc.c  */
-#line 189 "parse-gram.y"
+/* Line 716 of yacc.c  */
+#line 187 "parse-gram.y"
        { fputs ((yyvaluep->uniqstr), stderr); };
 
-/* Line 715 of yacc.c  */
-#line 1121 "parse-gram.c"
+/* Line 716 of yacc.c  */
+#line 1118 "parse-gram.c"
        break;
       case 83: /* "content.opt" */
 
-/* Line 715 of yacc.c  */
-#line 184 "parse-gram.y"
+/* Line 716 of yacc.c  */
+#line 182 "parse-gram.y"
        { fprintf (stderr, "{\n%s\n}", (yyvaluep->chars)); };
 
-/* Line 715 of yacc.c  */
-#line 1130 "parse-gram.c"
+/* Line 716 of yacc.c  */
+#line 1127 "parse-gram.c"
        break;
       case 84: /* "braceless" */
 
-/* Line 715 of yacc.c  */
-#line 184 "parse-gram.y"
+/* Line 716 of yacc.c  */
+#line 182 "parse-gram.y"
        { fprintf (stderr, "{\n%s\n}", (yyvaluep->chars)); };
 
-/* Line 715 of yacc.c  */
-#line 1139 "parse-gram.c"
+/* Line 716 of yacc.c  */
+#line 1136 "parse-gram.c"
        break;
       case 85: /* "id" */
 
-/* Line 715 of yacc.c  */
-#line 196 "parse-gram.y"
+/* Line 716 of yacc.c  */
+#line 194 "parse-gram.y"
        { fprintf (stderr, "%s", (yyvaluep->symbol)->tag); };
 
-/* Line 715 of yacc.c  */
-#line 1148 "parse-gram.c"
+/* Line 716 of yacc.c  */
+#line 1145 "parse-gram.c"
        break;
       case 86: /* "id_colon" */
 
-/* Line 715 of yacc.c  */
-#line 197 "parse-gram.y"
+/* Line 716 of yacc.c  */
+#line 195 "parse-gram.y"
        { fprintf (stderr, "%s:", (yyvaluep->symbol)->tag); };
 
-/* Line 715 of yacc.c  */
-#line 1157 "parse-gram.c"
+/* Line 716 of yacc.c  */
+#line 1154 "parse-gram.c"
        break;
       case 87: /* "symbol" */
 
-/* Line 715 of yacc.c  */
-#line 196 "parse-gram.y"
+/* Line 716 of yacc.c  */
+#line 194 "parse-gram.y"
        { fprintf (stderr, "%s", (yyvaluep->symbol)->tag); };
 
-/* Line 715 of yacc.c  */
-#line 1166 "parse-gram.c"
+/* Line 716 of yacc.c  */
+#line 1163 "parse-gram.c"
        break;
       case 88: /* "string_as_id" */
 
-/* Line 715 of yacc.c  */
-#line 196 "parse-gram.y"
+/* Line 716 of yacc.c  */
+#line 194 "parse-gram.y"
        { fprintf (stderr, "%s", (yyvaluep->symbol)->tag); };
 
-/* Line 715 of yacc.c  */
-#line 1175 "parse-gram.c"
+/* Line 716 of yacc.c  */
+#line 1172 "parse-gram.c"
        break;
       default:
        break;
@@ -1665,7 +1662,6 @@ YYLTYPE yylloc;
   yyss = yyssa;
   yyvs = yyvsa;
   yyls = yylsa;
-
   yystacksize = YYINITDEPTH;
 
   YYDPRINTF ((stderr, "Starting parse\n"));
@@ -1692,7 +1688,7 @@ YYLTYPE yylloc;
 /* User initialization code.  */
 
 /* Line 1243 of yacc.c  */
-#line 86 "parse-gram.y"
+#line 84 "parse-gram.y"
 {
   /* Bison's grammar can initial empty locations, hence a default
      location is needed. */
@@ -1701,7 +1697,7 @@ YYLTYPE yylloc;
 }
 
 /* Line 1243 of yacc.c  */
-#line 1705 "parse-gram.c"
+#line 1701 "parse-gram.c"
   yylsp[0] = yylloc;
 
   goto yysetstate;
@@ -1888,8 +1884,8 @@ yyreduce:
     {
         case 6:
 
-/* Line 1460 of yacc.c  */
-#line 220 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 218 "parse-gram.y"
     {
       code_props plain_code;
       code_props_plain_init (&plain_code, (yyvsp[(1) - (1)].chars), (yylsp[(1) - (1)]));
@@ -1903,15 +1899,15 @@ yyreduce:
 
   case 7:
 
-/* Line 1460 of yacc.c  */
-#line 229 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 227 "parse-gram.y"
     { debug_flag = true; }
     break;
 
   case 8:
 
-/* Line 1460 of yacc.c  */
-#line 231 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 229 "parse-gram.y"
     {
       muscle_percent_define_insert ((yyvsp[(2) - (3)].uniqstr), (yylsp[(2) - (3)]), (yyvsp[(3) - (3)].chars));
     }
@@ -1919,15 +1915,15 @@ yyreduce:
 
   case 9:
 
-/* Line 1460 of yacc.c  */
-#line 234 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 232 "parse-gram.y"
     { defines_flag = true; }
     break;
 
   case 10:
 
-/* Line 1460 of yacc.c  */
-#line 236 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 234 "parse-gram.y"
     {
       defines_flag = true;
       spec_defines_file = xstrdup ((yyvsp[(2) - (2)].chars));
@@ -1936,43 +1932,43 @@ yyreduce:
 
   case 11:
 
-/* Line 1460 of yacc.c  */
-#line 240 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 238 "parse-gram.y"
     { error_verbose = true; }
     break;
 
   case 12:
 
-/* Line 1460 of yacc.c  */
-#line 241 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 239 "parse-gram.y"
     { expected_sr_conflicts = (yyvsp[(2) - (2)].integer); }
     break;
 
   case 13:
 
-/* Line 1460 of yacc.c  */
-#line 242 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 240 "parse-gram.y"
     { expected_rr_conflicts = (yyvsp[(2) - (2)].integer); }
     break;
 
   case 14:
 
-/* Line 1460 of yacc.c  */
-#line 243 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 241 "parse-gram.y"
     { spec_file_prefix = (yyvsp[(2) - (2)].chars); }
     break;
 
   case 15:
 
-/* Line 1460 of yacc.c  */
-#line 244 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 242 "parse-gram.y"
     { spec_file_prefix = (yyvsp[(3) - (3)].chars); }
     break;
 
   case 16:
 
-/* Line 1460 of yacc.c  */
-#line 246 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 244 "parse-gram.y"
     {
       nondeterministic_parser = true;
       glr_parser = true;
@@ -1981,8 +1977,8 @@ yyreduce:
 
   case 17:
 
-/* Line 1460 of yacc.c  */
-#line 251 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 249 "parse-gram.y"
     {
       code_props action;
       code_props_symbol_action_init (&action, (yyvsp[(2) - (2)].code), (yylsp[(2) - (2)]));
@@ -1995,78 +1991,78 @@ yyreduce:
 
   case 18:
 
-/* Line 1460 of yacc.c  */
-#line 259 "parse-gram.y"
-    { language_argmatch ((yyvsp[(2) - (2)].chars), 1, &(yylsp[(1) - (2)])); }
+/* Line 1456 of yacc.c  */
+#line 257 "parse-gram.y"
+    { language_argmatch ((yyvsp[(2) - (2)].chars), grammar_prio, &(yylsp[(1) - (2)])); }
     break;
 
   case 19:
 
-/* Line 1460 of yacc.c  */
-#line 260 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 258 "parse-gram.y"
     { add_param ("lex_param", (yyvsp[(2) - (2)].code), (yylsp[(2) - (2)])); }
     break;
 
   case 20:
 
-/* Line 1460 of yacc.c  */
-#line 261 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 259 "parse-gram.y"
     { locations_flag = true; }
     break;
 
   case 21:
 
-/* Line 1460 of yacc.c  */
-#line 262 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 260 "parse-gram.y"
     { spec_name_prefix = (yyvsp[(2) - (2)].chars); }
     break;
 
   case 22:
 
-/* Line 1460 of yacc.c  */
-#line 263 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 261 "parse-gram.y"
     { spec_name_prefix = (yyvsp[(3) - (3)].chars); }
     break;
 
   case 23:
 
-/* Line 1460 of yacc.c  */
-#line 264 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 262 "parse-gram.y"
     { no_lines_flag = true; }
     break;
 
   case 24:
 
-/* Line 1460 of yacc.c  */
-#line 265 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 263 "parse-gram.y"
     { nondeterministic_parser = true; }
     break;
 
   case 25:
 
-/* Line 1460 of yacc.c  */
-#line 266 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 264 "parse-gram.y"
     { spec_outfile = (yyvsp[(2) - (2)].chars); }
     break;
 
   case 26:
 
-/* Line 1460 of yacc.c  */
-#line 267 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 265 "parse-gram.y"
     { spec_outfile = (yyvsp[(3) - (3)].chars); }
     break;
 
   case 27:
 
-/* Line 1460 of yacc.c  */
-#line 268 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 266 "parse-gram.y"
     { add_param ("parse_param", (yyvsp[(2) - (2)].code), (yylsp[(2) - (2)])); }
     break;
 
   case 28:
 
-/* Line 1460 of yacc.c  */
-#line 270 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 268 "parse-gram.y"
     {
       /* %pure-parser is deprecated in favor of `%define api.pure', so use
          `%define api.pure' in a backward-compatible manner here.  First, don't
@@ -2083,15 +2079,15 @@ yyreduce:
 
   case 29:
 
-/* Line 1460 of yacc.c  */
-#line 282 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 280 "parse-gram.y"
     { version_check (&(yylsp[(2) - (2)]), (yyvsp[(2) - (2)].chars)); }
     break;
 
   case 30:
 
-/* Line 1460 of yacc.c  */
-#line 284 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 282 "parse-gram.y"
     {
       char const *skeleton_user = (yyvsp[(2) - (2)].chars);
       if (strchr (skeleton_user, '/'))
@@ -2113,35 +2109,35 @@ yyreduce:
           skeleton_user = uniqstr_new (skeleton_build);
           free (skeleton_build);
         }
-      skeleton_arg (skeleton_user, 1, &(yylsp[(1) - (2)]));
+      skeleton_arg (skeleton_user, grammar_prio, &(yylsp[(1) - (2)]));
     }
     break;
 
   case 31:
 
-/* Line 1460 of yacc.c  */
-#line 307 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 305 "parse-gram.y"
     { token_table_flag = true; }
     break;
 
   case 32:
 
-/* Line 1460 of yacc.c  */
-#line 308 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 306 "parse-gram.y"
     { report_flag |= report_states; }
     break;
 
   case 33:
 
-/* Line 1460 of yacc.c  */
-#line 309 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 307 "parse-gram.y"
     { yacc_flag = true; }
     break;
 
   case 37:
 
-/* Line 1460 of yacc.c  */
-#line 317 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 315 "parse-gram.y"
     {
       grammar_start_symbol_set ((yyvsp[(2) - (2)].symbol), (yylsp[(2) - (2)]));
     }
@@ -2149,8 +2145,8 @@ yyreduce:
 
   case 38:
 
-/* Line 1460 of yacc.c  */
-#line 321 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 319 "parse-gram.y"
     {
       symbol_list *list;
       for (list = (yyvsp[(3) - (3)].list); list; list = list->next)
@@ -2161,8 +2157,8 @@ yyreduce:
 
   case 39:
 
-/* Line 1460 of yacc.c  */
-#line 328 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 326 "parse-gram.y"
     {
       symbol_list *list;
       for (list = (yyvsp[(3) - (3)].list); list; list = list->next)
@@ -2173,8 +2169,8 @@ yyreduce:
 
   case 40:
 
-/* Line 1460 of yacc.c  */
-#line 335 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 333 "parse-gram.y"
     {
       default_prec = true;
     }
@@ -2182,8 +2178,8 @@ yyreduce:
 
   case 41:
 
-/* Line 1460 of yacc.c  */
-#line 339 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 337 "parse-gram.y"
     {
       default_prec = false;
     }
@@ -2191,8 +2187,8 @@ yyreduce:
 
   case 42:
 
-/* Line 1460 of yacc.c  */
-#line 343 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 341 "parse-gram.y"
     {
       /* Do not invoke muscle_percent_code_grow here since it invokes
          muscle_user_name_list_grow.  */
@@ -2203,8 +2199,8 @@ yyreduce:
 
   case 43:
 
-/* Line 1460 of yacc.c  */
-#line 350 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 348 "parse-gram.y"
     {
       muscle_percent_code_grow ((yyvsp[(2) - (3)].uniqstr), (yylsp[(2) - (3)]), (yyvsp[(3) - (3)].chars), (yylsp[(3) - (3)]));
       code_scanner_last_string_free ();
@@ -2213,22 +2209,22 @@ yyreduce:
 
   case 44:
 
-/* Line 1460 of yacc.c  */
-#line 364 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 362 "parse-gram.y"
     {}
     break;
 
   case 45:
 
-/* Line 1460 of yacc.c  */
-#line 365 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 363 "parse-gram.y"
     { muscle_code_grow ("union_name", (yyvsp[(1) - (1)].uniqstr), (yylsp[(1) - (1)])); }
     break;
 
   case 46:
 
-/* Line 1460 of yacc.c  */
-#line 370 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 368 "parse-gram.y"
     {
       union_seen = true;
       muscle_code_grow ("stype", (yyvsp[(3) - (3)].chars), (yylsp[(3) - (3)]));
@@ -2238,15 +2234,15 @@ yyreduce:
 
   case 47:
 
-/* Line 1460 of yacc.c  */
-#line 381 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 379 "parse-gram.y"
     { current_class = nterm_sym; }
     break;
 
   case 48:
 
-/* Line 1460 of yacc.c  */
-#line 382 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 380 "parse-gram.y"
     {
       current_class = unknown_sym;
       current_type = NULL;
@@ -2255,15 +2251,15 @@ yyreduce:
 
   case 49:
 
-/* Line 1460 of yacc.c  */
-#line 386 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 384 "parse-gram.y"
     { current_class = token_sym; }
     break;
 
   case 50:
 
-/* Line 1460 of yacc.c  */
-#line 387 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 385 "parse-gram.y"
     {
       current_class = unknown_sym;
       current_type = NULL;
@@ -2272,8 +2268,8 @@ yyreduce:
 
   case 51:
 
-/* Line 1460 of yacc.c  */
-#line 392 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 390 "parse-gram.y"
     {
       symbol_list *list;
       tag_seen = true;
@@ -2285,8 +2281,8 @@ yyreduce:
 
   case 52:
 
-/* Line 1460 of yacc.c  */
-#line 403 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 401 "parse-gram.y"
     {
       symbol_list *list;
       ++current_prec;
@@ -2302,127 +2298,127 @@ yyreduce:
 
   case 53:
 
-/* Line 1460 of yacc.c  */
-#line 417 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 415 "parse-gram.y"
     { (yyval.assoc) = left_assoc; }
     break;
 
   case 54:
 
-/* Line 1460 of yacc.c  */
-#line 418 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 416 "parse-gram.y"
     { (yyval.assoc) = right_assoc; }
     break;
 
   case 55:
 
-/* Line 1460 of yacc.c  */
-#line 419 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 417 "parse-gram.y"
     { (yyval.assoc) = non_assoc; }
     break;
 
   case 56:
 
-/* Line 1460 of yacc.c  */
-#line 423 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 421 "parse-gram.y"
     { current_type = NULL; }
     break;
 
   case 57:
 
-/* Line 1460 of yacc.c  */
-#line 424 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 422 "parse-gram.y"
     { current_type = (yyvsp[(1) - (1)].uniqstr); tag_seen = true; }
     break;
 
   case 58:
 
-/* Line 1460 of yacc.c  */
-#line 430 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 428 "parse-gram.y"
     { (yyval.list) = symbol_list_sym_new ((yyvsp[(1) - (1)].symbol), (yylsp[(1) - (1)])); }
     break;
 
   case 59:
 
-/* Line 1460 of yacc.c  */
-#line 432 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 430 "parse-gram.y"
     { (yyval.list) = symbol_list_prepend ((yyvsp[(1) - (2)].list), symbol_list_sym_new ((yyvsp[(2) - (2)].symbol), (yylsp[(2) - (2)]))); }
     break;
 
   case 60:
 
-/* Line 1460 of yacc.c  */
-#line 436 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 434 "parse-gram.y"
     { (yyval.symbol) = (yyvsp[(1) - (1)].symbol); }
     break;
 
   case 61:
 
-/* Line 1460 of yacc.c  */
-#line 437 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 435 "parse-gram.y"
     { (yyval.symbol) = (yyvsp[(1) - (2)].symbol); symbol_user_token_number_set ((yyvsp[(1) - (2)].symbol), (yyvsp[(2) - (2)].integer), (yylsp[(2) - (2)])); }
     break;
 
   case 62:
 
-/* Line 1460 of yacc.c  */
-#line 443 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 441 "parse-gram.y"
     { (yyval.list) = symbol_list_sym_new ((yyvsp[(1) - (1)].symbol), (yylsp[(1) - (1)])); }
     break;
 
   case 63:
 
-/* Line 1460 of yacc.c  */
-#line 445 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 443 "parse-gram.y"
     { (yyval.list) = symbol_list_prepend ((yyvsp[(1) - (2)].list), symbol_list_sym_new ((yyvsp[(2) - (2)].symbol), (yylsp[(2) - (2)]))); }
     break;
 
   case 64:
 
-/* Line 1460 of yacc.c  */
-#line 449 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 447 "parse-gram.y"
     { (yyval.list) = (yyvsp[(1) - (1)].list); }
     break;
 
   case 65:
 
-/* Line 1460 of yacc.c  */
-#line 450 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 448 "parse-gram.y"
     { (yyval.list) = symbol_list_prepend ((yyvsp[(1) - (2)].list), (yyvsp[(2) - (2)].list)); }
     break;
 
   case 66:
 
-/* Line 1460 of yacc.c  */
-#line 454 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 452 "parse-gram.y"
     { (yyval.list) = symbol_list_sym_new ((yyvsp[(1) - (1)].symbol), (yylsp[(1) - (1)])); }
     break;
 
   case 67:
 
-/* Line 1460 of yacc.c  */
-#line 455 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 453 "parse-gram.y"
     { (yyval.list) = symbol_list_type_new ((yyvsp[(1) - (1)].uniqstr), (yylsp[(1) - (1)])); }
     break;
 
   case 68:
 
-/* Line 1460 of yacc.c  */
-#line 456 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 454 "parse-gram.y"
     { (yyval.list) = symbol_list_default_tagged_new ((yylsp[(1) - (1)])); }
     break;
 
   case 69:
 
-/* Line 1460 of yacc.c  */
-#line 457 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 455 "parse-gram.y"
     { (yyval.list) = symbol_list_default_tagless_new ((yylsp[(1) - (1)])); }
     break;
 
   case 70:
 
-/* Line 1460 of yacc.c  */
-#line 463 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 461 "parse-gram.y"
     {
        current_type = (yyvsp[(1) - (1)].uniqstr);
        tag_seen = true;
@@ -2431,8 +2427,8 @@ yyreduce:
 
   case 71:
 
-/* Line 1460 of yacc.c  */
-#line 468 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 466 "parse-gram.y"
     {
        symbol_class_set ((yyvsp[(1) - (1)].symbol), current_class, (yylsp[(1) - (1)]), true);
        symbol_type_set ((yyvsp[(1) - (1)].symbol), current_type, (yylsp[(1) - (1)]));
@@ -2441,8 +2437,8 @@ yyreduce:
 
   case 72:
 
-/* Line 1460 of yacc.c  */
-#line 473 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 471 "parse-gram.y"
     {
       symbol_class_set ((yyvsp[(1) - (2)].symbol), current_class, (yylsp[(1) - (2)]), true);
       symbol_type_set ((yyvsp[(1) - (2)].symbol), current_type, (yylsp[(1) - (2)]));
@@ -2452,8 +2448,8 @@ yyreduce:
 
   case 73:
 
-/* Line 1460 of yacc.c  */
-#line 479 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 477 "parse-gram.y"
     {
       symbol_class_set ((yyvsp[(1) - (2)].symbol), current_class, (yylsp[(1) - (2)]), true);
       symbol_type_set ((yyvsp[(1) - (2)].symbol), current_type, (yylsp[(1) - (2)]));
@@ -2463,8 +2459,8 @@ yyreduce:
 
   case 74:
 
-/* Line 1460 of yacc.c  */
-#line 485 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 483 "parse-gram.y"
     {
       symbol_class_set ((yyvsp[(1) - (3)].symbol), current_class, (yylsp[(1) - (3)]), true);
       symbol_type_set ((yyvsp[(1) - (3)].symbol), current_type, (yylsp[(1) - (3)]));
@@ -2475,8 +2471,8 @@ yyreduce:
 
   case 81:
 
-/* Line 1460 of yacc.c  */
-#line 515 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 513 "parse-gram.y"
     {
       yyerrok;
     }
@@ -2484,78 +2480,78 @@ yyreduce:
 
   case 82:
 
-/* Line 1460 of yacc.c  */
-#line 521 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 519 "parse-gram.y"
     { current_lhs = (yyvsp[(1) - (1)].symbol); current_lhs_location = (yylsp[(1) - (1)]); }
     break;
 
   case 84:
 
-/* Line 1460 of yacc.c  */
-#line 525 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 523 "parse-gram.y"
     { grammar_current_rule_end ((yylsp[(1) - (1)])); }
     break;
 
   case 85:
 
-/* Line 1460 of yacc.c  */
-#line 526 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 524 "parse-gram.y"
     { grammar_current_rule_end ((yylsp[(3) - (3)])); }
     break;
 
   case 87:
 
-/* Line 1460 of yacc.c  */
-#line 532 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 530 "parse-gram.y"
     { grammar_current_rule_begin (current_lhs, current_lhs_location); }
     break;
 
   case 88:
 
-/* Line 1460 of yacc.c  */
-#line 534 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 532 "parse-gram.y"
     { grammar_current_rule_symbol_append ((yyvsp[(2) - (2)].symbol), (yylsp[(2) - (2)])); }
     break;
 
   case 89:
 
-/* Line 1460 of yacc.c  */
-#line 536 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 534 "parse-gram.y"
     { grammar_current_rule_action_append ((yyvsp[(2) - (2)].code), (yylsp[(2) - (2)])); }
     break;
 
   case 90:
 
-/* Line 1460 of yacc.c  */
-#line 538 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 536 "parse-gram.y"
     { grammar_current_rule_prec_set ((yyvsp[(3) - (3)].symbol), (yylsp[(3) - (3)])); }
     break;
 
   case 91:
 
-/* Line 1460 of yacc.c  */
-#line 540 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 538 "parse-gram.y"
     { grammar_current_rule_dprec_set ((yyvsp[(3) - (3)].integer), (yylsp[(3) - (3)])); }
     break;
 
   case 92:
 
-/* Line 1460 of yacc.c  */
-#line 542 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 540 "parse-gram.y"
     { grammar_current_rule_merge_set ((yyvsp[(3) - (3)].uniqstr), (yylsp[(3) - (3)])); }
     break;
 
   case 94:
 
-/* Line 1460 of yacc.c  */
-#line 552 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 550 "parse-gram.y"
     { (yyval.uniqstr) = uniqstr_new ((yyvsp[(1) - (1)].chars)); }
     break;
 
   case 95:
 
-/* Line 1460 of yacc.c  */
-#line 558 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 556 "parse-gram.y"
     {
       (yyval.chars) = "";
     }
@@ -2563,8 +2559,8 @@ yyreduce:
 
   case 97:
 
-/* Line 1460 of yacc.c  */
-#line 571 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 569 "parse-gram.y"
     {
       code_props plain_code;
       (yyvsp[(1) - (1)].code)[strlen ((yyvsp[(1) - (1)].code)) - 1] = '\n';
@@ -2577,15 +2573,15 @@ yyreduce:
 
   case 98:
 
-/* Line 1460 of yacc.c  */
-#line 591 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 589 "parse-gram.y"
     { (yyval.symbol) = symbol_from_uniqstr ((yyvsp[(1) - (1)].uniqstr), (yylsp[(1) - (1)])); }
     break;
 
   case 99:
 
-/* Line 1460 of yacc.c  */
-#line 593 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 591 "parse-gram.y"
     {
       (yyval.symbol) = symbol_get (char_name ((yyvsp[(1) - (1)].character)), (yylsp[(1) - (1)]));
       symbol_class_set ((yyval.symbol), token_sym, (yylsp[(1) - (1)]), false);
@@ -2595,15 +2591,15 @@ yyreduce:
 
   case 100:
 
-/* Line 1460 of yacc.c  */
-#line 601 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 599 "parse-gram.y"
     { (yyval.symbol) = symbol_from_uniqstr ((yyvsp[(1) - (1)].uniqstr), (yylsp[(1) - (1)])); }
     break;
 
   case 103:
 
-/* Line 1460 of yacc.c  */
-#line 613 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 611 "parse-gram.y"
     {
       (yyval.symbol) = symbol_get (quotearg_style (c_quoting_style, (yyvsp[(1) - (1)].chars)), (yylsp[(1) - (1)]));
       symbol_class_set ((yyval.symbol), token_sym, (yylsp[(1) - (1)]), false);
@@ -2612,8 +2608,8 @@ yyreduce:
 
   case 105:
 
-/* Line 1460 of yacc.c  */
-#line 622 "parse-gram.y"
+/* Line 1456 of yacc.c  */
+#line 620 "parse-gram.y"
     {
       code_props plain_code;
       code_props_plain_init (&plain_code, (yyvsp[(2) - (2)].chars), (yylsp[(2) - (2)]));
@@ -2626,8 +2622,8 @@ yyreduce:
 
 
 
-/* Line 1460 of yacc.c  */
-#line 2631 "parse-gram.c"
+/* Line 1456 of yacc.c  */
+#line 2627 "parse-gram.c"
       default: break;
     }
   YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc);
@@ -2845,8 +2841,8 @@ yyreturn:
 
 
 
-/* Line 1680 of yacc.c  */
-#line 632 "parse-gram.y"
+/* Line 1676 of yacc.c  */
+#line 630 "parse-gram.y"