]> git.saurik.com Git - bison.git/blame - data/yacc.c
(yyglrReduce): Don't use C89 string concatenation.
[bison.git] / data / yacc.c
CommitLineData
007a50a4 1m4_divert(-1) -*- C -*-
a8289c62 2
60491a94 3# Yacc compatible skeleton for Bison
c1a0d7e0 4# Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003
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
79 b4_ints_in($@, [0], [65535]), [1], [unsigned short],
80 b4_ints_in($@, [-32768], [32767]), [1], [short],
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],
c1a0d7e0 137 [1984, 1989, 1990, 2000, 2001, 2002, 2003])[
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{
2729e106
PE
264 short yyss;
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) \
cf44a9ae 277 ((N) * (sizeof (short) + sizeof (YYSTYPE) + sizeof (YYLTYPE)) \
17836590 278 + 2 * YYSTACK_GAP_MAXIMUM)],
58612f1d 279[# define YYSTACK_BYTES(N) \
cf44a9ae 280 ((N) * (sizeof (short) + 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
322 typedef short yysigned_char;
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
504#define YYTERROR 1
505#define YYERRCODE 256
506
3abcd459 507/* YYLLOC_DEFAULT -- Compute the default location (before the actions
b2d52318 508 are run). */
3abcd459
AD
509
510#ifndef YYLLOC_DEFAULT
0ae99356
PE
511# define YYLLOC_DEFAULT(Current, Rhs, N) \
512 ((Current).first_line = (Rhs)[1].first_line, \
513 (Current).first_column = (Rhs)[1].first_column, \
514 (Current).last_line = (Rhs)[N].last_line, \
515 (Current).last_column = (Rhs)[N].last_column)
3abcd459
AD
516#endif
517
3abcd459 518/* YYLEX -- calling `yylex' with the right arguments. */
553e2b22 519
ae7453f2 520#ifdef YYLEX_PARAM
9c1e26bd 521# define YYLEX yylex (]b4_pure_if([&yylval[]b4_location_if([, &yylloc]), ])[YYLEX_PARAM)
74310291 522#else
9c1e26bd 523# define YYLEX ]b4_c_function_call([yylex], [int], b4_lex_param)[
ae7453f2 524#endif
553e2b22 525
5a35a6cb 526/* Enable debugging if requested. */
0d533154 527#if YYDEBUG
b7575ffe
PE
528
529# ifndef YYFPRINTF
45119af1
PE
530# include <stdio.h> /* INFRINGES ON USER NAME SPACE */
531# define YYFPRINTF fprintf
b7575ffe
PE
532# endif
533
5a35a6cb
AD
534# define YYDPRINTF(Args) \
535do { \
17da6427 536 if (yydebug) \
b7575ffe 537 YYFPRINTF Args; \
5a35a6cb 538} while (0)
c5e3e510 539
253862fd
AD
540# define YYDSYMPRINT(Args) \
541do { \
542 if (yydebug) \
543 yysymprint Args; \
544} while (0)
c5e3e510 545
9c1e26bd
AD
546# define YYDSYMPRINTF(Title, Token, Value, Location) \
547do { \
548 if (yydebug) \
549 { \
550 YYFPRINTF (stderr, "%s ", Title); \
551 yysymprint (stderr, \
552 Token, Value]b4_location_if([, Location])[); \
553 YYFPRINTF (stderr, "\n"); \
554 } \
555} while (0)
556
b0937b22
AD
557/*------------------------------------------------------------------.
558| yy_stack_print -- Print the state stack from its BOTTOM up to its |
559| TOP (cinluded). |
560`------------------------------------------------------------------*/
561
562]b4_c_function_def([yy_stack_print], [static void],
563 [[short *bottom], [bottom]],
564 [[short *top], [top]])[
565{
566 YYFPRINTF (stderr, "Stack now");
567 for (/* Nothing. */; bottom <= top; ++bottom)
568 YYFPRINTF (stderr, " %d", *bottom);
569 YYFPRINTF (stderr, "\n");
570}
571
572# define YY_STACK_PRINT(Bottom, Top) \
573do { \
574 if (yydebug) \
575 yy_stack_print ((Bottom), (Top)); \
576} while (0)
577
578
579/*------------------------------------------------.
580| Report that the YYRULE is going to be reduced. |
581`------------------------------------------------*/
582
583]b4_c_function_def([yy_reduce_print], [static void],
584 [[int yyrule], [yyrule]])[
585{
586 int yyi;
52f32190 587 unsigned int yylno = yyrline[yyrule];
4f21fffe 588 YYFPRINTF (stderr, "Reducing stack by rule %d (line %u), ",
52f32190 589 yyrule - 1, yylno);
b0937b22
AD
590 /* Print the symbols being reduced, and their result. */
591 for (yyi = yyprhs[yyrule]; 0 <= yyrhs[yyi]; yyi++)
592 YYFPRINTF (stderr, "%s ", yytname [yyrhs[yyi]]);
593 YYFPRINTF (stderr, "-> %s\n", yytname [yyr1[yyrule]]);
594}
595
596# define YY_REDUCE_PRINT(Rule) \
597do { \
598 if (yydebug) \
599 yy_reduce_print (Rule); \
600} while (0)
601
cf44a9ae
PE
602/* Nonzero means print parse trace. It is left uninitialized so that
603 multiple parsers can coexist. */
17da6427 604int yydebug;
5a35a6cb
AD
605#else /* !YYDEBUG */
606# define YYDPRINTF(Args)
253862fd 607# define YYDSYMPRINT(Args)
9c1e26bd 608# define YYDSYMPRINTF(Title, Token, Value, Location)
b0937b22
AD
609# define YY_STACK_PRINT(Bottom, Top)
610# define YY_REDUCE_PRINT(Rule)
5a35a6cb
AD
611#endif /* !YYDEBUG */
612
b0937b22 613
5a35a6cb 614/* YYINITDEPTH -- initial size of the parser's stacks. */
10fa2066 615#ifndef YYINITDEPTH
9c1e26bd 616# define YYINITDEPTH ]b4_stack_depth_init[
10fa2066
RS
617#endif
618
5a35a6cb 619/* YYMAXDEPTH -- maximum size the stacks can grow to (effective only
600f9b0c
PE
620 if the built-in stack extension method is used).
621
622 Do not make this value too large; the results are undefined if
623 SIZE_MAX < YYSTACK_BYTES (YYMAXDEPTH)
624 evaluated with infinite-precision integer arithmetic. */
625
b929851a 626#if defined (YYMAXDEPTH) && YYMAXDEPTH == 0
b07b484a 627# undef YYMAXDEPTH
10fa2066
RS
628#endif
629
630#ifndef YYMAXDEPTH
9c1e26bd 631# define YYMAXDEPTH ]b4_stack_depth_max[
10fa2066 632#endif
a8289c62 633
10fa2066 634\f
a8289c62 635
7093d0f5
AD
636#if YYERROR_VERBOSE
637
638# ifndef yystrlen
639# if defined (__GLIBC__) && defined (_STRING_H)
640# define yystrlen strlen
641# else
642/* Return the length of YYSTR. */
643static YYSIZE_T
644# if defined (__STDC__) || defined (__cplusplus)
645yystrlen (const char *yystr)
646# else
647yystrlen (yystr)
648 const char *yystr;
649# endif
650{
651 register const char *yys = yystr;
652
653 while (*yys++ != '\0')
654 continue;
655
656 return yys - yystr - 1;
657}
658# endif
659# endif
660
661# ifndef yystpcpy
662# if defined (__GLIBC__) && defined (_STRING_H) && defined (_GNU_SOURCE)
663# define yystpcpy stpcpy
664# else
665/* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in
666 YYDEST. */
667static char *
f11966ff
PE
668# if defined (__STDC__) || defined (__cplusplus)
669yystpcpy (char *yydest, const char *yysrc)
670# else
7093d0f5
AD
671yystpcpy (yydest, yysrc)
672 char *yydest;
673 const char *yysrc;
7093d0f5
AD
674# endif
675{
676 register char *yyd = yydest;
677 register const char *yys = yysrc;
678
679 while ((*yyd++ = *yys++) != '\0')
680 continue;
681
682 return yyd - 1;
683}
684# endif
685# endif
686
687#endif /* !YYERROR_VERBOSE */
688
10fa2066 689\f
a8289c62 690
b8df3223 691#if YYDEBUG
9c1e26bd 692]b4_yysymprint_generate([b4_c_function_def])[
c5e3e510 693#endif /* ! YYDEBUG */
9c1e26bd 694]b4_yydestruct_generate([b4_c_function_def])
4a2a22f4
AD
695\f
696
0245f82d 697/* Prevent warnings from -Wmissing-prototypes. */
4a2a22f4
AD
698
699#ifdef YYPARSE_PARAM
700# if defined (__STDC__) || defined (__cplusplus)
0245f82d 701int yyparse (void *YYPARSE_PARAM);
4a2a22f4 702# else
0245f82d 703int yyparse ();
4a2a22f4 704# endif
0245f82d
AD
705#else /* ! YYPARSE_PARAM */
706b4_c_function_decl([yyparse], [int], b4_parse_param)
c5e3e510 707#endif /* ! YYPARSE_PARAM */
1b181651 708
0245f82d 709
74310291
AD
710m4_divert_push([KILL])# ======================== M4 code.
711# b4_declare_parser_variables
712# ---------------------------
713# Declare the variables that are global, or local to YYPARSE if
0245f82d 714# pure-parser.
74310291
AD
715m4_define([b4_declare_parser_variables],
716[/* The lookahead symbol. */
717int yychar;
718
719/* The semantic value of the lookahead symbol. */
720YYSTYPE yylval;
721
6e649e65 722/* Number of syntax errors so far. */
74310291
AD
723int yynerrs;b4_location_if([
724/* Location data for the lookahead symbol. */
58612f1d 725YYLTYPE yylloc;])
74310291
AD
726])
727m4_divert_pop([KILL])dnl# ====================== End of M4 code.
58612f1d 728
74310291
AD
729b4_pure_if([],
730 [b4_declare_parser_variables])
a35f64ea 731
0245f82d
AD
732
733/*----------.
734| yyparse. |
735`----------*/
736
737#ifdef YYPARSE_PARAM
738# if defined (__STDC__) || defined (__cplusplus)
739int yyparse (void *YYPARSE_PARAM)
740# else
741int yyparse (YYPARSE_PARAM)
742 void *YYPARSE_PARAM;
743# endif
744#else /* ! YYPARSE_PARAM */
745b4_c_function_def([yyparse], [int], b4_parse_param)
746#endif
be2a1a68 747{[
74310291 748 ]b4_pure_if([b4_declare_parser_variables])[
10fa2066
RS
749 register int yystate;
750 register int yyn;
600f9b0c 751 int yyresult;
b07b484a
AD
752 /* Number of tokens to shift before error messages enabled. */
753 int yyerrstatus;
754 /* Lookahead token as an internal (translated) token number. */
b0400cc6 755 int yytoken = 0;
10fa2066 756
bb10be54
AD
757 /* Three stacks and their tools:
758 `yyss': related to states,
e9e4c321 759 `yyvs': related to semantic values,
bb10be54
AD
760 `yyls': related to locations.
761
762 Refer to the stacks thru separate pointers, to allow yyoverflow
763 to reallocate them elsewhere. */
764
e8cb70b9 765 /* The state stack. */
b07b484a 766 short yyssa[YYINITDEPTH];
bb10be54
AD
767 short *yyss = yyssa;
768 register short *yyssp;
769
b07b484a
AD
770 /* The semantic value stack. */
771 YYSTYPE yyvsa[YYINITDEPTH];
b07b484a 772 YYSTYPE *yyvs = yyvsa;
bb10be54 773 register YYSTYPE *yyvsp;
10fa2066 774
58612f1d
AD
775]b4_location_if(
776[[ /* The location stack. */
b07b484a 777 YYLTYPE yylsa[YYINITDEPTH];
10fa2066 778 YYLTYPE *yyls = yylsa;
d42f69cd
PE
779 YYLTYPE *yylsp;
780 YYLTYPE *yylerrsp;]])[
10fa2066 781
58612f1d 782#define YYPOPSTACK (yyvsp--, yyssp--]b4_location_if([, yylsp--])[)
10fa2066 783
7093d0f5 784 YYSIZE_T yystacksize = YYINITDEPTH;
10fa2066 785
6666f98f
AD
786 /* The variables used to return semantic value and location from the
787 action routines. */
bb10be54 788 YYSTYPE yyval;
58612f1d 789]b4_location_if([ YYLTYPE yyloc;])[
10fa2066 790
6666f98f 791 /* When reducing, the number of symbols on the RHS of the reduced
e8cb70b9 792 rule. */
10fa2066
RS
793 int yylen;
794
7ea5e977 795 YYDPRINTF ((stderr, "Starting parse\n"));
10fa2066
RS
796
797 yystate = 0;
798 yyerrstatus = 0;
17da6427 799 yynerrs = 0;
a20713a4 800 yychar = YYEMPTY; /* Cause a token to be read. */
10fa2066
RS
801
802 /* Initialize stack pointers.
803 Waste one element of value and location stack
804 so that they stay on the same level as the state stack.
805 The wasted elements are never initialized. */
806
cbd89906 807 yyssp = yyss;
10fa2066 808 yyvsp = yyvs;
58612f1d 809]b4_location_if([ yylsp = yyls;])[
cbd89906 810 goto yysetstate;
10fa2066 811
71da9eea
AD
812/*------------------------------------------------------------.
813| yynewstate -- Push a new state, which is found in yystate. |
814`------------------------------------------------------------*/
342b8b6e 815 yynewstate:
71da9eea
AD
816 /* In all cases, when you get here, the value and location stacks
817 have just been pushed. so pushing a state here evens the stacks.
818 */
cbd89906
PE
819 yyssp++;
820
342b8b6e 821 yysetstate:
cbd89906 822 *yyssp = yystate;
10fa2066 823
39912f52 824 if (yyss + yystacksize - 1 <= yyssp)
10fa2066 825 {
10fa2066 826 /* Get the current used size of the three stacks, in elements. */
7093d0f5 827 YYSIZE_T yysize = yyssp - yyss + 1;
10fa2066
RS
828
829#ifdef yyoverflow
3d76b07d
AD
830 {
831 /* Give user a chance to reallocate the stack. Use copies of
832 these so that the &'s don't force the real ones into
833 memory. */
834 YYSTYPE *yyvs1 = yyvs;
835 short *yyss1 = yyss;
58612f1d 836]b4_location_if([ YYLTYPE *yyls1 = yyls;])[
3d76b07d
AD
837
838 /* Each stack pointer address is followed by the size of the
58612f1d
AD
839 data in use in that stack, in bytes. This used to be a
840 conditional around just the two extra args, but that might
841 be undefined if yyoverflow is a macro. */
3d76b07d 842 yyoverflow ("parser stack overflow",
7093d0f5
AD
843 &yyss1, yysize * sizeof (*yyssp),
844 &yyvs1, yysize * sizeof (*yyvsp),
58612f1d 845]b4_location_if([ &yyls1, yysize * sizeof (*yylsp),])[
3d76b07d 846 &yystacksize);
58612f1d 847]b4_location_if([ yyls = yyls1;])[
3d76b07d
AD
848 yyss = yyss1;
849 yyvs = yyvs1;
850 }
10fa2066 851#else /* no yyoverflow */
cf44a9ae
PE
852# ifndef YYSTACK_RELOCATE
853 goto yyoverflowlab;
854# else
10fa2066 855 /* Extend the stack our own way. */
39912f52 856 if (YYMAXDEPTH <= yystacksize)
600f9b0c 857 goto yyoverflowlab;
10fa2066 858 yystacksize *= 2;
39912f52 859 if (YYMAXDEPTH < yystacksize)
10fa2066 860 yystacksize = YYMAXDEPTH;
e9e4c321 861
600f9b0c
PE
862 {
863 short *yyss1 = yyss;
2729e106
PE
864 union yyalloc *yyptr =
865 (union yyalloc *) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize));
600f9b0c
PE
866 if (! yyptr)
867 goto yyoverflowlab;
5b041382
PE
868 YYSTACK_RELOCATE (yyss);
869 YYSTACK_RELOCATE (yyvs);
58612f1d 870]b4_location_if([ YYSTACK_RELOCATE (yyls);])[
cf44a9ae 871# undef YYSTACK_RELOCATE
600f9b0c
PE
872 if (yyss1 != yyssa)
873 YYSTACK_FREE (yyss1);
874 }
cf44a9ae 875# endif
10fa2066
RS
876#endif /* no yyoverflow */
877
7093d0f5
AD
878 yyssp = yyss + yysize - 1;
879 yyvsp = yyvs + yysize - 1;
58612f1d 880]b4_location_if([ yylsp = yyls + yysize - 1;])[
10fa2066 881
7ea5e977 882 YYDPRINTF ((stderr, "Stack size increased to %lu\n",
600f9b0c 883 (unsigned long int) yystacksize));
10fa2066 884
39912f52 885 if (yyss + yystacksize - 1 <= yyssp)
10fa2066
RS
886 YYABORT;
887 }
888
7ea5e977 889 YYDPRINTF ((stderr, "Entering state %d\n", yystate));
10fa2066
RS
890
891 goto yybackup;
71da9eea 892
71da9eea
AD
893/*-----------.
894| yybackup. |
895`-----------*/
896yybackup:
10fa2066
RS
897
898/* Do appropriate processing given the current state. */
899/* Read a lookahead token if we need one and don't already have one. */
900/* yyresume: */
901
902 /* First try to decide what to do without reference to lookahead token. */
903
904 yyn = yypact[yystate];
12b0043a 905 if (yyn == YYPACT_NINF)
10fa2066
RS
906 goto yydefault;
907
908 /* Not known => get a lookahead token if don't already have one. */
909
a20713a4
PE
910 /* YYCHAR is either YYEMPTY or YYEOF or a valid lookahead symbol. */
911 if (yychar == YYEMPTY)
10fa2066 912 {
7ea5e977 913 YYDPRINTF ((stderr, "Reading a token: "));
17da6427 914 yychar = YYLEX;
10fa2066
RS
915 }
916
a20713a4 917 if (yychar <= YYEOF)
10fa2066 918 {
a20713a4 919 yychar = yytoken = YYEOF;
7ea5e977 920 YYDPRINTF ((stderr, "Now at end of input.\n"));
10fa2066
RS
921 }
922 else
923 {
a20713a4 924 yytoken = YYTRANSLATE (yychar);
9c1e26bd 925 YYDSYMPRINTF ("Next token is", yytoken, &yylval, &yylloc);
10fa2066
RS
926 }
927
b0400cc6 928 /* If the proper action on seeing token YYTOKEN is to reduce or to
e5cfd9d8 929 detect an error, take that action. */
b0400cc6
AD
930 yyn += yytoken;
931 if (yyn < 0 || YYLAST < yyn || yycheck[yyn] != yytoken)
e5cfd9d8
PE
932 goto yydefault;
933 yyn = yytable[yyn];
934 if (yyn <= 0)
10fa2066 935 {
e5cfd9d8
PE
936 if (yyn == 0 || yyn == YYTABLE_NINF)
937 goto yyerrlab;
10fa2066
RS
938 yyn = -yyn;
939 goto yyreduce;
940 }
10fa2066
RS
941
942 if (yyn == YYFINAL)
943 YYACCEPT;
944
945 /* Shift the lookahead token. */
9c1e26bd 946 YYDPRINTF ((stderr, "Shifting token %s, ", yytname[yytoken]));
10fa2066
RS
947
948 /* Discard the token being shifted unless it is eof. */
a20713a4
PE
949 if (yychar != YYEOF)
950 yychar = YYEMPTY;
10fa2066 951
17da6427 952 *++yyvsp = yylval;
58612f1d 953]b4_location_if([ *++yylsp = yylloc;])[
10fa2066 954
71da9eea
AD
955 /* Count tokens shifted since error; after three, turn off error
956 status. */
957 if (yyerrstatus)
958 yyerrstatus--;
10fa2066
RS
959
960 yystate = yyn;
961 goto yynewstate;
962
10fa2066 963
71da9eea
AD
964/*-----------------------------------------------------------.
965| yydefault -- do the default action for the current state. |
966`-----------------------------------------------------------*/
967yydefault:
10fa2066
RS
968 yyn = yydefact[yystate];
969 if (yyn == 0)
970 goto yyerrlab;
71da9eea 971 goto yyreduce;
10fa2066 972
71da9eea
AD
973
974/*-----------------------------.
975| yyreduce -- Do a reduction. |
976`-----------------------------*/
10fa2066 977yyreduce:
71da9eea 978 /* yyn is the number of a rule to reduce with. */
10fa2066 979 yylen = yyr2[yyn];
da9abf43
AD
980
981 /* If YYLEN is nonzero, implement the default value of the action:
573c1d9f 982 `$$ = $1'.
da9abf43 983
accea6db
PE
984 Otherwise, the following line sets YYVAL to garbage.
985 This behavior is undocumented and Bison
da9abf43
AD
986 users should not rely upon it. Assigning to YYVAL
987 unconditionally makes the parser a bit smaller, and it avoids a
988 GCC warning that YYVAL may be used uninitialized. */
989 yyval = yyvsp[1-yylen];
3abcd459 990
58612f1d
AD
991]b4_location_if(
992[ /* Default location. */
0ae99356 993 YYLLOC_DEFAULT (yyloc, yylsp - yylen, yylen);])[
b0937b22 994 YY_REDUCE_PRINT (yyn);
a8289c62 995 switch (yyn)
be2a1a68
AD
996 ]{
997 b4_actions
a8289c62 998 }
897668ee 999
996b1c7e 1000/* Line __line__ of yacc.c. */
947427ae 1001b4_syncline([@oline@], [@ofile@])
10fa2066 1002\f
be2a1a68 1003[ yyvsp -= yylen;
10fa2066 1004 yyssp -= yylen;
58612f1d 1005]b4_location_if([ yylsp -= yylen;])[
10fa2066 1006
b0937b22 1007 YY_STACK_PRINT (yyss, yyssp);
10fa2066
RS
1008
1009 *++yyvsp = yyval;
58612f1d 1010]b4_location_if([ *++yylsp = yyloc;])[
10fa2066 1011
41aca2e0
AD
1012 /* Now `shift' the result of the reduction. Determine what state
1013 that goes to, based on the state we popped back to and the rule
1014 number reduced by. */
10fa2066
RS
1015
1016 yyn = yyr1[yyn];
1017
7742ddeb 1018 yystate = yypgoto[yyn - YYNTOKENS] + *yyssp;
12b0043a 1019 if (0 <= yystate && yystate <= YYLAST && yycheck[yystate] == *yyssp)
10fa2066
RS
1020 yystate = yytable[yystate];
1021 else
7742ddeb 1022 yystate = yydefgoto[yyn - YYNTOKENS];
10fa2066
RS
1023
1024 goto yynewstate;
1025
10fa2066 1026
71da9eea
AD
1027/*------------------------------------.
1028| yyerrlab -- here on detecting error |
1029`------------------------------------*/
1030yyerrlab:
1031 /* If not already recovering from an error, report this error. */
1032 if (!yyerrstatus)
10fa2066 1033 {
17da6427 1034 ++yynerrs;
df5aed8c
PE
1035#if YYERROR_VERBOSE
1036 yyn = yypact[yystate];
1037
1038 if (YYPACT_NINF < yyn && yyn < YYLAST)
1039 {
1040 YYSIZE_T yysize = 0;
1041 int yytype = YYTRANSLATE (yychar);
c4749565 1042 const char* yyprefix;
df5aed8c 1043 char *yymsg;
3aa2f55d 1044 int yyx;
df5aed8c 1045
df5aed8c
PE
1046 /* Start YYX at -YYN if negative to avoid negative indexes in
1047 YYCHECK. */
c4749565 1048 int yyxbegin = yyn < 0 ? -yyn : 0;
3aa2f55d
PE
1049
1050 /* Stay within bounds of both yycheck and yytname. */
1051 int yychecklim = YYLAST - yyn;
c4749565 1052 int yyxend = yychecklim < YYNTOKENS ? yychecklim : YYNTOKENS;
3aa2f55d
PE
1053 int yycount = 0;
1054
c4749565
AD
1055 yyprefix = ", expecting ";
1056 for (yyx = yyxbegin; yyx < yyxend; ++yyx)
df5aed8c 1057 if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR)
3aa2f55d 1058 {
c4749565
AD
1059 yysize += yystrlen (yyprefix) + yystrlen (yytname [yyx]);
1060 yycount += 1;
3aa2f55d
PE
1061 if (yycount == 5)
1062 {
1063 yysize = 0;
1064 break;
c4749565 1065 }
3aa2f55d
PE
1066 }
1067 yysize += (sizeof ("syntax error, unexpected ")
1068 + yystrlen (yytname[yytype]));
df5aed8c
PE
1069 yymsg = (char *) YYSTACK_ALLOC (yysize);
1070 if (yymsg != 0)
1071 {
6e649e65 1072 char *yyp = yystpcpy (yymsg, "syntax error, unexpected ");
df5aed8c
PE
1073 yyp = yystpcpy (yyp, yytname[yytype]);
1074
1075 if (yycount < 5)
1076 {
c4749565
AD
1077 yyprefix = ", expecting ";
1078 for (yyx = yyxbegin; yyx < yyxend; ++yyx)
df5aed8c
PE
1079 if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR)
1080 {
c4749565 1081 yyp = yystpcpy (yyp, yyprefix);
df5aed8c 1082 yyp = yystpcpy (yyp, yytname[yyx]);
c4749565 1083 yyprefix = " or ";
df5aed8c
PE
1084 }
1085 }
93724f13 1086 yyerror (]b4_yyerror_args[yymsg);
df5aed8c
PE
1087 YYSTACK_FREE (yymsg);
1088 }
1089 else
6e649e65 1090 yyerror (]b4_yyerror_args["syntax error; also virtual memory exhausted");
df5aed8c
PE
1091 }
1092 else
1093#endif /* YYERROR_VERBOSE */
6e649e65 1094 yyerror (]b4_yyerror_args["syntax error");
10fa2066 1095 }
71da9eea 1096
d42f69cd
PE
1097]b4_location_if([ yylerrsp = yylsp;])[
1098
10fa2066
RS
1099 if (yyerrstatus == 3)
1100 {
71da9eea
AD
1101 /* If just tried and failed to reuse lookahead token after an
1102 error, discard it. */
10fa2066 1103
a6b89bb2 1104 if (yychar <= YYEOF)
5719c109 1105 {
a6b89bb2
PE
1106 /* If at end of input, pop the error token,
1107 then the rest of the stack, then return failure. */
1108 if (yychar == YYEOF)
1109 for (;;)
1110 {
1111 YYPOPSTACK;
1112 if (yyssp == yyss)
1113 YYABORT;
1114 YYDSYMPRINTF ("Error: popping", yystos[*yyssp], yyvsp, yylsp);
1115 yydestruct (yystos[*yyssp], yyvsp]b4_location_if([, yylsp])[);
1116 }
5719c109 1117 }
a6b89bb2
PE
1118 else
1119 {
1120 YYDSYMPRINTF ("Error: discarding", yytoken, &yylval, &yylloc);
1121 yydestruct (yytoken, &yylval]b4_location_if([, &yylloc])[);
1122 yychar = YYEMPTY;
1123]b4_location_if([ *++yylerrsp = yylloc;])[
1124 }
10fa2066
RS
1125 }
1126
71da9eea
AD
1127 /* Else will try to reuse lookahead token after shifting the error
1128 token. */
8a3eb3c8 1129 goto yyerrlab1;
300a7966 1130
10fa2066 1131
a6b89bb2
PE
1132/*---------------------------------------------------.
1133| yyerrorlab -- error raised explicitly by YYERROR. |
1134`---------------------------------------------------*/
1135yyerrorlab:
1136
1137#ifdef __GNUC__
1138 /* Pacify GCC when the user code never invokes YYERROR and the label
1139 yyerrorlab therefore never appears in user code. */
1140 if (0)
1141 goto yyerrorlab;
1142#endif
1143
1144 yyvsp -= yylen;
1145 yyssp -= yylen;
1146 yystate = *yyssp;
1147 ]b4_location_if([yylerrsp = yylsp;
1148 *++yylerrsp = yyloc;
1149 yylsp -= yylen;
1150 ])[goto yyerrlab1;
1151
1152
1153/*-------------------------------------------------------------.
1154| yyerrlab1 -- common code for both syntax error and YYERROR. |
1155`-------------------------------------------------------------*/
300a7966 1156yyerrlab1:
cf44a9ae 1157 yyerrstatus = 3; /* Each real token shifted decrements this. */
10fa2066 1158
660bc8dd
PE
1159 for (;;)
1160 {
1161 yyn = yypact[yystate];
12b0043a 1162 if (yyn != YYPACT_NINF)
660bc8dd
PE
1163 {
1164 yyn += YYTERROR;
1165 if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR)
1166 {
1167 yyn = yytable[yyn];
1168 if (0 < yyn)
1169 break;
1170 }
1171 }
10fa2066 1172
660bc8dd
PE
1173 /* Pop the current state because it cannot handle the error token. */
1174 if (yyssp == yyss)
1175 YYABORT;
5504898e 1176
9c1e26bd 1177 YYDSYMPRINTF ("Error: popping", yystos[*yyssp], yyvsp, yylsp);
7bd6c77e 1178 yydestruct (yystos[yystate], yyvsp]b4_location_if([, yylsp])[);
a6b89bb2
PE
1179 YYPOPSTACK;
1180 yystate = *yyssp;
b0937b22 1181 YY_STACK_PRINT (yyss, yyssp);
10fa2066 1182 }
10fa2066
RS
1183
1184 if (yyn == YYFINAL)
1185 YYACCEPT;
1186
7ea5e977 1187 YYDPRINTF ((stderr, "Shifting error token, "));
10fa2066 1188
17da6427 1189 *++yyvsp = yylval;
0ae99356 1190]b4_location_if([ YYLLOC_DEFAULT (yyloc, yylsp, yylerrsp - yylsp);
d42f69cd 1191 *++yylsp = yyloc;])[
10fa2066
RS
1192
1193 yystate = yyn;
1194 goto yynewstate;
70ddf897 1195
71da9eea
AD
1196
1197/*-------------------------------------.
1198| yyacceptlab -- YYACCEPT comes here. |
1199`-------------------------------------*/
1200yyacceptlab:
600f9b0c
PE
1201 yyresult = 0;
1202 goto yyreturn;
71da9eea
AD
1203
1204/*-----------------------------------.
1205| yyabortlab -- YYABORT comes here. |
1206`-----------------------------------*/
1207yyabortlab:
600f9b0c
PE
1208 yyresult = 1;
1209 goto yyreturn;
1210
0bfb02ff 1211#ifndef yyoverflow
ca98bf57
AD
1212/*----------------------------------------------.
1213| yyoverflowlab -- parser overflow comes here. |
1214`----------------------------------------------*/
600f9b0c 1215yyoverflowlab:
93724f13 1216 yyerror (]b4_yyerror_args["parser stack overflow");
600f9b0c
PE
1217 yyresult = 2;
1218 /* Fall through. */
0bfb02ff 1219#endif
600f9b0c
PE
1220
1221yyreturn:
1222#ifndef yyoverflow
1223 if (yyss != yyssa)
1224 YYSTACK_FREE (yyss);
70ddf897 1225#endif
600f9b0c 1226 return yyresult;
be2a1a68
AD
1227]}
1228
24c0aad7 1229
be2a1a68
AD
1230b4_epilogue
1231m4_if(b4_defines_flag, 0, [],
947427ae 1232[@output @output_header_name@
c76e14da 1233b4_copyright([Skeleton parser for Yacc-like parsing with Bison],
c1a0d7e0 1234 [1984, 1989, 1990, 2000, 2001, 2002, 2003])
0252b55c
PE
1235
1236/* As a special exception, when this file is copied by Bison into a
1237 Bison output file, you may use that output file without restriction.
1238 This special exception was added by the Free Software Foundation
1239 in version 1.24 of Bison. */
c76e14da 1240
0d8bed56 1241b4_token_defines(b4_tokens)
be2a1a68 1242
050c471b 1243#if ! defined (YYSTYPE) && ! defined (YYSTYPE_IS_DECLARED)
e9955c83 1244m4_ifdef([b4_stype],
437c2d80 1245[b4_syncline([b4_stype_line], [b4_filename])
050c471b 1246typedef union m4_bregexp(b4_stype, [^{], [YYSTYPE ])b4_stype YYSTYPE;
996b1c7e 1247/* Line __line__ of yacc.c. */
947427ae 1248b4_syncline([@oline@], [@ofile@])],
050c471b
PE
1249[typedef int YYSTYPE;])
1250# define yystype YYSTYPE /* obsolescent; will be withdrawn */
1251# define YYSTYPE_IS_DECLARED 1
947427ae 1252# define YYSTYPE_IS_TRIVIAL 1
be2a1a68
AD
1253#endif
1254
74310291 1255b4_pure_if([],
be2a1a68
AD
1256[extern YYSTYPE b4_prefix[]lval;])
1257
58612f1d 1258b4_location_if(
050c471b
PE
1259[#if ! defined (YYLTYPE) && ! defined (YYLTYPE_IS_DECLARED)
1260typedef struct YYLTYPE
be2a1a68
AD
1261{
1262 int first_line;
1263 int first_column;
1264 int last_line;
1265 int last_column;
050c471b
PE
1266} YYLTYPE;
1267# define yyltype YYLTYPE /* obsolescent; will be withdrawn */
1268# define YYLTYPE_IS_DECLARED 1
1269# define YYLTYPE_IS_TRIVIAL 1
be2a1a68 1270#endif
ff48177d 1271
be2a1a68
AD
1272m4_if(b4_pure, [0],
1273[extern YYLTYPE b4_prefix[]lloc;])
1274])
be2a1a68 1275])