]> git.saurik.com Git - bison.git/blame - data/yacc.c
(YYRHSLOC): New macro, taken from glr.c.
[bison.git] / data / yacc.c
CommitLineData
007a50a4 1m4_divert(-1) -*- C -*-
a8289c62 2
60491a94 3# Yacc compatible skeleton for Bison
779e7ceb 4# Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004
12b0043a 5# Free Software Foundation, Inc.
60491a94
AD
6
7# This program is free software; you can redistribute it and/or modify
8# it under the terms of the GNU General Public License as published by
9# the Free Software Foundation; either version 2 of the License, or
10# (at your option) any later version.
11
12# This program is distributed in the hope that it will be useful,
13# but WITHOUT ANY WARRANTY; without even the implied warranty of
14# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15# GNU General Public License for more details.
16
17# You should have received a copy of the GNU General Public License
18# along with this program; if not, write to the Free Software
19# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
20# 02111-1307 USA
21
66d30cd4
AD
22
23
24## ---------------- ##
25## Default values. ##
26## ---------------- ##
27
28# Stack parameters.
29m4_define_default([b4_stack_depth_max], [10000])
30m4_define_default([b4_stack_depth_init], [200])
31
2a8d363a
AD
32
33## ------------------------ ##
34## Pure/impure interfaces. ##
35## ------------------------ ##
36
37
947427ae 38# b4_pure_if(IF-TRUE, IF-FALSE)
2a8d363a
AD
39# -----------------------------
40# Expand IF-TRUE, if %pure-parser and %parse-param, IF-FALSE otherwise.
41m4_define([b4_Pure_if],
42[b4_pure_if([m4_ifset([b4_parse_param],
43 [$1], [$2])],
44 [$2])])
45
46
93724f13
AD
47# b4_yyerror_args
48# ---------------
2a8d363a 49# Arguments passed to yyerror: user args plus yylloc.
93724f13
AD
50m4_define([b4_yyerror_args],
51[b4_Pure_if([b4_location_if([&yylloc, ])])dnl
52m4_ifset([b4_parse_param], [b4_c_args(b4_parse_param), ])])
2a8d363a
AD
53
54
55# b4_lex_param
56# ------------
d42f69cd 57# Accumulate in b4_lex_param all the yylex arguments.
2a8d363a 58# b4_lex_param arrives quoted twice, but we want to keep only one level.
21964f43
AD
59m4_define([b4_lex_param],
60m4_dquote(b4_pure_if([[[[YYSTYPE *]], [[&yylval]]][]dnl
68cdf747
PE
61b4_location_if([, [[YYLTYPE *], [&yylloc]]])m4_ifdef([b4_lex_param], [, ])])dnl
62m4_ifdef([b4_lex_param], b4_lex_param)))
66d30cd4
AD
63
64
f1886bb2
AD
65
66## ------------ ##
67## Data Types. ##
68## ------------ ##
69
70# b4_int_type(MIN, MAX)
71# ---------------------
72# Return the smallest int type able to handle numbers ranging from
73# MIN to MAX (included). We overwrite the version from c.m4 which relies
2a8d363a 74# on "signed char" which is not portable to old K&R compilers.
f1886bb2
AD
75m4_define([b4_int_type],
76[m4_if(b4_ints_in($@, [0], [255]), [1], [unsigned char],
77 b4_ints_in($@, [-128], [127]), [1], [yysigned_char],
78
779e7ceb
PE
79 b4_ints_in($@, [0], [65535]), [1], [unsigned short int],
80 b4_ints_in($@, [-32768], [32767]), [1], [short int],
f1886bb2
AD
81
82 m4_eval([0 <= $1]), [1], [unsigned int],
83
84 [int])])
85
86
66d30cd4
AD
87## ----------------- ##
88## Semantic Values. ##
89## ----------------- ##
90
91
82b6cb3f
AD
92# b4_lhs_value([TYPE])
93# --------------------
94# Expansion of $<TYPE>$.
95m4_define([b4_lhs_value],
96[yyval[]m4_ifval([$1], [.$1])])
97
98
99# b4_rhs_value(RULE-LENGTH, NUM, [TYPE])
100# --------------------------------------
101# Expansion of $<TYPE>NUM, where the current rule has RULE-LENGTH
102# symbols on RHS.
103m4_define([b4_rhs_value],
947427ae 104[yyvsp@{m4_eval([$2 - $1])@}m4_ifval([$3], [.$3])])
82b6cb3f
AD
105
106
58612f1d
AD
107
108## ----------- ##
109## Locations. ##
110## ----------- ##
111
82b6cb3f
AD
112# b4_lhs_location()
113# -----------------
114# Expansion of @$.
115m4_define([b4_lhs_location],
116[yyloc])
117
118
119# b4_rhs_location(RULE-LENGTH, NUM)
120# ---------------------------------
121# Expansion of @NUM, where the current rule has RULE-LENGTH symbols
122# on RHS.
123m4_define([b4_rhs_location],
947427ae 124[yylsp@{m4_eval([$2 - $1])@}])
be2a1a68 125
0d8bed56 126
0d8bed56 127
1ae72863
AD
128## --------------------------------------------------------- ##
129## Defining symbol actions, e.g., printers and destructors. ##
130## --------------------------------------------------------- ##
131
b526ee61
AD
132# We do want M4 expansion after # for CPP macros.
133m4_changecom()
be2a1a68 134m4_divert(0)dnl
947427ae 135@output @output_parser_name@
fb8135fa 136b4_copyright([Skeleton parser for Yacc-like parsing with Bison],
779e7ceb 137 [1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004])[
fb8135fa 138
0252b55c
PE
139/* As a special exception, when this file is copied by Bison into a
140 Bison output file, you may use that output file without restriction.
141 This special exception was added by the Free Software Foundation
142 in version 1.24 of Bison. */
143
fb8135fa
AD
144/* Written by Richard Stallman by simplifying the original so called
145 ``semantic'' parser. */
444fbf65 146
cf44a9ae
PE
147/* All symbols defined below should begin with yy or YY, to avoid
148 infringing on user name space. This should be done even for local
149 variables, as they might otherwise be expanded by user macros.
150 There are some unavoidable exceptions within include files to
151 define necessary library symbols; they are noted "INFRINGES ON
152 USER NAME SPACE" below. */
153
9c1e26bd 154]b4_identification
be2a1a68
AD
155m4_if(b4_prefix[], [yy], [],
156[/* If NAME_PREFIX is specified substitute the variables and functions
17da6427 157 names. */
be2a1a68
AD
158#define yyparse b4_prefix[]parse
159#define yylex b4_prefix[]lex
160#define yyerror b4_prefix[]error
161#define yylval b4_prefix[]lval
162#define yychar b4_prefix[]char
163#define yydebug b4_prefix[]debug
164#define yynerrs b4_prefix[]nerrs
9c1e26bd 165b4_location_if([#define yylloc b4_prefix[]lloc])])[
17da6427 166
9c1e26bd 167]b4_token_defines(b4_tokens)[
17acead5 168
0dd1580a 169/* Copy the first part of user declarations. */
9c1e26bd 170]b4_pre_prologue[
cce71710 171
d99361e6
AD
172/* Enabling traces. */
173#ifndef YYDEBUG
9c1e26bd 174# define YYDEBUG ]b4_debug[
d99361e6
AD
175#endif
176
177/* Enabling verbose error messages. */
178#ifdef YYERROR_VERBOSE
179# undef YYERROR_VERBOSE
180# define YYERROR_VERBOSE 1
181#else
9c1e26bd 182# define YYERROR_VERBOSE ]b4_error_verbose[
d99361e6
AD
183#endif
184
050c471b 185#if ! defined (YYSTYPE) && ! defined (YYSTYPE_IS_DECLARED)
9c1e26bd 186]m4_ifdef([b4_stype],
437c2d80 187[b4_syncline([b4_stype_line], [b4_filename])
050c471b 188typedef union m4_bregexp(b4_stype, [^{], [YYSTYPE ])b4_stype YYSTYPE;
996b1c7e 189/* Line __line__ of yacc.c. */
947427ae 190b4_syncline([@oline@], [@ofile@])],
050c471b
PE
191[typedef int YYSTYPE;])[
192# define yystype YYSTYPE /* obsolescent; will be withdrawn */
193# define YYSTYPE_IS_DECLARED 1
71cd15d4 194# define YYSTYPE_IS_TRIVIAL 1
fd51e5ff
AD
195#endif
196
050c471b
PE
197]b4_location_if([#if ! defined (YYLTYPE) && ! defined (YYLTYPE_IS_DECLARED)
198typedef struct YYLTYPE
fd51e5ff
AD
199{
200 int first_line;
201 int first_column;
202 int last_line;
203 int last_column;
050c471b
PE
204} YYLTYPE;
205# define yyltype YYLTYPE /* obsolescent; will be withdrawn */
206# define YYLTYPE_IS_DECLARED 1
71cd15d4 207# define YYLTYPE_IS_TRIVIAL 1
fd51e5ff 208#endif
1915f133 209])[
fd51e5ff 210
0dd1580a 211/* Copy the second part of user declarations. */
ee41006f 212]b4_post_prologue
0dd1580a 213
996b1c7e 214/* Line __line__ of yacc.c. */
ee41006f 215b4_syncline([@oline@], [@ofile@])[
7093d0f5 216
cf44a9ae 217#if ! defined (yyoverflow) || YYERROR_VERBOSE
7093d0f5 218
2779e383
PE
219# ifndef YYFREE
220# define YYFREE free
221# endif
222# ifndef YYMALLOC
223# define YYMALLOC malloc
224# endif
225
7093d0f5
AD
226/* The parser invokes alloca or malloc; define the necessary symbols. */
227
b929851a
PE
228# ifdef YYSTACK_USE_ALLOCA
229# if YYSTACK_USE_ALLOCA
230# define YYSTACK_ALLOC alloca
231# endif
7093d0f5 232# else
b929851a
PE
233# if defined (alloca) || defined (_ALLOCA_H)
234# define YYSTACK_ALLOC alloca
235# else
236# ifdef __GNUC__
237# define YYSTACK_ALLOC __builtin_alloca
7093d0f5
AD
238# endif
239# endif
240# endif
241
242# ifdef YYSTACK_ALLOC
243 /* Pacify GCC's `empty if-body' warning. */
244# define YYSTACK_FREE(Ptr) do { /* empty */; } while (0)
245# else
45119af1
PE
246# if defined (__STDC__) || defined (__cplusplus)
247# include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
248# define YYSIZE_T size_t
7093d0f5 249# endif
2779e383
PE
250# define YYSTACK_ALLOC YYMALLOC
251# define YYSTACK_FREE YYFREE
7093d0f5 252# endif
cf44a9ae
PE
253#endif /* ! defined (yyoverflow) || YYERROR_VERBOSE */
254
255
256#if (! defined (yyoverflow) \
257 && (! defined (__cplusplus) \
d7aa6ec1
PE
258 || (]b4_location_if([[defined (YYLTYPE_IS_TRIVIAL) && YYLTYPE_IS_TRIVIAL \
259 && ]])[defined (YYSTYPE_IS_TRIVIAL) && YYSTYPE_IS_TRIVIAL)))
7093d0f5 260
600f9b0c
PE
261/* A type that is properly aligned for any stack member. */
262union yyalloc
263{
779e7ceb 264 short int yyss;
2729e106 265 YYSTYPE yyvs;
9c1e26bd 266 ]b4_location_if([ YYLTYPE yyls;
58612f1d 267])dnl
9c1e26bd 268[};
600f9b0c
PE
269
270/* The size of the maximum gap between one aligned stack and the next. */
17836590 271# define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1)
600f9b0c
PE
272
273/* The size of an array large to enough to hold all stacks, each with
274 N elements. */
9c1e26bd 275]b4_location_if(
58612f1d 276[# define YYSTACK_BYTES(N) \
779e7ceb 277 ((N) * (sizeof (short int) + sizeof (YYSTYPE) + sizeof (YYLTYPE)) \
17836590 278 + 2 * YYSTACK_GAP_MAXIMUM)],
58612f1d 279[# define YYSTACK_BYTES(N) \
779e7ceb 280 ((N) * (sizeof (short int) + sizeof (YYSTYPE)) \
17836590 281 + YYSTACK_GAP_MAXIMUM)])[
600f9b0c 282
5b041382
PE
283/* Copy COUNT objects from FROM to TO. The source and destination do
284 not overlap. */
285# ifndef YYCOPY
d7aa6ec1 286# if defined (__GNUC__) && 1 < __GNUC__
5b041382
PE
287# define YYCOPY(To, From, Count) \
288 __builtin_memcpy (To, From, (Count) * sizeof (*(From)))
289# else
290# define YYCOPY(To, From, Count) \
291 do \
292 { \
293 register YYSIZE_T yyi; \
294 for (yyi = 0; yyi < (Count); yyi++) \
9c1e26bd 295 (To)[yyi] = (From)[yyi]; \
5b041382
PE
296 } \
297 while (0)
298# endif
299# endif
300
301/* Relocate STACK from its old location to the new one. The
7093d0f5 302 local variables YYSIZE and YYSTACKSIZE give the old and new number of
600f9b0c
PE
303 elements in the stack, and YYPTR gives the new location of the
304 stack. Advance YYPTR to a properly aligned location for the next
305 stack. */
5b041382 306# define YYSTACK_RELOCATE(Stack) \
7093d0f5
AD
307 do \
308 { \
309 YYSIZE_T yynewbytes; \
5b041382 310 YYCOPY (&yyptr->Stack, Stack, yysize); \
2729e106 311 Stack = &yyptr->Stack; \
17836590 312 yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \
2729e106 313 yyptr += yynewbytes / sizeof (*yyptr); \
7093d0f5
AD
314 } \
315 while (0)
316
cf44a9ae 317#endif
8850be4b 318
768eb43f
PE
319#if defined (__STDC__) || defined (__cplusplus)
320 typedef signed char yysigned_char;
321#else
779e7ceb 322 typedef short int yysigned_char;
768eb43f
PE
323#endif
324
7742ddeb 325/* YYFINAL -- State number of the termination state. */
9c1e26bd 326#define YYFINAL ]b4_final_state_number[
39912f52 327/* YYLAST -- Last index in YYTABLE. */
9c1e26bd 328#define YYLAST ]b4_last[
7742ddeb
AD
329
330/* YYNTOKENS -- Number of terminals. */
9c1e26bd 331#define YYNTOKENS ]b4_tokens_number[
7742ddeb 332/* YYNNTS -- Number of nonterminals. */
9c1e26bd 333#define YYNNTS ]b4_nterms_number[
7742ddeb 334/* YYNRULES -- Number of rules. */
9c1e26bd 335#define YYNRULES ]b4_rules_number[
7742ddeb 336/* YYNRULES -- Number of states. */
9c1e26bd 337#define YYNSTATES ]b4_states_number[
7742ddeb
AD
338
339/* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
9c1e26bd
AD
340#define YYUNDEFTOK ]b4_undef_token_number[
341#define YYMAXUTOK ]b4_user_token_number_max[
007a50a4 342
b0400cc6 343#define YYTRANSLATE(YYX) \
a20713a4 344 ((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK)
a8289c62 345
b0400cc6
AD
346/* YYTRANSLATE[YYLEX] -- Bison symbol number corresponding to YYLEX. */
347static const ]b4_int_type_for([b4_translate])[ yytranslate[] =
a8289c62 348{
c5e3e510 349 ]b4_translate[
a8289c62
RA
350};
351
352#if YYDEBUG
c5e3e510 353/* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in
7742ddeb 354 YYRHS. */
c5e3e510 355static const ]b4_int_type_for([b4_prhs])[ yyprhs[] =
a8289c62 356{
c5e3e510 357 ]b4_prhs[
a8289c62
RA
358};
359
3db472b9 360/* YYRHS -- A `-1'-separated list of the rules' RHS. */
c5e3e510 361static const ]b4_int_type_for([b4_rhs])[ yyrhs[] =
a8289c62 362{
c5e3e510 363 ]b4_rhs[
a8289c62
RA
364};
365
c5e3e510
AD
366/* YYRLINE[YYN] -- source line where rule number YYN was defined. */
367static const ]b4_int_type_for([b4_rline])[ yyrline[] =
a8289c62 368{
c5e3e510 369 ]b4_rline[
a8289c62
RA
370};
371#endif
372
5504898e 373#if YYDEBUG || YYERROR_VERBOSE
c5e3e510 374/* YYTNME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM.
7742ddeb 375 First, the terminals, then, starting at YYNTOKENS, nonterminals. */
c5e3e510 376static const char *const yytname[] =
a8289c62 377{
c5e3e510 378 ]b4_tname[
a8289c62
RA
379};
380#endif
381
c0ad8bf3 382# ifdef YYPRINT
c5e3e510 383/* YYTOKNUM[YYLEX-NUM] -- Internal token number corresponding to
769b430f 384 token YYLEX-NUM. */
c5e3e510 385static const ]b4_int_type_for([b4_toknum])[ yytoknum[] =
a8289c62 386{
c5e3e510 387 ]b4_toknum[
a8289c62 388};
c0ad8bf3 389# endif
a8289c62 390
c5e3e510
AD
391/* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */
392static const ]b4_int_type_for([b4_r1])[ yyr1[] =
a8289c62 393{
c5e3e510 394 ]b4_r1[
a8289c62
RA
395};
396
c5e3e510
AD
397/* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
398static const ]b4_int_type_for([b4_r2])[ yyr2[] =
a8289c62 399{
c5e3e510 400 ]b4_r2[
a8289c62
RA
401};
402
c5e3e510 403/* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state
5504898e
AD
404 STATE-NUM when YYTABLE doesn't specify something else to do. Zero
405 means the default is an error. */
c5e3e510 406static const ]b4_int_type_for([b4_defact])[ yydefact[] =
a8289c62 407{
c5e3e510 408 ]b4_defact[
a8289c62
RA
409};
410
c5e3e510
AD
411/* YYDEFGOTO[NTERM-NUM]. */
412static const ]b4_int_type_for([b4_defgoto])[ yydefgoto[] =
a8289c62 413{
c5e3e510 414 ]b4_defgoto[
a8289c62
RA
415};
416
c5e3e510 417/* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
7742ddeb 418 STATE-NUM. */
c5e3e510
AD
419#define YYPACT_NINF ]b4_pact_ninf[
420static const ]b4_int_type_for([b4_pact])[ yypact[] =
a8289c62 421{
c5e3e510 422 ]b4_pact[
a8289c62
RA
423};
424
c5e3e510
AD
425/* YYPGOTO[NTERM-NUM]. */
426static const ]b4_int_type_for([b4_pgoto])[ yypgoto[] =
a8289c62 427{
c5e3e510 428 ]b4_pgoto[
a8289c62
RA
429};
430
c5e3e510 431/* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If
7742ddeb 432 positive, shift that token. If negative, reduce the rule which
f50adbbd 433 number is the opposite. If zero, do what YYDEFACT says.
6e649e65 434 If YYTABLE_NINF, syntax error. */
c5e3e510
AD
435#define YYTABLE_NINF ]b4_table_ninf[
436static const ]b4_int_type_for([b4_table])[ yytable[] =
a8289c62 437{
c5e3e510 438 ]b4_table[
a8289c62
RA
439};
440
c5e3e510 441static const ]b4_int_type_for([b4_check])[ yycheck[] =
a8289c62 442{
c5e3e510 443 ]b4_check[
a8289c62
RA
444};
445
c5e3e510 446/* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
5504898e 447 symbol of state STATE-NUM. */
c5e3e510 448static const ]b4_int_type_for([b4_stos])[ yystos[] =
5504898e 449{
c5e3e510 450 ]b4_stos[
5504898e 451};
7093d0f5
AD
452
453#if ! defined (YYSIZE_T) && defined (__SIZE_TYPE__)
454# define YYSIZE_T __SIZE_TYPE__
455#endif
456#if ! defined (YYSIZE_T) && defined (size_t)
457# define YYSIZE_T size_t
458#endif
b7575ffe 459#if ! defined (YYSIZE_T)
45119af1
PE
460# if defined (__STDC__) || defined (__cplusplus)
461# include <stddef.h> /* INFRINGES ON USER NAME SPACE */
462# define YYSIZE_T size_t
b7575ffe 463# endif
7093d0f5
AD
464#endif
465#if ! defined (YYSIZE_T)
466# define YYSIZE_T unsigned int
467#endif
468
10fa2066 469#define yyerrok (yyerrstatus = 0)
a20713a4
PE
470#define yyclearin (yychar = YYEMPTY)
471#define YYEMPTY (-2)
10fa2066 472#define YYEOF 0
a8289c62 473
70ddf897 474#define YYACCEPT goto yyacceptlab
a8289c62 475#define YYABORT goto yyabortlab
a6b89bb2 476#define YYERROR goto yyerrorlab
8a3eb3c8 477
a8289c62 478
71da9eea
AD
479/* Like YYERROR except do call yyerror. This remains here temporarily
480 to ease the transition to the new meaning of YYERROR, for GCC.
10fa2066 481 Once GCC version 2 has supplanted version 1, this can go. */
a8289c62 482
10fa2066 483#define YYFAIL goto yyerrlab
a8289c62 484
10fa2066 485#define YYRECOVERING() (!!yyerrstatus)
a8289c62 486
69b4e0c5 487#define YYBACKUP(Token, Value) \
10fa2066 488do \
a20713a4 489 if (yychar == YYEMPTY && yylen == 1) \
71da9eea 490 { \
17da6427 491 yychar = (Token); \
7742ddeb 492 yylval = (Value); \
b0400cc6 493 yytoken = YYTRANSLATE (yychar); \
10fa2066
RS
494 YYPOPSTACK; \
495 goto yybackup; \
496 } \
497 else \
71da9eea 498 { \
9c1e26bd 499 yyerror (]b4_yyerror_args["syntax error: cannot back up");\
71da9eea
AD
500 YYERROR; \
501 } \
10fa2066
RS
502while (0)
503
3fc16193 504
10fa2066
RS
505#define YYTERROR 1
506#define YYERRCODE 256
507
3fc16193 508
b4a20338
AD
509/* YYLLOC_DEFAULT -- Set CURRENT to span from RHS[1] to RHS[N].
510 If N is 0, then set CURRENT to the empty location which ends
511 the previous symbol: RHS[0] (always defined). */
3abcd459 512
24e0cbd0 513#define YYRHSLOC(Rhs, K) ((Rhs)[K])
3abcd459 514#ifndef YYLLOC_DEFAULT
24e0cbd0
PE
515# define YYLLOC_DEFAULT(Current, Rhs, N) \
516 do \
517 if (N) \
518 { \
519 (Current).first_line = YYRHSLOC(Rhs, 1).first_line; \
520 (Current).first_column = YYRHSLOC(Rhs, 1).first_column; \
521 (Current).last_line = YYRHSLOC(Rhs, N).last_line; \
522 (Current).last_column = YYRHSLOC(Rhs, N).last_column; \
523 } \
524 else \
525 { \
526 (Current).first_line = (Current).last_line = \
527 YYRHSLOC(Rhs, 0).last_line; \
528 (Current).first_column = (Current).last_column = \
529 YYRHSLOC(Rhs, 0).last_column; \
530 } \
531 while (0)
b8458aa5
AD
532#endif
533
3fc16193
AD
534
535/* YY_LOCATION_PRINT -- Print the location on the stream.
536 This macro was not mandated originally: define only if we know
537 we won't break user code: when these are the locations we know. */
538
3fc16193 539#ifndef YY_LOCATION_PRINT
b8458aa5
AD
540# if YYLTYPE_IS_TRIVIAL
541# define YY_LOCATION_PRINT(File, Loc) \
542 fprintf (File, "%d.%d-%d.%d", \
543 (Loc).first_line, (Loc).first_column, \
544 (Loc).last_line, (Loc).last_column)
0dcca5c2
AD
545# else
546# define YY_LOCATION_PRINT(File, Loc) ((void) 0)
b8458aa5 547# endif
3abcd459
AD
548#endif
549
3fc16193 550
3abcd459 551/* YYLEX -- calling `yylex' with the right arguments. */
553e2b22 552
ae7453f2 553#ifdef YYLEX_PARAM
9c1e26bd 554# define YYLEX yylex (]b4_pure_if([&yylval[]b4_location_if([, &yylloc]), ])[YYLEX_PARAM)
74310291 555#else
9c1e26bd 556# define YYLEX ]b4_c_function_call([yylex], [int], b4_lex_param)[
ae7453f2 557#endif
553e2b22 558
5a35a6cb 559/* Enable debugging if requested. */
0d533154 560#if YYDEBUG
b7575ffe
PE
561
562# ifndef YYFPRINTF
45119af1
PE
563# include <stdio.h> /* INFRINGES ON USER NAME SPACE */
564# define YYFPRINTF fprintf
b7575ffe
PE
565# endif
566
5a35a6cb
AD
567# define YYDPRINTF(Args) \
568do { \
17da6427 569 if (yydebug) \
b7575ffe 570 YYFPRINTF Args; \
5a35a6cb 571} while (0)
c5e3e510 572
284acc8b 573# define YY_SYMBOL_PRINT(Title, Type, Value, Location) \
9c1e26bd
AD
574do { \
575 if (yydebug) \
576 { \
577 YYFPRINTF (stderr, "%s ", Title); \
578 yysymprint (stderr, \
284acc8b 579 Type, Value]b4_location_if([, Location])[); \
9c1e26bd
AD
580 YYFPRINTF (stderr, "\n"); \
581 } \
582} while (0)
583
b0937b22
AD
584/*------------------------------------------------------------------.
585| yy_stack_print -- Print the state stack from its BOTTOM up to its |
5348bfbe 586| TOP (included). |
b0937b22
AD
587`------------------------------------------------------------------*/
588
589]b4_c_function_def([yy_stack_print], [static void],
779e7ceb
PE
590 [[short int *bottom], [bottom]],
591 [[short int *top], [top]])[
b0937b22
AD
592{
593 YYFPRINTF (stderr, "Stack now");
594 for (/* Nothing. */; bottom <= top; ++bottom)
595 YYFPRINTF (stderr, " %d", *bottom);
596 YYFPRINTF (stderr, "\n");
597}
598
599# define YY_STACK_PRINT(Bottom, Top) \
600do { \
601 if (yydebug) \
602 yy_stack_print ((Bottom), (Top)); \
603} while (0)
604
605
606/*------------------------------------------------.
607| Report that the YYRULE is going to be reduced. |
608`------------------------------------------------*/
609
610]b4_c_function_def([yy_reduce_print], [static void],
611 [[int yyrule], [yyrule]])[
612{
613 int yyi;
52f32190 614 unsigned int yylno = yyrline[yyrule];
4f21fffe 615 YYFPRINTF (stderr, "Reducing stack by rule %d (line %u), ",
52f32190 616 yyrule - 1, yylno);
b0937b22
AD
617 /* Print the symbols being reduced, and their result. */
618 for (yyi = yyprhs[yyrule]; 0 <= yyrhs[yyi]; yyi++)
619 YYFPRINTF (stderr, "%s ", yytname [yyrhs[yyi]]);
620 YYFPRINTF (stderr, "-> %s\n", yytname [yyr1[yyrule]]);
621}
622
623# define YY_REDUCE_PRINT(Rule) \
624do { \
625 if (yydebug) \
626 yy_reduce_print (Rule); \
627} while (0)
628
cf44a9ae
PE
629/* Nonzero means print parse trace. It is left uninitialized so that
630 multiple parsers can coexist. */
17da6427 631int yydebug;
5a35a6cb
AD
632#else /* !YYDEBUG */
633# define YYDPRINTF(Args)
284acc8b 634# define YY_SYMBOL_PRINT(Title, Type, Value, Location)
b0937b22
AD
635# define YY_STACK_PRINT(Bottom, Top)
636# define YY_REDUCE_PRINT(Rule)
5a35a6cb
AD
637#endif /* !YYDEBUG */
638
b0937b22 639
5a35a6cb 640/* YYINITDEPTH -- initial size of the parser's stacks. */
10fa2066 641#ifndef YYINITDEPTH
9c1e26bd 642# define YYINITDEPTH ]b4_stack_depth_init[
10fa2066
RS
643#endif
644
5a35a6cb 645/* YYMAXDEPTH -- maximum size the stacks can grow to (effective only
600f9b0c
PE
646 if the built-in stack extension method is used).
647
648 Do not make this value too large; the results are undefined if
649 SIZE_MAX < YYSTACK_BYTES (YYMAXDEPTH)
650 evaluated with infinite-precision integer arithmetic. */
651
b929851a 652#if defined (YYMAXDEPTH) && YYMAXDEPTH == 0
b07b484a 653# undef YYMAXDEPTH
10fa2066
RS
654#endif
655
656#ifndef YYMAXDEPTH
9c1e26bd 657# define YYMAXDEPTH ]b4_stack_depth_max[
10fa2066 658#endif
a8289c62 659
10fa2066 660\f
a8289c62 661
7093d0f5
AD
662#if YYERROR_VERBOSE
663
664# ifndef yystrlen
665# if defined (__GLIBC__) && defined (_STRING_H)
666# define yystrlen strlen
667# else
668/* Return the length of YYSTR. */
669static YYSIZE_T
670# if defined (__STDC__) || defined (__cplusplus)
671yystrlen (const char *yystr)
672# else
673yystrlen (yystr)
674 const char *yystr;
675# endif
676{
677 register const char *yys = yystr;
678
679 while (*yys++ != '\0')
680 continue;
681
682 return yys - yystr - 1;
683}
684# endif
685# endif
686
687# ifndef yystpcpy
688# if defined (__GLIBC__) && defined (_STRING_H) && defined (_GNU_SOURCE)
689# define yystpcpy stpcpy
690# else
691/* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in
692 YYDEST. */
693static char *
f11966ff
PE
694# if defined (__STDC__) || defined (__cplusplus)
695yystpcpy (char *yydest, const char *yysrc)
696# else
7093d0f5
AD
697yystpcpy (yydest, yysrc)
698 char *yydest;
699 const char *yysrc;
7093d0f5
AD
700# endif
701{
702 register char *yyd = yydest;
703 register const char *yys = yysrc;
704
705 while ((*yyd++ = *yys++) != '\0')
706 continue;
707
708 return yyd - 1;
709}
710# endif
711# endif
712
713#endif /* !YYERROR_VERBOSE */
714
10fa2066 715\f
a8289c62 716
b8df3223 717#if YYDEBUG
9c1e26bd 718]b4_yysymprint_generate([b4_c_function_def])[
c5e3e510 719#endif /* ! YYDEBUG */
9c1e26bd 720]b4_yydestruct_generate([b4_c_function_def])
4a2a22f4
AD
721\f
722
0245f82d 723/* Prevent warnings from -Wmissing-prototypes. */
4a2a22f4
AD
724
725#ifdef YYPARSE_PARAM
726# if defined (__STDC__) || defined (__cplusplus)
0245f82d 727int yyparse (void *YYPARSE_PARAM);
4a2a22f4 728# else
0245f82d 729int yyparse ();
4a2a22f4 730# endif
0245f82d
AD
731#else /* ! YYPARSE_PARAM */
732b4_c_function_decl([yyparse], [int], b4_parse_param)
c5e3e510 733#endif /* ! YYPARSE_PARAM */
1b181651 734
0245f82d 735
74310291
AD
736m4_divert_push([KILL])# ======================== M4 code.
737# b4_declare_parser_variables
738# ---------------------------
739# Declare the variables that are global, or local to YYPARSE if
0245f82d 740# pure-parser.
74310291 741m4_define([b4_declare_parser_variables],
8dd162d3 742[/* The look-ahead symbol. */
74310291
AD
743int yychar;
744
8dd162d3 745/* The semantic value of the look-ahead symbol. */
74310291
AD
746YYSTYPE yylval;
747
6e649e65 748/* Number of syntax errors so far. */
74310291 749int yynerrs;b4_location_if([
8dd162d3 750/* Location data for the look-ahead symbol. */
58612f1d 751YYLTYPE yylloc;])
74310291
AD
752])
753m4_divert_pop([KILL])dnl# ====================== End of M4 code.
58612f1d 754
74310291
AD
755b4_pure_if([],
756 [b4_declare_parser_variables])
a35f64ea 757
0245f82d
AD
758
759/*----------.
760| yyparse. |
761`----------*/
762
763#ifdef YYPARSE_PARAM
764# if defined (__STDC__) || defined (__cplusplus)
765int yyparse (void *YYPARSE_PARAM)
766# else
767int yyparse (YYPARSE_PARAM)
768 void *YYPARSE_PARAM;
769# endif
770#else /* ! YYPARSE_PARAM */
771b4_c_function_def([yyparse], [int], b4_parse_param)
772#endif
be2a1a68 773{[
74310291 774 ]b4_pure_if([b4_declare_parser_variables])[
10fa2066
RS
775 register int yystate;
776 register int yyn;
600f9b0c 777 int yyresult;
b07b484a
AD
778 /* Number of tokens to shift before error messages enabled. */
779 int yyerrstatus;
8dd162d3 780 /* Look-ahead token as an internal (translated) token number. */
b0400cc6 781 int yytoken = 0;
10fa2066 782
bb10be54
AD
783 /* Three stacks and their tools:
784 `yyss': related to states,
e9e4c321 785 `yyvs': related to semantic values,
bb10be54
AD
786 `yyls': related to locations.
787
788 Refer to the stacks thru separate pointers, to allow yyoverflow
789 to reallocate them elsewhere. */
790
e8cb70b9 791 /* The state stack. */
779e7ceb
PE
792 short int yyssa[YYINITDEPTH];
793 short int *yyss = yyssa;
794 register short int *yyssp;
bb10be54 795
b07b484a
AD
796 /* The semantic value stack. */
797 YYSTYPE yyvsa[YYINITDEPTH];
b07b484a 798 YYSTYPE *yyvs = yyvsa;
bb10be54 799 register YYSTYPE *yyvsp;
10fa2066 800
58612f1d
AD
801]b4_location_if(
802[[ /* The location stack. */
b07b484a 803 YYLTYPE yylsa[YYINITDEPTH];
10fa2066 804 YYLTYPE *yyls = yylsa;
d42f69cd 805 YYLTYPE *yylsp;
3fc16193
AD
806 /* The locations where the error started and ended. */
807 YYLTYPE yyerror_range[2];]])[
10fa2066 808
58612f1d 809#define YYPOPSTACK (yyvsp--, yyssp--]b4_location_if([, yylsp--])[)
10fa2066 810
7093d0f5 811 YYSIZE_T yystacksize = YYINITDEPTH;
10fa2066 812
6666f98f
AD
813 /* The variables used to return semantic value and location from the
814 action routines. */
bb10be54 815 YYSTYPE yyval;
58612f1d 816]b4_location_if([ YYLTYPE yyloc;])[
10fa2066 817
6666f98f 818 /* When reducing, the number of symbols on the RHS of the reduced
e8cb70b9 819 rule. */
10fa2066
RS
820 int yylen;
821
7ea5e977 822 YYDPRINTF ((stderr, "Starting parse\n"));
10fa2066
RS
823
824 yystate = 0;
825 yyerrstatus = 0;
17da6427 826 yynerrs = 0;
a20713a4 827 yychar = YYEMPTY; /* Cause a token to be read. */
10fa2066
RS
828
829 /* Initialize stack pointers.
830 Waste one element of value and location stack
831 so that they stay on the same level as the state stack.
832 The wasted elements are never initialized. */
833
cbd89906 834 yyssp = yyss;
10fa2066 835 yyvsp = yyvs;
b8458aa5
AD
836]b4_location_if([[ yylsp = yyls;
837#if YYLTYPE_IS_TRIVIAL
838 /* Initialize the default location before parsing starts. */
451364ed
AD
839 yylloc.first_line = yylloc.last_line = 1;
840 yylloc.first_column = yylloc.last_column = 0;
b8458aa5
AD
841#endif
842]])
843m4_ifdef([b4_initial_action], [
0092f063
AD
844m4_pushdef([b4_at_dollar], [yylloc])dnl
845m4_pushdef([b4_dollar_dollar], [yylval])dnl
cd3684cf
AD
846 /* User initialization code. */
847 b4_initial_action
848m4_popdef([b4_dollar_dollar])dnl
849m4_popdef([b4_at_dollar])dnl
850/* Line __line__ of yacc.c. */
851b4_syncline([@oline@], [@ofile@])])dnl
451364ed
AD
852[
853 yyvsp[0] = yylval;
854]b4_location_if([[ yylsp[0] = yylloc;
855]])
cd3684cf 856[ goto yysetstate;
10fa2066 857
71da9eea
AD
858/*------------------------------------------------------------.
859| yynewstate -- Push a new state, which is found in yystate. |
860`------------------------------------------------------------*/
342b8b6e 861 yynewstate:
71da9eea
AD
862 /* In all cases, when you get here, the value and location stacks
863 have just been pushed. so pushing a state here evens the stacks.
864 */
cbd89906
PE
865 yyssp++;
866
342b8b6e 867 yysetstate:
cbd89906 868 *yyssp = yystate;
10fa2066 869
39912f52 870 if (yyss + yystacksize - 1 <= yyssp)
10fa2066 871 {
10fa2066 872 /* Get the current used size of the three stacks, in elements. */
7093d0f5 873 YYSIZE_T yysize = yyssp - yyss + 1;
10fa2066
RS
874
875#ifdef yyoverflow
3d76b07d
AD
876 {
877 /* Give user a chance to reallocate the stack. Use copies of
878 these so that the &'s don't force the real ones into
879 memory. */
880 YYSTYPE *yyvs1 = yyvs;
779e7ceb 881 short int *yyss1 = yyss;
58612f1d 882]b4_location_if([ YYLTYPE *yyls1 = yyls;])[
3d76b07d
AD
883
884 /* Each stack pointer address is followed by the size of the
58612f1d
AD
885 data in use in that stack, in bytes. This used to be a
886 conditional around just the two extra args, but that might
887 be undefined if yyoverflow is a macro. */
3d76b07d 888 yyoverflow ("parser stack overflow",
7093d0f5
AD
889 &yyss1, yysize * sizeof (*yyssp),
890 &yyvs1, yysize * sizeof (*yyvsp),
58612f1d 891]b4_location_if([ &yyls1, yysize * sizeof (*yylsp),])[
3d76b07d 892 &yystacksize);
58612f1d 893]b4_location_if([ yyls = yyls1;])[
3d76b07d
AD
894 yyss = yyss1;
895 yyvs = yyvs1;
896 }
10fa2066 897#else /* no yyoverflow */
cf44a9ae
PE
898# ifndef YYSTACK_RELOCATE
899 goto yyoverflowlab;
900# else
10fa2066 901 /* Extend the stack our own way. */
39912f52 902 if (YYMAXDEPTH <= yystacksize)
600f9b0c 903 goto yyoverflowlab;
10fa2066 904 yystacksize *= 2;
39912f52 905 if (YYMAXDEPTH < yystacksize)
10fa2066 906 yystacksize = YYMAXDEPTH;
e9e4c321 907
600f9b0c 908 {
779e7ceb 909 short int *yyss1 = yyss;
2729e106
PE
910 union yyalloc *yyptr =
911 (union yyalloc *) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize));
600f9b0c
PE
912 if (! yyptr)
913 goto yyoverflowlab;
5b041382
PE
914 YYSTACK_RELOCATE (yyss);
915 YYSTACK_RELOCATE (yyvs);
58612f1d 916]b4_location_if([ YYSTACK_RELOCATE (yyls);])[
cf44a9ae 917# undef YYSTACK_RELOCATE
600f9b0c
PE
918 if (yyss1 != yyssa)
919 YYSTACK_FREE (yyss1);
920 }
cf44a9ae 921# endif
10fa2066
RS
922#endif /* no yyoverflow */
923
7093d0f5
AD
924 yyssp = yyss + yysize - 1;
925 yyvsp = yyvs + yysize - 1;
58612f1d 926]b4_location_if([ yylsp = yyls + yysize - 1;])[
10fa2066 927
7ea5e977 928 YYDPRINTF ((stderr, "Stack size increased to %lu\n",
600f9b0c 929 (unsigned long int) yystacksize));
10fa2066 930
39912f52 931 if (yyss + yystacksize - 1 <= yyssp)
10fa2066
RS
932 YYABORT;
933 }
934
7ea5e977 935 YYDPRINTF ((stderr, "Entering state %d\n", yystate));
10fa2066
RS
936
937 goto yybackup;
71da9eea 938
71da9eea
AD
939/*-----------.
940| yybackup. |
941`-----------*/
942yybackup:
10fa2066
RS
943
944/* Do appropriate processing given the current state. */
8dd162d3 945/* Read a look-ahead token if we need one and don't already have one. */
10fa2066
RS
946/* yyresume: */
947
8dd162d3 948 /* First try to decide what to do without reference to look-ahead token. */
10fa2066
RS
949
950 yyn = yypact[yystate];
12b0043a 951 if (yyn == YYPACT_NINF)
10fa2066
RS
952 goto yydefault;
953
8dd162d3 954 /* Not known => get a look-ahead token if don't already have one. */
10fa2066 955
8dd162d3 956 /* YYCHAR is either YYEMPTY or YYEOF or a valid look-ahead symbol. */
a20713a4 957 if (yychar == YYEMPTY)
10fa2066 958 {
7ea5e977 959 YYDPRINTF ((stderr, "Reading a token: "));
17da6427 960 yychar = YYLEX;
10fa2066
RS
961 }
962
a20713a4 963 if (yychar <= YYEOF)
10fa2066 964 {
a20713a4 965 yychar = yytoken = YYEOF;
7ea5e977 966 YYDPRINTF ((stderr, "Now at end of input.\n"));
10fa2066
RS
967 }
968 else
969 {
a20713a4 970 yytoken = YYTRANSLATE (yychar);
284acc8b 971 YY_SYMBOL_PRINT ("Next token is", yytoken, &yylval, &yylloc);
10fa2066
RS
972 }
973
b0400cc6 974 /* If the proper action on seeing token YYTOKEN is to reduce or to
e5cfd9d8 975 detect an error, take that action. */
b0400cc6
AD
976 yyn += yytoken;
977 if (yyn < 0 || YYLAST < yyn || yycheck[yyn] != yytoken)
e5cfd9d8
PE
978 goto yydefault;
979 yyn = yytable[yyn];
980 if (yyn <= 0)
10fa2066 981 {
e5cfd9d8
PE
982 if (yyn == 0 || yyn == YYTABLE_NINF)
983 goto yyerrlab;
10fa2066
RS
984 yyn = -yyn;
985 goto yyreduce;
986 }
10fa2066
RS
987
988 if (yyn == YYFINAL)
989 YYACCEPT;
990
8dd162d3 991 /* Shift the look-ahead token. */
1576d44d 992 YY_SYMBOL_PRINT ("Shifting", yytoken, &yylval, &yylloc);
10fa2066
RS
993
994 /* Discard the token being shifted unless it is eof. */
a20713a4
PE
995 if (yychar != YYEOF)
996 yychar = YYEMPTY;
10fa2066 997
17da6427 998 *++yyvsp = yylval;
58612f1d 999]b4_location_if([ *++yylsp = yylloc;])[
10fa2066 1000
71da9eea
AD
1001 /* Count tokens shifted since error; after three, turn off error
1002 status. */
1003 if (yyerrstatus)
1004 yyerrstatus--;
10fa2066
RS
1005
1006 yystate = yyn;
1007 goto yynewstate;
1008
10fa2066 1009
71da9eea
AD
1010/*-----------------------------------------------------------.
1011| yydefault -- do the default action for the current state. |
1012`-----------------------------------------------------------*/
1013yydefault:
10fa2066
RS
1014 yyn = yydefact[yystate];
1015 if (yyn == 0)
1016 goto yyerrlab;
71da9eea 1017 goto yyreduce;
10fa2066 1018
71da9eea
AD
1019
1020/*-----------------------------.
1021| yyreduce -- Do a reduction. |
1022`-----------------------------*/
10fa2066 1023yyreduce:
71da9eea 1024 /* yyn is the number of a rule to reduce with. */
10fa2066 1025 yylen = yyr2[yyn];
da9abf43
AD
1026
1027 /* If YYLEN is nonzero, implement the default value of the action:
573c1d9f 1028 `$$ = $1'.
da9abf43 1029
accea6db
PE
1030 Otherwise, the following line sets YYVAL to garbage.
1031 This behavior is undocumented and Bison
da9abf43
AD
1032 users should not rely upon it. Assigning to YYVAL
1033 unconditionally makes the parser a bit smaller, and it avoids a
1034 GCC warning that YYVAL may be used uninitialized. */
1035 yyval = yyvsp[1-yylen];
3abcd459 1036
58612f1d 1037]b4_location_if(
b8458aa5 1038[[ /* Default location. */
b4a20338 1039 YYLLOC_DEFAULT (yyloc, yylsp - yylen, yylen);]])[
b0937b22 1040 YY_REDUCE_PRINT (yyn);
a8289c62 1041 switch (yyn)
be2a1a68
AD
1042 ]{
1043 b4_actions
a8289c62 1044 }
897668ee 1045
996b1c7e 1046/* Line __line__ of yacc.c. */
947427ae 1047b4_syncline([@oline@], [@ofile@])
10fa2066 1048\f
be2a1a68 1049[ yyvsp -= yylen;
10fa2066 1050 yyssp -= yylen;
58612f1d 1051]b4_location_if([ yylsp -= yylen;])[
10fa2066 1052
b0937b22 1053 YY_STACK_PRINT (yyss, yyssp);
10fa2066
RS
1054
1055 *++yyvsp = yyval;
58612f1d 1056]b4_location_if([ *++yylsp = yyloc;])[
10fa2066 1057
41aca2e0
AD
1058 /* Now `shift' the result of the reduction. Determine what state
1059 that goes to, based on the state we popped back to and the rule
1060 number reduced by. */
10fa2066
RS
1061
1062 yyn = yyr1[yyn];
1063
7742ddeb 1064 yystate = yypgoto[yyn - YYNTOKENS] + *yyssp;
12b0043a 1065 if (0 <= yystate && yystate <= YYLAST && yycheck[yystate] == *yyssp)
10fa2066
RS
1066 yystate = yytable[yystate];
1067 else
7742ddeb 1068 yystate = yydefgoto[yyn - YYNTOKENS];
10fa2066
RS
1069
1070 goto yynewstate;
1071
10fa2066 1072
71da9eea
AD
1073/*------------------------------------.
1074| yyerrlab -- here on detecting error |
1075`------------------------------------*/
1076yyerrlab:
1077 /* If not already recovering from an error, report this error. */
1078 if (!yyerrstatus)
10fa2066 1079 {
17da6427 1080 ++yynerrs;
df5aed8c
PE
1081#if YYERROR_VERBOSE
1082 yyn = yypact[yystate];
1083
1084 if (YYPACT_NINF < yyn && yyn < YYLAST)
1085 {
1086 YYSIZE_T yysize = 0;
1087 int yytype = YYTRANSLATE (yychar);
c4749565 1088 const char* yyprefix;
df5aed8c 1089 char *yymsg;
3aa2f55d 1090 int yyx;
df5aed8c 1091
df5aed8c
PE
1092 /* Start YYX at -YYN if negative to avoid negative indexes in
1093 YYCHECK. */
c4749565 1094 int yyxbegin = yyn < 0 ? -yyn : 0;
3aa2f55d
PE
1095
1096 /* Stay within bounds of both yycheck and yytname. */
1097 int yychecklim = YYLAST - yyn;
c4749565 1098 int yyxend = yychecklim < YYNTOKENS ? yychecklim : YYNTOKENS;
3aa2f55d
PE
1099 int yycount = 0;
1100
c4749565
AD
1101 yyprefix = ", expecting ";
1102 for (yyx = yyxbegin; yyx < yyxend; ++yyx)
df5aed8c 1103 if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR)
3aa2f55d 1104 {
c4749565
AD
1105 yysize += yystrlen (yyprefix) + yystrlen (yytname [yyx]);
1106 yycount += 1;
3aa2f55d
PE
1107 if (yycount == 5)
1108 {
1109 yysize = 0;
1110 break;
c4749565 1111 }
3aa2f55d
PE
1112 }
1113 yysize += (sizeof ("syntax error, unexpected ")
1114 + yystrlen (yytname[yytype]));
df5aed8c
PE
1115 yymsg = (char *) YYSTACK_ALLOC (yysize);
1116 if (yymsg != 0)
1117 {
6e649e65 1118 char *yyp = yystpcpy (yymsg, "syntax error, unexpected ");
df5aed8c
PE
1119 yyp = yystpcpy (yyp, yytname[yytype]);
1120
1121 if (yycount < 5)
1122 {
c4749565
AD
1123 yyprefix = ", expecting ";
1124 for (yyx = yyxbegin; yyx < yyxend; ++yyx)
df5aed8c
PE
1125 if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR)
1126 {
c4749565 1127 yyp = yystpcpy (yyp, yyprefix);
df5aed8c 1128 yyp = yystpcpy (yyp, yytname[yyx]);
c4749565 1129 yyprefix = " or ";
df5aed8c
PE
1130 }
1131 }
93724f13 1132 yyerror (]b4_yyerror_args[yymsg);
df5aed8c
PE
1133 YYSTACK_FREE (yymsg);
1134 }
1135 else
6e649e65 1136 yyerror (]b4_yyerror_args["syntax error; also virtual memory exhausted");
df5aed8c
PE
1137 }
1138 else
1139#endif /* YYERROR_VERBOSE */
6e649e65 1140 yyerror (]b4_yyerror_args["syntax error");
10fa2066 1141 }
71da9eea 1142
3fc16193 1143]b4_location_if([[ yyerror_range[0] = yylloc;]])[
d42f69cd 1144
10fa2066
RS
1145 if (yyerrstatus == 3)
1146 {
8dd162d3 1147 /* If just tried and failed to reuse look-ahead token after an
71da9eea 1148 error, discard it. */
10fa2066 1149
a6b89bb2 1150 if (yychar <= YYEOF)
5719c109 1151 {
a6b89bb2
PE
1152 /* If at end of input, pop the error token,
1153 then the rest of the stack, then return failure. */
1154 if (yychar == YYEOF)
1155 for (;;)
1156 {
3fc16193 1157]b4_location_if([[ yyerror_range[0] = *yylsp;]])[
a6b89bb2
PE
1158 YYPOPSTACK;
1159 if (yyssp == yyss)
1160 YYABORT;
a0e68930
AD
1161 yydestruct ("Error: popping",
1162 yystos[*yyssp], yyvsp]b4_location_if([, yylsp])[);
a6b89bb2 1163 }
5719c109 1164 }
a6b89bb2
PE
1165 else
1166 {
a0e68930 1167 yydestruct ("Error: discarding", yytoken, &yylval]b4_location_if([, &yylloc])[);
a6b89bb2 1168 yychar = YYEMPTY;
a6b89bb2 1169 }
10fa2066
RS
1170 }
1171
8dd162d3 1172 /* Else will try to reuse look-ahead token after shifting the error
71da9eea 1173 token. */
8a3eb3c8 1174 goto yyerrlab1;
300a7966 1175
10fa2066 1176
a6b89bb2
PE
1177/*---------------------------------------------------.
1178| yyerrorlab -- error raised explicitly by YYERROR. |
1179`---------------------------------------------------*/
1180yyerrorlab:
1181
1182#ifdef __GNUC__
1183 /* Pacify GCC when the user code never invokes YYERROR and the label
1184 yyerrorlab therefore never appears in user code. */
1185 if (0)
1186 goto yyerrorlab;
1187#endif
1188
3fc16193
AD
1189]b4_location_if([[ yyerror_range[0] = yylsp[1-yylen];
1190 yylsp -= yylen;
1191 ]])[yyvsp -= yylen;
a6b89bb2
PE
1192 yyssp -= yylen;
1193 yystate = *yyssp;
3fc16193 1194 goto yyerrlab1;
a6b89bb2
PE
1195
1196
1197/*-------------------------------------------------------------.
1198| yyerrlab1 -- common code for both syntax error and YYERROR. |
1199`-------------------------------------------------------------*/
300a7966 1200yyerrlab1:
cf44a9ae 1201 yyerrstatus = 3; /* Each real token shifted decrements this. */
10fa2066 1202
660bc8dd
PE
1203 for (;;)
1204 {
1205 yyn = yypact[yystate];
12b0043a 1206 if (yyn != YYPACT_NINF)
660bc8dd
PE
1207 {
1208 yyn += YYTERROR;
1209 if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR)
1210 {
1211 yyn = yytable[yyn];
1212 if (0 < yyn)
1213 break;
1214 }
1215 }
10fa2066 1216
660bc8dd
PE
1217 /* Pop the current state because it cannot handle the error token. */
1218 if (yyssp == yyss)
1219 YYABORT;
5504898e 1220
3fc16193 1221]b4_location_if([[ yyerror_range[0] = *yylsp;]])[
a0e68930 1222 yydestruct ("Error: popping", yystos[yystate], yyvsp]b4_location_if([, yylsp])[);
a6b89bb2
PE
1223 YYPOPSTACK;
1224 yystate = *yyssp;
b0937b22 1225 YY_STACK_PRINT (yyss, yyssp);
10fa2066 1226 }
10fa2066
RS
1227
1228 if (yyn == YYFINAL)
1229 YYACCEPT;
1230
17da6427 1231 *++yyvsp = yylval;
3fc16193
AD
1232]b4_location_if([[
1233 yyerror_range[1] = yylloc;
1234 /* Using YYLLOC is tempting, but would change the location of
1235 the look-ahead. YYLOC is available though. */
1236 YYLLOC_DEFAULT (yyloc, yyerror_range - 1, 2);
1237 *++yylsp = yyloc;]])[
10fa2066 1238
1576d44d
AD
1239 /* Shift the error token. */
1240 YY_SYMBOL_PRINT ("Shifting", yystos[yyn], yyvsp, yylsp);
1241
10fa2066
RS
1242 yystate = yyn;
1243 goto yynewstate;
70ddf897 1244
71da9eea
AD
1245
1246/*-------------------------------------.
1247| yyacceptlab -- YYACCEPT comes here. |
1248`-------------------------------------*/
1249yyacceptlab:
600f9b0c
PE
1250 yyresult = 0;
1251 goto yyreturn;
71da9eea
AD
1252
1253/*-----------------------------------.
1254| yyabortlab -- YYABORT comes here. |
1255`-----------------------------------*/
1256yyabortlab:
a0e68930
AD
1257 yydestruct ("Error: discarding lookahead",
1258 yytoken, &yylval]b4_location_if([, &yylloc])[);
e757bb10 1259 yychar = YYEMPTY;
600f9b0c
PE
1260 yyresult = 1;
1261 goto yyreturn;
1262
0bfb02ff 1263#ifndef yyoverflow
ca98bf57
AD
1264/*----------------------------------------------.
1265| yyoverflowlab -- parser overflow comes here. |
1266`----------------------------------------------*/
600f9b0c 1267yyoverflowlab:
93724f13 1268 yyerror (]b4_yyerror_args["parser stack overflow");
600f9b0c
PE
1269 yyresult = 2;
1270 /* Fall through. */
0bfb02ff 1271#endif
600f9b0c
PE
1272
1273yyreturn:
1274#ifndef yyoverflow
1275 if (yyss != yyssa)
1276 YYSTACK_FREE (yyss);
70ddf897 1277#endif
600f9b0c 1278 return yyresult;
be2a1a68
AD
1279]}
1280
24c0aad7 1281
be2a1a68
AD
1282b4_epilogue
1283m4_if(b4_defines_flag, 0, [],
947427ae 1284[@output @output_header_name@
c76e14da 1285b4_copyright([Skeleton parser for Yacc-like parsing with Bison],
779e7ceb 1286 [1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004])
0252b55c
PE
1287
1288/* As a special exception, when this file is copied by Bison into a
1289 Bison output file, you may use that output file without restriction.
1290 This special exception was added by the Free Software Foundation
1291 in version 1.24 of Bison. */
c76e14da 1292
0d8bed56 1293b4_token_defines(b4_tokens)
be2a1a68 1294
050c471b 1295#if ! defined (YYSTYPE) && ! defined (YYSTYPE_IS_DECLARED)
e9955c83 1296m4_ifdef([b4_stype],
437c2d80 1297[b4_syncline([b4_stype_line], [b4_filename])
050c471b 1298typedef union m4_bregexp(b4_stype, [^{], [YYSTYPE ])b4_stype YYSTYPE;
996b1c7e 1299/* Line __line__ of yacc.c. */
947427ae 1300b4_syncline([@oline@], [@ofile@])],
050c471b
PE
1301[typedef int YYSTYPE;])
1302# define yystype YYSTYPE /* obsolescent; will be withdrawn */
1303# define YYSTYPE_IS_DECLARED 1
947427ae 1304# define YYSTYPE_IS_TRIVIAL 1
be2a1a68
AD
1305#endif
1306
74310291 1307b4_pure_if([],
be2a1a68
AD
1308[extern YYSTYPE b4_prefix[]lval;])
1309
58612f1d 1310b4_location_if(
050c471b
PE
1311[#if ! defined (YYLTYPE) && ! defined (YYLTYPE_IS_DECLARED)
1312typedef struct YYLTYPE
be2a1a68
AD
1313{
1314 int first_line;
1315 int first_column;
1316 int last_line;
1317 int last_column;
050c471b
PE
1318} YYLTYPE;
1319# define yyltype YYLTYPE /* obsolescent; will be withdrawn */
1320# define YYLTYPE_IS_DECLARED 1
1321# define YYLTYPE_IS_TRIVIAL 1
be2a1a68 1322#endif
ff48177d 1323
be2a1a68
AD
1324m4_if(b4_pure, [0],
1325[extern YYLTYPE b4_prefix[]lloc;])
1326])
be2a1a68 1327])