1 /* A Bison parser, made by GNU Bison 1.875d.  */ 
   3 /* Skeleton parser for Yacc-like parsing with Bison, 
   4    Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004 Free Software Foundation, Inc. 
   6    This program is free software; you can redistribute it and/or modify 
   7    it under the terms of the GNU General Public License as published by 
   8    the Free Software Foundation; either version 2, or (at your option) 
  11    This program is distributed in the hope that it will be useful, 
  12    but WITHOUT ANY WARRANTY; without even the implied warranty of 
  13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 
  14    GNU General Public License for more details. 
  16    You should have received a copy of the GNU General Public License 
  17    along with this program; if not, write to the Free Software 
  18    Foundation, Inc., 59 Temple Place - Suite 330, 
  19    Boston, MA 02111-1307, USA.  */ 
  21 /* As a special exception, when this file is copied by Bison into a 
  22    Bison output file, you may use that output file without restriction. 
  23    This special exception was added by the Free Software Foundation 
  24    in version 1.24 of Bison.  */ 
  26 /* Written by Richard Stallman by simplifying the original so called 
  27    ``semantic'' parser.  */ 
  29 /* All symbols defined below should begin with yy or YY, to avoid 
  30    infringing on user name space.  This should be done even for local 
  31    variables, as they might otherwise be expanded by user macros. 
  32    There are some unavoidable exceptions within include files to 
  33    define necessary library symbols; they are noted "INFRINGES ON 
  34    USER NAME SPACE" below.  */ 
  36 /* Identify Bison output.  */ 
  40 #define YYSKELETON_NAME "yacc.c" 
  45 /* Using locations.  */ 
  46 #define YYLSP_NEEDED 1 
  48 /* If NAME_PREFIX is specified substitute the variables and functions 
  50 #define yyparse gram_parse 
  51 #define yylex   gram_lex 
  52 #define yyerror gram_error 
  53 #define yylval  gram_lval 
  54 #define yychar  gram_char 
  55 #define yydebug gram_debug 
  56 #define yynerrs gram_nerrs 
  57 #define yylloc gram_lloc 
  62    /* Put the tokens into the symbol table, so that GDB and other debuggers 
  71      PERCENT_DESTRUCTOR 
= 263, 
  72      PERCENT_PRINTER 
= 264, 
  76      PERCENT_NONASSOC 
= 268, 
  81      PERCENT_DEFAULT_PREC 
= 273, 
  83      PERCENT_DEFINES 
= 275, 
  84      PERCENT_ERROR_VERBOSE 
= 276, 
  86      PERCENT_EXPECT_RR 
= 278, 
  87      PERCENT_FILE_PREFIX 
= 279, 
  88      PERCENT_GLR_PARSER 
= 280, 
  89      PERCENT_INITIAL_ACTION 
= 281, 
  90      PERCENT_LEX_PARAM 
= 282, 
  91      PERCENT_LOCATIONS 
= 283, 
  92      PERCENT_NAME_PREFIX 
= 284, 
  93      PERCENT_NO_DEFAULT_PREC 
= 285, 
  94      PERCENT_NO_LINES 
= 286, 
  95      PERCENT_NONDETERMINISTIC_PARSER 
= 287, 
  97      PERCENT_PARSE_PARAM 
= 289, 
  98      PERCENT_PURE_PARSER 
= 290, 
  99      PERCENT_SKELETON 
= 291, 
 101      PERCENT_TOKEN_TABLE 
= 293, 
 102      PERCENT_VERBOSE 
= 294, 
 110      PERCENT_PERCENT 
= 302, 
 119 #define PERCENT_TOKEN 260 
 120 #define PERCENT_NTERM 261 
 121 #define PERCENT_TYPE 262 
 122 #define PERCENT_DESTRUCTOR 263 
 123 #define PERCENT_PRINTER 264 
 124 #define PERCENT_UNION 265 
 125 #define PERCENT_LEFT 266 
 126 #define PERCENT_RIGHT 267 
 127 #define PERCENT_NONASSOC 268 
 128 #define PERCENT_PREC 269 
 129 #define PERCENT_DPREC 270 
 130 #define PERCENT_MERGE 271 
 131 #define PERCENT_DEBUG 272 
 132 #define PERCENT_DEFAULT_PREC 273 
 133 #define PERCENT_DEFINE 274 
 134 #define PERCENT_DEFINES 275 
 135 #define PERCENT_ERROR_VERBOSE 276 
 136 #define PERCENT_EXPECT 277 
 137 #define PERCENT_EXPECT_RR 278 
 138 #define PERCENT_FILE_PREFIX 279 
 139 #define PERCENT_GLR_PARSER 280 
 140 #define PERCENT_INITIAL_ACTION 281 
 141 #define PERCENT_LEX_PARAM 282 
 142 #define PERCENT_LOCATIONS 283 
 143 #define PERCENT_NAME_PREFIX 284 
 144 #define PERCENT_NO_DEFAULT_PREC 285 
 145 #define PERCENT_NO_LINES 286 
 146 #define PERCENT_NONDETERMINISTIC_PARSER 287 
 147 #define PERCENT_OUTPUT 288 
 148 #define PERCENT_PARSE_PARAM 289 
 149 #define PERCENT_PURE_PARSER 290 
 150 #define PERCENT_SKELETON 291 
 151 #define PERCENT_START 292 
 152 #define PERCENT_TOKEN_TABLE 293 
 153 #define PERCENT_VERBOSE 294 
 154 #define PERCENT_YACC 295 
 157 #define SEMICOLON 298 
 161 #define PERCENT_PERCENT 302 
 164 #define BRACED_CODE 305 
 169 /* Copy the first part of user declarations.  */ 
 170 #line 1 "parse-gram.y" 
 171 /* Bison Grammar Parser                             -*- C -*- 
 173    Copyright (C) 2002, 2003, 2004 Free Software Foundation, Inc. 
 175    This file is part of Bison, the GNU Compiler Compiler. 
 177    This program is free software; you can redistribute it and/or modify 
 178    it under the terms of the GNU General Public License as published by 
 179    the Free Software Foundation; either version 2 of the License, or 
 180    (at your option) any later version. 
 182    This program is distributed in the hope that it will be useful, 
 183    but WITHOUT ANY WARRANTY; without even the implied warranty of 
 184    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 
 185    GNU General Public License for more details. 
 187    You should have received a copy of the GNU General Public License 
 188    along with this program; if not, write to the Free Software 
 189    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 
 195 #include "complain.h" 
 196 #include "conflicts.h" 
 200 #include "muscle_tab.h" 
 205 #define YYLLOC_DEFAULT(Current, Rhs, N)  (Current) = lloc_default (Rhs, N) 
 206 static YYLTYPE 
lloc_default (YYLTYPE 
const *, int); 
 208 /* Request detailed syntax error messages, and pass them to GRAM_ERROR. 
 209    FIXME: depends on the undocumented availability of YYLLOC.  */ 
 211 #define yyerror(Msg) \ 
 212         gram_error (&yylloc, Msg) 
 213 static void gram_error (location 
const *, char const *); 
 215 #define YYPRINT(File, Type, Value) \ 
 216         print_token_value (File, Type, &Value) 
 217 static void print_token_value (FILE *, int, YYSTYPE 
const *); 
 219 static void add_param (char const *, char *, location
); 
 221 symbol_class current_class 
= unknown_sym
; 
 222 uniqstr current_type 
= 0; 
 224 location current_lhs_location
; 
 226 int current_prec 
= 0; 
 229 /* Enabling traces.  */ 
 234 /* Enabling verbose error messages.  */ 
 235 #ifdef YYERROR_VERBOSE 
 236 # undef YYERROR_VERBOSE 
 237 # define YYERROR_VERBOSE 1 
 239 # define YYERROR_VERBOSE 1 
 242 #if ! defined (YYSTYPE) && ! defined (YYSTYPE_IS_DECLARED) 
 243 #line 78 "parse-gram.y" 
 244 typedef union YYSTYPE 
{ 
 252 /* Line 191 of yacc.c.  */ 
 253 #line 254 "parse-gram.c" 
 254 # define yystype YYSTYPE /* obsolescent; will be withdrawn */ 
 255 # define YYSTYPE_IS_DECLARED 1 
 256 # define YYSTYPE_IS_TRIVIAL 1 
 259 #if ! defined (YYLTYPE) && ! defined (YYLTYPE_IS_DECLARED) 
 260 typedef struct YYLTYPE
 
 267 # define yyltype YYLTYPE /* obsolescent; will be withdrawn */ 
 268 # define YYLTYPE_IS_DECLARED 1 
 269 # define YYLTYPE_IS_TRIVIAL 1 
 273 /* Copy the second part of user declarations.  */ 
 276 /* Line 214 of yacc.c.  */ 
 277 #line 278 "parse-gram.c" 
 279 #if ! defined (yyoverflow) || YYERROR_VERBOSE 
 285 #  define YYMALLOC malloc 
 288 /* The parser invokes alloca or malloc; define the necessary symbols.  */ 
 290 # ifdef YYSTACK_USE_ALLOCA 
 291 #  if YYSTACK_USE_ALLOCA 
 292 #   define YYSTACK_ALLOC alloca 
 295 #  if defined (alloca) || defined (_ALLOCA_H) 
 296 #   define YYSTACK_ALLOC alloca 
 299 #    define YYSTACK_ALLOC __builtin_alloca 
 304 # ifdef YYSTACK_ALLOC 
 305    /* Pacify GCC's `empty if-body' warning. */ 
 306 #  define YYSTACK_FREE(Ptr) do { /* empty */; } while (0) 
 308 #  if defined (__STDC__) || defined (__cplusplus) 
 309 #   include <stdlib.h> /* INFRINGES ON USER NAME SPACE */ 
 310 #   define YYSIZE_T size_t 
 312 #  define YYSTACK_ALLOC YYMALLOC 
 313 #  define YYSTACK_FREE YYFREE 
 315 #endif /* ! defined (yyoverflow) || YYERROR_VERBOSE */ 
 318 #if (! defined (yyoverflow) \ 
 319      && (! defined (__cplusplus) \ 
 320          || (defined (YYLTYPE_IS_TRIVIAL) && YYLTYPE_IS_TRIVIAL \ 
 321              && defined (YYSTYPE_IS_TRIVIAL) && YYSTYPE_IS_TRIVIAL))) 
 323 /* A type that is properly aligned for any stack member.  */ 
 331 /* The size of the maximum gap between one aligned stack and the next.  */ 
 332 # define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1) 
 334 /* The size of an array large to enough to hold all stacks, each with 
 336 # define YYSTACK_BYTES(N) \ 
 337      ((N) * (sizeof (short int) + sizeof (YYSTYPE) + sizeof (YYLTYPE))  \ 
 338       + 2 * YYSTACK_GAP_MAXIMUM) 
 340 /* Copy COUNT objects from FROM to TO.  The source and destination do 
 343 #  if defined (__GNUC__) && 1 < __GNUC__ 
 344 #   define YYCOPY(To, From, Count) \ 
 345       __builtin_memcpy (To, From, (Count) * sizeof (*(From))) 
 347 #   define YYCOPY(To, From, Count)              \ 
 350           register YYSIZE_T yyi;                \ 
 351           for (yyi = 0; yyi < (Count); yyi++)   \ 
 352             (To)[yyi] = (From)[yyi];            \ 
 358 /* Relocate STACK from its old location to the new one.  The 
 359    local variables YYSIZE and YYSTACKSIZE give the old and new number of 
 360    elements in the stack, and YYPTR gives the new location of the 
 361    stack.  Advance YYPTR to a properly aligned location for the next 
 363 # define YYSTACK_RELOCATE(Stack)                                        \ 
 366         YYSIZE_T yynewbytes;                                            \ 
 367         YYCOPY (&yyptr->Stack, Stack, yysize);                          \ 
 368         Stack = &yyptr->Stack;                                          \ 
 369         yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \ 
 370         yyptr += yynewbytes / sizeof (*yyptr);                          \ 
 376 #if defined (__STDC__) || defined (__cplusplus) 
 377    typedef signed char yysigned_char
; 
 379    typedef short int yysigned_char
; 
 382 /* YYFINAL -- State number of the termination state. */ 
 384 /* YYLAST -- Last index in YYTABLE.  */ 
 387 /* YYNTOKENS -- Number of terminals. */ 
 389 /* YYNNTS -- Number of nonterminals. */ 
 391 /* YYNRULES -- Number of rules. */ 
 393 /* YYNRULES -- Number of states. */ 
 394 #define YYNSTATES  108 
 396 /* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX.  */ 
 398 #define YYMAXUTOK   305 
 400 #define YYTRANSLATE(YYX)                                                \ 
 401   ((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK) 
 403 /* YYTRANSLATE[YYLEX] -- Bison symbol number corresponding to YYLEX.  */ 
 404 static const unsigned char yytranslate
[] = 
 406        0,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 407        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 408        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 409        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 410        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 411        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 412        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 413        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 414        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 415        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 416        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 417        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 418        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 419        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 420        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 421        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 422        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 423        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 424        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 425        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 426        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 427        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 428        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 429        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 430        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, 
 431        2,     2,     2,     2,     2,     2,     1,     2,     3,     4, 
 432        5,     6,     7,     8,     9,    10,    11,    12,    13,    14, 
 433       15,    16,    17,    18,    19,    20,    21,    22,    23,    24, 
 434       25,    26,    27,    28,    29,    30,    31,    32,    33,    34, 
 435       35,    36,    37,    38,    39,    40,    41,    42,    43,    44, 
 436       45,    46,    47,    48,    49,    50 
 440 /* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in 
 442 static const unsigned char yyprhs
[] = 
 444        0,     0,     3,     8,     9,    12,    14,    16,    18,    22, 
 445       24,    26,    29,    32,    36,    38,    40,    42,    44,    48, 
 446       50,    52,    56,    58,    60,    63,    65,    67,    69,    71, 
 447       73,    75,    78,    80,    83,    86,    88,    90,    91,    95, 
 448       96,   100,   104,   108,   110,   112,   114,   115,   117,   119, 
 449      122,   124,   126,   129,   132,   136,   138,   141,   143,   146, 
 450      148,   151,   154,   155,   159,   161,   165,   168,   169,   172, 
 451      175,   179,   183,   187,   189,   191,   193,   195,   197,   198 
 454 /* YYRHS -- A `-1'-separated list of the rules' RHS. */ 
 455 static const yysigned_char yyrhs
[] = 
 457       52,     0,    -1,    53,    47,    65,    75,    -1,    -1,    53, 
 458       54,    -1,    55,    -1,    48,    -1,    17,    -1,    19,    74, 
 459       74,    -1,    20,    -1,    21,    -1,    22,     4,    -1,    23, 
 460        4,    -1,    24,    42,    74,    -1,    25,    -1,    26,    -1, 
 461       27,    -1,    28,    -1,    29,    42,    74,    -1,    31,    -1, 
 462       32,    -1,    33,    42,    74,    -1,    34,    -1,    35,    -1, 
 463       36,    74,    -1,    38,    -1,    39,    -1,    40,    -1,    43, 
 464       -1,    59,    -1,    56,    -1,    37,    71,    -1,    10,    -1, 
 465        8,    62,    -1,     9,    62,    -1,    18,    -1,    30,    -1, 
 466       -1,     6,    57,    64,    -1,    -1,     5,    58,    64,    -1, 
 467        7,    41,    62,    -1,    60,    61,    62,    -1,    11,    -1, 
 468       12,    -1,    13,    -1,    -1,    41,    -1,    71,    -1,    62, 
 469       71,    -1,    41,    -1,    45,    -1,    45,     4,    -1,    45, 
 470       73,    -1,    45,     4,    73,    -1,    63,    -1,    64,    63, 
 471       -1,    66,    -1,    65,    66,    -1,    67,    -1,    55,    43, 
 472       -1,     1,    43,    -1,    -1,    46,    68,    69,    -1,    70, 
 473       -1,    69,    44,    70,    -1,    69,    43,    -1,    -1,    70, 
 474       71,    -1,    70,    72,    -1,    70,    14,    71,    -1,    70, 
 475       15,     4,    -1,    70,    16,    41,    -1,    45,    -1,    73, 
 476       -1,    50,    -1,     3,    -1,     3,    -1,    -1,    47,    49, 
 480 /* YYRLINE[YYN] -- source line where rule number YYN was defined.  */ 
 481 static const unsigned short int yyrline
[] = 
 483        0,   171,   171,   179,   181,   185,   186,   187,   188,   189, 
 484      190,   191,   192,   193,   194,   199,   203,   204,   205,   206, 
 485      207,   208,   209,   210,   211,   212,   213,   214,   215,   219, 
 486      220,   221,   225,   231,   238,   245,   249,   256,   256,   261, 
 487      261,   266,   276,   291,   292,   293,   297,   298,   304,   305, 
 488      310,   314,   319,   325,   331,   342,   343,   352,   353,   359, 
 489      360,   365,   372,   372,   376,   377,   378,   383,   384,   386, 
 490      388,   390,   392,   397,   398,   402,   408,   417,   424,   426 
 494 #if YYDEBUG || YYERROR_VERBOSE 
 495 /* YYTNME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM. 
 496    First, the terminals, then, starting at YYNTOKENS, nonterminals. */ 
 497 static const char *const yytname
[] = 
 499   "\"end of file\"", "error", "$undefined", "\"string\"", "\"integer\"", 
 500   "\"%token\"", "\"%nterm\"", "\"%type\"", "\"%destructor {...}\"", 
 501   "\"%printer {...}\"", "\"%union {...}\"", "\"%left\"", "\"%right\"", 
 502   "\"%nonassoc\"", "\"%prec\"", "\"%dprec\"", "\"%merge\"", "\"%debug\"", 
 503   "\"%default-prec\"", "\"%define\"", "\"%defines\"", "\"%error-verbose\"", 
 504   "\"%expect\"", "\"%expect-rr\"", "\"%file-prefix\"", "\"%glr-parser\"", 
 505   "\"%initial-action {...}\"", "\"%lex-param {...}\"", "\"%locations\"", 
 506   "\"%name-prefix\"", "\"%no-default-prec\"", "\"%no-lines\"", 
 507   "\"%nondeterministic-parser\"", "\"%output\"", "\"%parse-param {...}\"", 
 508   "\"%pure-parser\"", "\"%skeleton\"", "\"%start\"", "\"%token-table\"", 
 509   "\"%verbose\"", "\"%yacc\"", "\"type\"", "\"=\"", "\";\"", "\"|\"", 
 510   "\"identifier\"", "\"identifier:\"", "\"%%\"", "\"%{...%}\"", 
 511   "\"epilogue\"", "\"{...}\"", "$accept", "input", "declarations", 
 512   "declaration", "grammar_declaration", "symbol_declaration", "@1", "@2", 
 513   "precedence_declaration", "precedence_declarator", "type.opt", 
 514   "symbols.1", "symbol_def", "symbol_defs.1", "grammar", 
 515   "rules_or_grammar_declaration", "rules", "@3", "rhses.1", "rhs", 
 516   "symbol", "action", "string_as_id", "string_content", "epilogue.opt", 0 
 521 /* YYTOKNUM[YYLEX-NUM] -- Internal token number corresponding to 
 523 static const unsigned short int yytoknum
[] = 
 525        0,   256,   257,   258,   259,   260,   261,   262,   263,   264, 
 526      265,   266,   267,   268,   269,   270,   271,   272,   273,   274, 
 527      275,   276,   277,   278,   279,   280,   281,   282,   283,   284, 
 528      285,   286,   287,   288,   289,   290,   291,   292,   293,   294, 
 529      295,   296,   297,   298,   299,   300,   301,   302,   303,   304, 
 534 /* YYR1[YYN] -- Symbol number of symbol that rule YYN derives.  */ 
 535 static const unsigned char yyr1
[] = 
 537        0,    51,    52,    53,    53,    54,    54,    54,    54,    54, 
 538       54,    54,    54,    54,    54,    54,    54,    54,    54,    54, 
 539       54,    54,    54,    54,    54,    54,    54,    54,    54,    55, 
 540       55,    55,    55,    55,    55,    55,    55,    57,    56,    58, 
 541       56,    56,    59,    60,    60,    60,    61,    61,    62,    62, 
 542       63,    63,    63,    63,    63,    64,    64,    65,    65,    66, 
 543       66,    66,    68,    67,    69,    69,    69,    70,    70,    70, 
 544       70,    70,    70,    71,    71,    72,    73,    74,    75,    75 
 547 /* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN.  */ 
 548 static const unsigned char yyr2
[] = 
 550        0,     2,     4,     0,     2,     1,     1,     1,     3,     1, 
 551        1,     2,     2,     3,     1,     1,     1,     1,     3,     1, 
 552        1,     3,     1,     1,     2,     1,     1,     1,     1,     1, 
 553        1,     2,     1,     2,     2,     1,     1,     0,     3,     0, 
 554        3,     3,     3,     1,     1,     1,     0,     1,     1,     2, 
 555        1,     1,     2,     2,     3,     1,     2,     1,     2,     1, 
 556        2,     2,     0,     3,     1,     3,     2,     0,     2,     2, 
 557        3,     3,     3,     1,     1,     1,     1,     1,     0,     2 
 560 /* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state 
 561    STATE-NUM when YYTABLE doesn't specify something else to do.  Zero 
 562    means the default is an error.  */ 
 563 static const unsigned char yydefact
[] = 
 565        3,     0,     0,     1,    39,    37,     0,     0,     0,    32, 
 566       43,    44,    45,     7,    35,     0,     9,    10,     0,     0, 
 567        0,    14,    15,    16,    17,     0,    36,    19,    20,     0, 
 568       22,    23,     0,     0,    25,    26,    27,    28,     0,     6, 
 569        4,     5,    30,    29,    46,     0,     0,     0,    76,    73, 
 570       33,    48,    74,    34,    77,     0,    11,    12,     0,     0, 
 571        0,    24,    31,     0,    62,     0,     0,    57,    59,    47, 
 572        0,    50,    51,    55,    40,    38,    41,    49,     8,    13, 
 573       18,    21,    61,    67,    60,     0,    58,     2,    42,    52, 
 574       53,    56,    63,    64,    79,    54,    66,    67,     0,     0, 
 575        0,    75,    68,    69,    65,    70,    71,    72 
 578 /* YYDEFGOTO[NTERM-NUM]. */ 
 579 static const yysigned_char yydefgoto
[] = 
 581       -1,     1,     2,    40,    65,    42,    46,    45,    43,    44, 
 582       70,    50,    73,    74,    66,    67,    68,    83,    92,    93, 
 586 /* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing 
 588 #define YYPACT_NINF -67 
 589 static const yysigned_char yypact
[] = 
 591      -67,     5,   110,   -67,   -67,   -67,   -34,     0,     0,   -67, 
 592      -67,   -67,   -67,   -67,   -67,    13,   -67,   -67,    20,    31, 
 593      -17,   -67,   -67,   -67,   -67,    -6,   -67,   -67,   -67,    -5, 
 594      -67,   -67,    13,     0,   -67,   -67,   -67,   -67,    68,   -67, 
 595      -67,   -67,   -67,   -67,    -3,   -37,   -37,     0,   -67,   -67, 
 596        0,   -67,   -67,     0,   -67,    13,   -67,   -67,    13,    13, 
 597       13,   -67,   -67,    -2,   -67,     3,    21,   -67,   -67,   -67, 
 598        0,   -67,     6,   -67,   -37,   -37,     0,   -67,   -67,   -67, 
 599      -67,   -67,   -67,   -67,   -67,     1,   -67,   -67,     0,    39, 
 600      -67,   -67,   -32,    -1,   -67,   -67,   -67,   -67,     0,    43, 
 601        7,   -67,   -67,   -67,    -1,   -67,   -67,   -67 
 604 /* YYPGOTO[NTERM-NUM].  */ 
 605 static const yysigned_char yypgoto
[] = 
 607      -67,   -67,   -67,   -67,    50,   -67,   -67,   -67,   -67,   -67, 
 608      -67,    -7,   -56,     8,   -67,   -13,   -67,   -67,   -67,   -41, 
 609      -33,   -67,   -66,    29,   -67 
 612 /* YYTABLE[YYPACT[STATE-NUM]].  What to do in state STATE-NUM.  If 
 613    positive, shift that token.  If negative, reduce the rule which 
 614    number is the opposite.  If zero, do what YYDEFACT says. 
 615    If YYTABLE_NINF, syntax error.  */ 
 616 #define YYTABLE_NINF -79 
 617 static const yysigned_char yytable
[] = 
 619       62,    53,    48,    48,    71,     3,    90,    47,    72,    48, 
 620       89,    96,    97,    98,    99,   100,    54,    77,    91,    91, 
 621       77,   -78,    63,    95,    56,    58,     4,     5,     6,     7, 
 622        8,     9,    10,    11,    12,    57,    59,    60,    69,    14, 
 623       76,    82,    48,    77,    49,    49,    84,   106,   107,   101, 
 624       94,    26,    41,    86,    75,    77,   104,     0,    33,     0, 
 625      102,    61,     0,    88,     0,   105,     0,    64,    85,    63, 
 626        0,   102,     0,     4,     5,     6,     7,     8,     9,    10, 
 627       11,    12,     0,     0,    78,     0,    14,    79,    80,    81, 
 628        0,     0,     0,     0,     0,     0,     0,     0,    26,     0, 
 629        0,     0,     0,     0,     0,    33,     0,     0,     0,     0, 
 630        0,     0,     0,     0,    64,     4,     5,     6,     7,     8, 
 631        9,    10,    11,    12,     0,     0,     0,    13,    14,    15, 
 632       16,    17,    18,    19,    20,    21,    22,    23,    24,    25, 
 633       26,    27,    28,    29,    30,    31,    32,    33,    34,    35, 
 634       36,     0,     0,    37,     0,     0,     0,    38,    39 
 637 static const yysigned_char yycheck
[] = 
 639       33,     8,     3,     3,    41,     0,    72,    41,    45,     3, 
 640        4,    43,    44,    14,    15,    16,     3,    50,    74,    75, 
 641       53,     0,     1,    89,     4,    42,     5,     6,     7,     8, 
 642        9,    10,    11,    12,    13,     4,    42,    42,    41,    18, 
 643       47,    43,     3,    76,    45,    45,    43,     4,    41,    50, 
 644       49,    30,     2,    66,    46,    88,    97,    -1,    37,    -1, 
 645       93,    32,    -1,    70,    -1,    98,    -1,    46,    47,     1, 
 646       -1,   104,    -1,     5,     6,     7,     8,     9,    10,    11, 
 647       12,    13,    -1,    -1,    55,    -1,    18,    58,    59,    60, 
 648       -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    30,    -1, 
 649       -1,    -1,    -1,    -1,    -1,    37,    -1,    -1,    -1,    -1, 
 650       -1,    -1,    -1,    -1,    46,     5,     6,     7,     8,     9, 
 651       10,    11,    12,    13,    -1,    -1,    -1,    17,    18,    19, 
 652       20,    21,    22,    23,    24,    25,    26,    27,    28,    29, 
 653       30,    31,    32,    33,    34,    35,    36,    37,    38,    39, 
 654       40,    -1,    -1,    43,    -1,    -1,    -1,    47,    48 
 657 /* YYSTOS[STATE-NUM] -- The (internal number of the) accessing 
 658    symbol of state STATE-NUM.  */ 
 659 static const unsigned char yystos
[] = 
 661        0,    52,    53,     0,     5,     6,     7,     8,     9,    10, 
 662       11,    12,    13,    17,    18,    19,    20,    21,    22,    23, 
 663       24,    25,    26,    27,    28,    29,    30,    31,    32,    33, 
 664       34,    35,    36,    37,    38,    39,    40,    43,    47,    48, 
 665       54,    55,    56,    59,    60,    58,    57,    41,     3,    45, 
 666       62,    71,    73,    62,     3,    74,     4,     4,    42,    42, 
 667       42,    74,    71,     1,    46,    55,    65,    66,    67,    41, 
 668       61,    41,    45,    63,    64,    64,    62,    71,    74,    74, 
 669       74,    74,    43,    68,    43,    47,    66,    75,    62,     4, 
 670       73,    63,    69,    70,    49,    73,    43,    44,    14,    15, 
 671       16,    50,    71,    72,    70,    71,     4,    41 
 674 #if ! defined (YYSIZE_T) && defined (__SIZE_TYPE__) 
 675 # define YYSIZE_T __SIZE_TYPE__ 
 677 #if ! defined (YYSIZE_T) && defined (size_t) 
 678 # define YYSIZE_T size_t 
 680 #if ! defined (YYSIZE_T) 
 681 # if defined (__STDC__) || defined (__cplusplus) 
 682 #  include <stddef.h> /* INFRINGES ON USER NAME SPACE */ 
 683 #  define YYSIZE_T size_t 
 686 #if ! defined (YYSIZE_T) 
 687 # define YYSIZE_T unsigned int 
 690 #define yyerrok         (yyerrstatus = 0) 
 691 #define yyclearin       (yychar = YYEMPTY) 
 695 #define YYACCEPT        goto yyacceptlab 
 696 #define YYABORT         goto yyabortlab 
 697 #define YYERROR         goto yyerrorlab 
 700 /* Like YYERROR except do call yyerror.  This remains here temporarily 
 701    to ease the transition to the new meaning of YYERROR, for GCC. 
 702    Once GCC version 2 has supplanted version 1, this can go.  */ 
 704 #define YYFAIL          goto yyerrlab 
 706 #define YYRECOVERING()  (!!yyerrstatus) 
 708 #define YYBACKUP(Token, Value)                                  \ 
 710   if (yychar == YYEMPTY && yylen == 1)                          \ 
 714       yytoken = YYTRANSLATE (yychar);                           \ 
 720       yyerror ("syntax error: cannot back up");\ 
 726 #define YYERRCODE       256 
 728 /* YYLLOC_DEFAULT -- Compute the default location (before the actions 
 731 #ifndef YYLLOC_DEFAULT 
 732 # define YYLLOC_DEFAULT(Current, Rhs, N)                \ 
 733    ((Current).first_line   = (Rhs)[1].first_line,       \ 
 734     (Current).first_column = (Rhs)[1].first_column,     \ 
 735     (Current).last_line    = (Rhs)[N].last_line,        \ 
 736     (Current).last_column  = (Rhs)[N].last_column) 
 739 /* YYLEX -- calling `yylex' with the right arguments.  */ 
 742 # define YYLEX yylex (&yylval, &yylloc, YYLEX_PARAM) 
 744 # define YYLEX yylex (&yylval, &yylloc) 
 747 /* Enable debugging if requested.  */ 
 751 #  include <stdio.h> /* INFRINGES ON USER NAME SPACE */ 
 752 #  define YYFPRINTF fprintf 
 755 # define YYDPRINTF(Args)                        \ 
 761 # define YYDSYMPRINT(Args)                      \ 
 767 # define YYDSYMPRINTF(Title, Token, Value, Location)            \ 
 771       YYFPRINTF (stderr, "%s ", Title);                         \ 
 772       yysymprint (stderr,                                       \ 
 773                   Token, Value, Location);      \ 
 774       YYFPRINTF (stderr, "\n");                                 \ 
 778 /*------------------------------------------------------------------. 
 779 | yy_stack_print -- Print the state stack from its BOTTOM up to its | 
 781 `------------------------------------------------------------------*/ 
 783 #if defined (__STDC__) || defined (__cplusplus) 
 785 yy_stack_print (short int *bottom
, short int *top
) 
 788 yy_stack_print (bottom
, top
) 
 793   YYFPRINTF (stderr
, "Stack now"); 
 794   for (/* Nothing. */; bottom 
<= top
; ++bottom
) 
 795     YYFPRINTF (stderr
, " %d", *bottom
); 
 796   YYFPRINTF (stderr
, "\n"); 
 799 # define YY_STACK_PRINT(Bottom, Top)                            \ 
 802     yy_stack_print ((Bottom), (Top));                           \ 
 806 /*------------------------------------------------. 
 807 | Report that the YYRULE is going to be reduced.  | 
 808 `------------------------------------------------*/ 
 810 #if defined (__STDC__) || defined (__cplusplus) 
 812 yy_reduce_print (int yyrule
) 
 815 yy_reduce_print (yyrule
) 
 820   unsigned int yylno 
= yyrline
[yyrule
]; 
 821   YYFPRINTF (stderr
, "Reducing stack by rule %d (line %u), ", 
 823   /* Print the symbols being reduced, and their result.  */ 
 824   for (yyi 
= yyprhs
[yyrule
]; 0 <= yyrhs
[yyi
]; yyi
++) 
 825     YYFPRINTF (stderr
, "%s ", yytname 
[yyrhs
[yyi
]]); 
 826   YYFPRINTF (stderr
, "-> %s\n", yytname 
[yyr1
[yyrule
]]); 
 829 # define YY_REDUCE_PRINT(Rule)          \ 
 832     yy_reduce_print (Rule);             \ 
 835 /* Nonzero means print parse trace.  It is left uninitialized so that 
 836    multiple parsers can coexist.  */ 
 839 # define YYDPRINTF(Args) 
 840 # define YYDSYMPRINT(Args) 
 841 # define YYDSYMPRINTF(Title, Token, Value, Location) 
 842 # define YY_STACK_PRINT(Bottom, Top) 
 843 # define YY_REDUCE_PRINT(Rule) 
 844 #endif /* !YYDEBUG */ 
 847 /* YYINITDEPTH -- initial size of the parser's stacks.  */ 
 849 # define YYINITDEPTH 200 
 852 /* YYMAXDEPTH -- maximum size the stacks can grow to (effective only 
 853    if the built-in stack extension method is used). 
 855    Do not make this value too large; the results are undefined if 
 856    SIZE_MAX < YYSTACK_BYTES (YYMAXDEPTH) 
 857    evaluated with infinite-precision integer arithmetic.  */ 
 859 #if defined (YYMAXDEPTH) && YYMAXDEPTH == 0 
 864 # define YYMAXDEPTH 10000 
 872 #  if defined (__GLIBC__) && defined (_STRING_H) 
 873 #   define yystrlen strlen 
 875 /* Return the length of YYSTR.  */ 
 877 #   if defined (__STDC__) || defined (__cplusplus) 
 878 yystrlen (const char *yystr
) 
 884   register const char *yys 
= yystr
; 
 886   while (*yys
++ != '\0') 
 889   return yys 
- yystr 
- 1; 
 895 #  if defined (__GLIBC__) && defined (_STRING_H) && defined (_GNU_SOURCE) 
 896 #   define yystpcpy stpcpy 
 898 /* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in 
 901 #   if defined (__STDC__) || defined (__cplusplus) 
 902 yystpcpy (char *yydest
, const char *yysrc
) 
 904 yystpcpy (yydest
, yysrc
) 
 909   register char *yyd 
= yydest
; 
 910   register const char *yys 
= yysrc
; 
 912   while ((*yyd
++ = *yys
++) != '\0') 
 920 #endif /* !YYERROR_VERBOSE */ 
 925 /*--------------------------------. 
 926 | Print this symbol on YYOUTPUT.  | 
 927 `--------------------------------*/ 
 929 #if defined (__STDC__) || defined (__cplusplus) 
 931 yysymprint (FILE *yyoutput
, int yytype
, YYSTYPE 
*yyvaluep
, YYLTYPE 
*yylocationp
) 
 934 yysymprint (yyoutput
, yytype
, yyvaluep
, yylocationp
) 
 938     YYLTYPE 
*yylocationp
; 
 941   /* Pacify ``unused variable'' warnings.  */ 
 945   if (yytype 
< YYNTOKENS
) 
 947       YYFPRINTF (yyoutput
, "token %s (", yytname
[yytype
]); 
 949       YYPRINT (yyoutput
, yytoknum
[yytype
], *yyvaluep
); 
 953     YYFPRINTF (yyoutput
, "nterm %s (", yytname
[yytype
]); 
 960   YYFPRINTF (yyoutput
, ")"); 
 963 #endif /* ! YYDEBUG */ 
 964 /*-----------------------------------------------. 
 965 | Release the memory associated to this symbol.  | 
 966 `-----------------------------------------------*/ 
 968 #if defined (__STDC__) || defined (__cplusplus) 
 970 yydestruct (int yytype
, YYSTYPE 
*yyvaluep
, YYLTYPE 
*yylocationp
) 
 973 yydestruct (yytype
, yyvaluep
, yylocationp
) 
 976     YYLTYPE 
*yylocationp
; 
 979   /* Pacify ``unused variable'' warnings.  */ 
 992 /* Prevent warnings from -Wmissing-prototypes.  */ 
 995 # if defined (__STDC__) || defined (__cplusplus) 
 996 int yyparse (void *YYPARSE_PARAM
); 
1000 #else /* ! YYPARSE_PARAM */ 
1001 #if defined (__STDC__) || defined (__cplusplus) 
1006 #endif /* ! YYPARSE_PARAM */ 
1017 #ifdef YYPARSE_PARAM 
1018 # if defined (__STDC__) || defined (__cplusplus) 
1019 int yyparse (void *YYPARSE_PARAM
) 
1021 int yyparse (YYPARSE_PARAM
) 
1022   void *YYPARSE_PARAM
; 
1024 #else /* ! YYPARSE_PARAM */ 
1025 #if defined (__STDC__) || defined (__cplusplus) 
1035   /* The lookahead symbol.  */ 
1038 /* The semantic value of the lookahead symbol.  */ 
1041 /* Number of syntax errors so far.  */ 
1043 /* Location data for the lookahead symbol.  */ 
1046   register int yystate
; 
1049   /* Number of tokens to shift before error messages enabled.  */ 
1051   /* Lookahead token as an internal (translated) token number.  */ 
1054   /* Three stacks and their tools: 
1055      `yyss': related to states, 
1056      `yyvs': related to semantic values, 
1057      `yyls': related to locations. 
1059      Refer to the stacks thru separate pointers, to allow yyoverflow 
1060      to reallocate them elsewhere.  */ 
1062   /* The state stack.  */ 
1063   short int yyssa
[YYINITDEPTH
]; 
1064   short int *yyss 
= yyssa
; 
1065   register short int *yyssp
; 
1067   /* The semantic value stack.  */ 
1068   YYSTYPE yyvsa
[YYINITDEPTH
]; 
1069   YYSTYPE 
*yyvs 
= yyvsa
; 
1070   register YYSTYPE 
*yyvsp
; 
1072   /* The location stack.  */ 
1073   YYLTYPE yylsa
[YYINITDEPTH
]; 
1074   YYLTYPE 
*yyls 
= yylsa
; 
1078 #define YYPOPSTACK   (yyvsp--, yyssp--, yylsp--) 
1080   YYSIZE_T yystacksize 
= YYINITDEPTH
; 
1082   /* The variables used to return semantic value and location from the 
1087   /* When reducing, the number of symbols on the RHS of the reduced 
1091   YYDPRINTF ((stderr
, "Starting parse\n")); 
1096   yychar 
= YYEMPTY
;             /* Cause a token to be read.  */ 
1098   /* Initialize stack pointers. 
1099      Waste one element of value and location stack 
1100      so that they stay on the same level as the state stack. 
1101      The wasted elements are never initialized.  */ 
1107   /* User initialization code. */ 
1108   #line 68 "parse-gram.y" 
1110   /* Bison's grammar can initial empty locations, hence a default 
1111      location is needed. */ 
1112   (*yylsp
).start
.file   
= (*yylsp
).end
.file   
= current_file
; 
1113   (*yylsp
).start
.line   
= (*yylsp
).end
.line   
= 1; 
1114   (*yylsp
).start
.column 
= (*yylsp
).end
.column 
= 0; 
1116 /* Line 818 of yacc.c.  */ 
1117 #line 1118 "parse-gram.c" 
1120 /*------------------------------------------------------------. 
1121 | yynewstate -- Push a new state, which is found in yystate.  | 
1122 `------------------------------------------------------------*/ 
1124   /* In all cases, when you get here, the value and location stacks 
1125      have just been pushed. so pushing a state here evens the stacks. 
1132   if (yyss 
+ yystacksize 
- 1 <= yyssp
) 
1134       /* Get the current used size of the three stacks, in elements.  */ 
1135       YYSIZE_T yysize 
= yyssp 
- yyss 
+ 1; 
1139         /* Give user a chance to reallocate the stack. Use copies of 
1140            these so that the &'s don't force the real ones into 
1142         YYSTYPE 
*yyvs1 
= yyvs
; 
1143         short int *yyss1 
= yyss
; 
1144         YYLTYPE 
*yyls1 
= yyls
; 
1146         /* Each stack pointer address is followed by the size of the 
1147            data in use in that stack, in bytes.  This used to be a 
1148            conditional around just the two extra args, but that might 
1149            be undefined if yyoverflow is a macro.  */ 
1150         yyoverflow ("parser stack overflow", 
1151                     &yyss1
, yysize 
* sizeof (*yyssp
), 
1152                     &yyvs1
, yysize 
* sizeof (*yyvsp
), 
1153                     &yyls1
, yysize 
* sizeof (*yylsp
), 
1159 #else /* no yyoverflow */ 
1160 # ifndef YYSTACK_RELOCATE 
1163       /* Extend the stack our own way.  */ 
1164       if (YYMAXDEPTH 
<= yystacksize
) 
1167       if (YYMAXDEPTH 
< yystacksize
) 
1168         yystacksize 
= YYMAXDEPTH
; 
1171         short int *yyss1 
= yyss
; 
1172         union yyalloc 
*yyptr 
= 
1173           (union yyalloc 
*) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize
)); 
1176         YYSTACK_RELOCATE (yyss
); 
1177         YYSTACK_RELOCATE (yyvs
); 
1178         YYSTACK_RELOCATE (yyls
); 
1179 #  undef YYSTACK_RELOCATE 
1181           YYSTACK_FREE (yyss1
); 
1184 #endif /* no yyoverflow */ 
1186       yyssp 
= yyss 
+ yysize 
- 1; 
1187       yyvsp 
= yyvs 
+ yysize 
- 1; 
1188       yylsp 
= yyls 
+ yysize 
- 1; 
1190       YYDPRINTF ((stderr
, "Stack size increased to %lu\n", 
1191                   (unsigned long int) yystacksize
)); 
1193       if (yyss 
+ yystacksize 
- 1 <= yyssp
) 
1197   YYDPRINTF ((stderr
, "Entering state %d\n", yystate
)); 
1206 /* Do appropriate processing given the current state.  */ 
1207 /* Read a lookahead token if we need one and don't already have one.  */ 
1210   /* First try to decide what to do without reference to lookahead token.  */ 
1212   yyn 
= yypact
[yystate
]; 
1213   if (yyn 
== YYPACT_NINF
) 
1216   /* Not known => get a lookahead token if don't already have one.  */ 
1218   /* YYCHAR is either YYEMPTY or YYEOF or a valid lookahead symbol.  */ 
1219   if (yychar 
== YYEMPTY
) 
1221       YYDPRINTF ((stderr
, "Reading a token: ")); 
1225   if (yychar 
<= YYEOF
) 
1227       yychar 
= yytoken 
= YYEOF
; 
1228       YYDPRINTF ((stderr
, "Now at end of input.\n")); 
1232       yytoken 
= YYTRANSLATE (yychar
); 
1233       YYDSYMPRINTF ("Next token is", yytoken
, &yylval
, &yylloc
); 
1236   /* If the proper action on seeing token YYTOKEN is to reduce or to 
1237      detect an error, take that action.  */ 
1239   if (yyn 
< 0 || YYLAST 
< yyn 
|| yycheck
[yyn
] != yytoken
) 
1244       if (yyn 
== 0 || yyn 
== YYTABLE_NINF
) 
1253   /* Shift the lookahead token.  */ 
1254   YYDPRINTF ((stderr
, "Shifting token %s, ", yytname
[yytoken
])); 
1256   /* Discard the token being shifted unless it is eof.  */ 
1257   if (yychar 
!= YYEOF
) 
1263   /* Count tokens shifted since error; after three, turn off error 
1272 /*-----------------------------------------------------------. 
1273 | yydefault -- do the default action for the current state.  | 
1274 `-----------------------------------------------------------*/ 
1276   yyn 
= yydefact
[yystate
]; 
1282 /*-----------------------------. 
1283 | yyreduce -- Do a reduction.  | 
1284 `-----------------------------*/ 
1286   /* yyn is the number of a rule to reduce with.  */ 
1289   /* If YYLEN is nonzero, implement the default value of the action: 
1292      Otherwise, the following line sets YYVAL to garbage. 
1293      This behavior is undocumented and Bison 
1294      users should not rely upon it.  Assigning to YYVAL 
1295      unconditionally makes the parser a bit smaller, and it avoids a 
1296      GCC warning that YYVAL may be used uninitialized.  */ 
1297   yyval 
= yyvsp
[1-yylen
]; 
1299   /* Default location. */ 
1300   YYLLOC_DEFAULT (yyloc
, yylsp 
- yylen
, yylen
); 
1301   YY_REDUCE_PRINT (yyn
); 
1305 #line 186 "parse-gram.y" 
1306     { prologue_augment (yyvsp
[0].chars
, yylsp
[0]); } 
1310 #line 187 "parse-gram.y" 
1311     { debug_flag 
= true; } 
1315 #line 188 "parse-gram.y" 
1316     { muscle_insert (yyvsp
[-1].chars
, yyvsp
[0].chars
); } 
1320 #line 189 "parse-gram.y" 
1321     { defines_flag 
= true; } 
1325 #line 190 "parse-gram.y" 
1326     { error_verbose 
= true; } 
1330 #line 191 "parse-gram.y" 
1331     { expected_sr_conflicts 
= yyvsp
[0].integer
; } 
1335 #line 192 "parse-gram.y" 
1336     { expected_rr_conflicts 
= yyvsp
[0].integer
; } 
1340 #line 193 "parse-gram.y" 
1341     { spec_file_prefix 
= yyvsp
[0].chars
; } 
1345 #line 195 "parse-gram.y" 
1347     nondeterministic_parser 
= true; 
1353 #line 200 "parse-gram.y" 
1355     muscle_code_grow ("initial_action", yyvsp
[0].chars
, yylsp
[0]); 
1360 #line 203 "parse-gram.y" 
1361     { add_param ("lex_param", yyvsp
[0].chars
, yylsp
[0]); } 
1365 #line 204 "parse-gram.y" 
1366     { locations_flag 
= true; } 
1370 #line 205 "parse-gram.y" 
1371     { spec_name_prefix 
= yyvsp
[0].chars
; } 
1375 #line 206 "parse-gram.y" 
1376     { no_lines_flag 
= true; } 
1380 #line 207 "parse-gram.y" 
1381     { nondeterministic_parser 
= true; } 
1385 #line 208 "parse-gram.y" 
1386     { spec_outfile 
= yyvsp
[0].chars
; } 
1390 #line 209 "parse-gram.y" 
1391     { add_param ("parse_param", yyvsp
[0].chars
, yylsp
[0]); } 
1395 #line 210 "parse-gram.y" 
1396     { pure_parser 
= true; } 
1400 #line 211 "parse-gram.y" 
1401     { skeleton 
= yyvsp
[0].chars
; } 
1405 #line 212 "parse-gram.y" 
1406     { token_table_flag 
= true; } 
1410 #line 213 "parse-gram.y" 
1411     { report_flag 
= report_states
; } 
1415 #line 214 "parse-gram.y" 
1416     { yacc_flag 
= true; } 
1420 #line 222 "parse-gram.y" 
1422       grammar_start_symbol_set (yyvsp
[0].symbol
, yylsp
[0]); 
1427 #line 226 "parse-gram.y" 
1430       MUSCLE_INSERT_INT ("stype_line", yylsp
[0].start
.line
); 
1431       muscle_insert ("stype", yyvsp
[0].chars
); 
1436 #line 232 "parse-gram.y" 
1439       for (list 
= yyvsp
[0].list
; list
; list 
= list
->next
) 
1440         symbol_destructor_set (list
->sym
, yyvsp
[-1].chars
, yylsp
[-1]); 
1441       symbol_list_free (yyvsp
[0].list
); 
1446 #line 239 "parse-gram.y" 
1449       for (list 
= yyvsp
[0].list
; list
; list 
= list
->next
) 
1450         symbol_printer_set (list
->sym
, yyvsp
[-1].chars
, list
->location
); 
1451       symbol_list_free (yyvsp
[0].list
); 
1456 #line 246 "parse-gram.y" 
1458       default_prec 
= true; 
1463 #line 250 "parse-gram.y" 
1465       default_prec 
= false; 
1470 #line 256 "parse-gram.y" 
1471     { current_class 
= nterm_sym
; } 
1475 #line 257 "parse-gram.y" 
1477       current_class 
= unknown_sym
; 
1478       current_type 
= NULL
; 
1483 #line 261 "parse-gram.y" 
1484     { current_class 
= token_sym
; } 
1488 #line 262 "parse-gram.y" 
1490       current_class 
= unknown_sym
; 
1491       current_type 
= NULL
; 
1496 #line 267 "parse-gram.y" 
1499       for (list 
= yyvsp
[0].list
; list
; list 
= list
->next
) 
1500         symbol_type_set (list
->sym
, yyvsp
[-1].uniqstr
, yylsp
[-1]); 
1501       symbol_list_free (yyvsp
[0].list
); 
1506 #line 277 "parse-gram.y" 
1510       for (list 
= yyvsp
[0].list
; list
; list 
= list
->next
) 
1512           symbol_type_set (list
->sym
, current_type
, yylsp
[-1]); 
1513           symbol_precedence_set (list
->sym
, current_prec
, yyvsp
[-2].assoc
, yylsp
[-2]); 
1515       symbol_list_free (yyvsp
[0].list
); 
1516       current_type 
= NULL
; 
1521 #line 291 "parse-gram.y" 
1522     { yyval
.assoc 
= left_assoc
; } 
1526 #line 292 "parse-gram.y" 
1527     { yyval
.assoc 
= right_assoc
; } 
1531 #line 293 "parse-gram.y" 
1532     { yyval
.assoc 
= non_assoc
; } 
1536 #line 297 "parse-gram.y" 
1537     { current_type 
= NULL
; } 
1541 #line 298 "parse-gram.y" 
1542     { current_type 
= yyvsp
[0].uniqstr
; } 
1546 #line 304 "parse-gram.y" 
1547     { yyval
.list 
= symbol_list_new (yyvsp
[0].symbol
, yylsp
[0]); } 
1551 #line 305 "parse-gram.y" 
1552     { yyval
.list 
= symbol_list_prepend (yyvsp
[-1].list
, yyvsp
[0].symbol
, yylsp
[0]); } 
1556 #line 311 "parse-gram.y" 
1558        current_type 
= yyvsp
[0].uniqstr
; 
1563 #line 315 "parse-gram.y" 
1565        symbol_class_set (yyvsp
[0].symbol
, current_class
, yylsp
[0]); 
1566        symbol_type_set (yyvsp
[0].symbol
, current_type
, yylsp
[0]); 
1571 #line 320 "parse-gram.y" 
1573       symbol_class_set (yyvsp
[-1].symbol
, current_class
, yylsp
[-1]); 
1574       symbol_type_set (yyvsp
[-1].symbol
, current_type
, yylsp
[-1]); 
1575       symbol_user_token_number_set (yyvsp
[-1].symbol
, yyvsp
[0].integer
, yylsp
[0]); 
1580 #line 326 "parse-gram.y" 
1582       symbol_class_set (yyvsp
[-1].symbol
, current_class
, yylsp
[-1]); 
1583       symbol_type_set (yyvsp
[-1].symbol
, current_type
, yylsp
[-1]); 
1584       symbol_make_alias (yyvsp
[-1].symbol
, yyvsp
[0].symbol
, yyloc
); 
1589 #line 332 "parse-gram.y" 
1591       symbol_class_set (yyvsp
[-2].symbol
, current_class
, yylsp
[-2]); 
1592       symbol_type_set (yyvsp
[-2].symbol
, current_type
, yylsp
[-2]); 
1593       symbol_user_token_number_set (yyvsp
[-2].symbol
, yyvsp
[-1].integer
, yylsp
[-1]); 
1594       symbol_make_alias (yyvsp
[-2].symbol
, yyvsp
[0].symbol
, yyloc
); 
1599 #line 361 "parse-gram.y" 
1602         complain_at (yyloc
, _("POSIX forbids declarations in the grammar")); 
1607 #line 366 "parse-gram.y" 
1614 #line 372 "parse-gram.y" 
1615     { current_lhs 
= yyvsp
[0].symbol
; current_lhs_location 
= yylsp
[0]; } 
1619 #line 376 "parse-gram.y" 
1620     { grammar_rule_end (yylsp
[0]); } 
1624 #line 377 "parse-gram.y" 
1625     { grammar_rule_end (yylsp
[0]); } 
1629 #line 383 "parse-gram.y" 
1630     { grammar_rule_begin (current_lhs
, current_lhs_location
); } 
1634 #line 385 "parse-gram.y" 
1635     { grammar_current_rule_symbol_append (yyvsp
[0].symbol
, yylsp
[0]); } 
1639 #line 387 "parse-gram.y" 
1640     { grammar_current_rule_action_append (yyvsp
[0].chars
, yylsp
[0]); } 
1644 #line 389 "parse-gram.y" 
1645     { grammar_current_rule_prec_set (yyvsp
[0].symbol
, yylsp
[0]); } 
1649 #line 391 "parse-gram.y" 
1650     { grammar_current_rule_dprec_set (yyvsp
[0].integer
, yylsp
[0]); } 
1654 #line 393 "parse-gram.y" 
1655     { grammar_current_rule_merge_set (yyvsp
[0].uniqstr
, yylsp
[0]); } 
1659 #line 397 "parse-gram.y" 
1660     { yyval
.symbol 
= yyvsp
[0].symbol
; } 
1664 #line 398 "parse-gram.y" 
1665     { yyval
.symbol 
= yyvsp
[0].symbol
; } 
1669 #line 403 "parse-gram.y" 
1670     { yyval
.chars 
= yyvsp
[0].chars
; } 
1674 #line 409 "parse-gram.y" 
1676       yyval
.symbol 
= symbol_get (yyvsp
[0].chars
, yylsp
[0]); 
1677       symbol_class_set (yyval
.symbol
, token_sym
, yylsp
[0]); 
1682 #line 418 "parse-gram.y" 
1684       yyval
.chars 
= yyvsp
[0].chars 
+ 1; 
1685       yyval
.chars
[strlen (yyval
.chars
) - 1] = '\0'; 
1690 #line 427 "parse-gram.y" 
1692       muscle_code_grow ("epilogue", yyvsp
[0].chars
, yylsp
[0]); 
1693       scanner_last_string_free (); 
1700 /* Line 1010 of yacc.c.  */ 
1701 #line 1702 "parse-gram.c" 
1707   YY_STACK_PRINT (yyss
, yyssp
); 
1712   /* Now `shift' the result of the reduction.  Determine what state 
1713      that goes to, based on the state we popped back to and the rule 
1714      number reduced by.  */ 
1718   yystate 
= yypgoto
[yyn 
- YYNTOKENS
] + *yyssp
; 
1719   if (0 <= yystate 
&& yystate 
<= YYLAST 
&& yycheck
[yystate
] == *yyssp
) 
1720     yystate 
= yytable
[yystate
]; 
1722     yystate 
= yydefgoto
[yyn 
- YYNTOKENS
]; 
1727 /*------------------------------------. 
1728 | yyerrlab -- here on detecting error | 
1729 `------------------------------------*/ 
1731   /* If not already recovering from an error, report this error.  */ 
1736       yyn 
= yypact
[yystate
]; 
1738       if (YYPACT_NINF 
< yyn 
&& yyn 
< YYLAST
) 
1740           YYSIZE_T yysize 
= 0; 
1741           int yytype 
= YYTRANSLATE (yychar
); 
1742           const char* yyprefix
; 
1746           /* Start YYX at -YYN if negative to avoid negative indexes in 
1748           int yyxbegin 
= yyn 
< 0 ? -yyn 
: 0; 
1750           /* Stay within bounds of both yycheck and yytname.  */ 
1751           int yychecklim 
= YYLAST 
- yyn
; 
1752           int yyxend 
= yychecklim 
< YYNTOKENS 
? yychecklim 
: YYNTOKENS
; 
1755           yyprefix 
= ", expecting "; 
1756           for (yyx 
= yyxbegin
; yyx 
< yyxend
; ++yyx
) 
1757             if (yycheck
[yyx 
+ yyn
] == yyx 
&& yyx 
!= YYTERROR
) 
1759                 yysize 
+= yystrlen (yyprefix
) + yystrlen (yytname 
[yyx
]); 
1767           yysize 
+= (sizeof ("syntax error, unexpected ") 
1768                      + yystrlen (yytname
[yytype
])); 
1769           yymsg 
= (char *) YYSTACK_ALLOC (yysize
); 
1772               char *yyp 
= yystpcpy (yymsg
, "syntax error, unexpected "); 
1773               yyp 
= yystpcpy (yyp
, yytname
[yytype
]); 
1777                   yyprefix 
= ", expecting "; 
1778                   for (yyx 
= yyxbegin
; yyx 
< yyxend
; ++yyx
) 
1779                     if (yycheck
[yyx 
+ yyn
] == yyx 
&& yyx 
!= YYTERROR
) 
1781                         yyp 
= yystpcpy (yyp
, yyprefix
); 
1782                         yyp 
= yystpcpy (yyp
, yytname
[yyx
]); 
1787               YYSTACK_FREE (yymsg
); 
1790             yyerror ("syntax error; also virtual memory exhausted"); 
1793 #endif /* YYERROR_VERBOSE */ 
1794         yyerror ("syntax error"); 
1799   if (yyerrstatus 
== 3) 
1801       /* If just tried and failed to reuse lookahead token after an 
1802          error, discard it.  */ 
1804       if (yychar 
<= YYEOF
) 
1806           /* If at end of input, pop the error token, 
1807              then the rest of the stack, then return failure.  */ 
1808           if (yychar 
== YYEOF
) 
1814                  YYDSYMPRINTF ("Error: popping", yystos
[*yyssp
], yyvsp
, yylsp
); 
1815                  yydestruct (yystos
[*yyssp
], yyvsp
, yylsp
); 
1820           YYDSYMPRINTF ("Error: discarding", yytoken
, &yylval
, &yylloc
); 
1821           yydestruct (yytoken
, &yylval
, &yylloc
); 
1823           *++yylerrsp 
= yylloc
; 
1827   /* Else will try to reuse lookahead token after shifting the error 
1832 /*---------------------------------------------------. 
1833 | yyerrorlab -- error raised explicitly by YYERROR.  | 
1834 `---------------------------------------------------*/ 
1838   /* Pacify GCC when the user code never invokes YYERROR and the label 
1839      yyerrorlab therefore never appears in user code.  */ 
1848   *++yylerrsp 
= yyloc
; 
1853 /*-------------------------------------------------------------. 
1854 | yyerrlab1 -- common code for both syntax error and YYERROR.  | 
1855 `-------------------------------------------------------------*/ 
1857   yyerrstatus 
= 3;      /* Each real token shifted decrements this.  */ 
1861       yyn 
= yypact
[yystate
]; 
1862       if (yyn 
!= YYPACT_NINF
) 
1865           if (0 <= yyn 
&& yyn 
<= YYLAST 
&& yycheck
[yyn
] == YYTERROR
) 
1873       /* Pop the current state because it cannot handle the error token.  */ 
1877       YYDSYMPRINTF ("Error: popping", yystos
[*yyssp
], yyvsp
, yylsp
); 
1878       yydestruct (yystos
[yystate
], yyvsp
, yylsp
); 
1881       YY_STACK_PRINT (yyss
, yyssp
); 
1887   YYDPRINTF ((stderr
, "Shifting error token, ")); 
1890   YYLLOC_DEFAULT (yyloc
, yylsp
, yylerrsp 
- yylsp
); 
1897 /*-------------------------------------. 
1898 | yyacceptlab -- YYACCEPT comes here.  | 
1899 `-------------------------------------*/ 
1904 /*-----------------------------------. 
1905 | yyabortlab -- YYABORT comes here.  | 
1906 `-----------------------------------*/ 
1912 /*----------------------------------------------. 
1913 | yyoverflowlab -- parser overflow comes here.  | 
1914 `----------------------------------------------*/ 
1916   yyerror ("parser stack overflow"); 
1924     YYSTACK_FREE (yyss
); 
1930 #line 433 "parse-gram.y" 
1934 /* Return the location of the left-hand side of a rule whose 
1935    right-hand side is RHS[1] ... RHS[N].  Ignore empty nonterminals in 
1936    the right-hand side, and return an empty location equal to the end 
1937    boundary of RHS[0] if the right-hand side is empty.  */ 
1940 lloc_default (YYLTYPE 
const *rhs
, int n
) 
1944   loc
.start 
= loc
.end 
= rhs
[n
].end
; 
1946   /* Ignore empty nonterminals the start of the the right-hand side. 
1947      Do not bother to ignore them at the end of the right-hand side, 
1948      since empty nonterminals have the same end as their predecessors.  */ 
1949   for (i 
= 1; i 
<= n
; i
++) 
1950     if (! equal_boundaries (rhs
[i
].start
, rhs
[i
].end
)) 
1952         loc
.start 
= rhs
[i
].start
; 
1960 /* Add a lex-param or a parse-param (depending on TYPE) with 
1961    declaration DECL and location LOC.  */ 
1964 add_param (char const *type
, char *decl
, location loc
) 
1966   static char const alphanum
[] = 
1968     "abcdefghijklmnopqrstuvwxyz" 
1969     "ABCDEFGHIJKLMNOPQRSTUVWXYZ" 
1971   char const *alpha 
= alphanum 
+ 10; 
1972   char const *name_start 
= NULL
; 
1975   for (p 
= decl
; *p
; p
++) 
1976     if ((p 
== decl 
|| ! strchr (alphanum
, p
[-1])) && strchr (alpha
, p
[0])) 
1979   /* Strip the surrounding '{' and '}'.  */ 
1984     complain_at (loc
, _("missing identifier in parameter declaration")); 
1991            name_start
[name_len
] && strchr (alphanum
, name_start
[name_len
]); 
1995       name 
= xmalloc (name_len 
+ 1); 
1996       memcpy (name
, name_start
, name_len
); 
1997       name
[name_len
] = '\0'; 
1998       muscle_pair_list_grow (type
, decl
, name
); 
2002   scanner_last_string_free (); 
2005 /*----------------------------------------------------. 
2006 | When debugging the parser, display tokens' values.  | 
2007 `----------------------------------------------------*/ 
2010 print_token_value (FILE *file
, int type
, YYSTYPE 
const *value
) 
2016       fprintf (file
, " = %s", value
->symbol
->tag
); 
2020       fprintf (file
, " = %d", value
->integer
); 
2024       fprintf (file
, " = \"%s\"", value
->chars
); 
2028       fprintf (file
, " = <%s>", value
->uniqstr
); 
2032     case PERCENT_DESTRUCTOR
: 
2033     case PERCENT_LEX_PARAM
: 
2034     case PERCENT_PARSE_PARAM
: 
2035     case PERCENT_PRINTER
: 
2039       fprintf (file
, " = {{ %s }}", value
->chars
); 
2043       fprintf (file
, "unknown token type"); 
2049 gram_error (location 
const *loc
, char const *msg
) 
2051   complain_at (*loc
, "%s", msg
); 
2055 token_name (int type
) 
2057   return yytname
[type
];