]> git.saurik.com Git - bison.git/blame - data/yacc.c
Include quote.h.
[bison.git] / data / yacc.c
CommitLineData
007a50a4 1m4_divert(-1) -*- C -*-
a8289c62 2
60491a94 3# Yacc compatible skeleton for Bison
12b0043a
AD
4# Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002
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# ------------
21964f43 57# Accumule 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
61b4_location_if([, [[YYLTYPE *], [&yylloc]]])])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],
9c1e26bd 137 [1984, 1989, 1990, 2000, 2001, 2002])[
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
AD
218
219/* The parser invokes alloca or malloc; define the necessary symbols. */
220
221# if YYSTACK_USE_ALLOCA
222# define YYSTACK_ALLOC alloca
7093d0f5
AD
223# else
224# ifndef YYSTACK_USE_ALLOCA
225# if defined (alloca) || defined (_ALLOCA_H)
226# define YYSTACK_ALLOC alloca
7093d0f5 227# else
0d8a7363 228# ifdef __GNUC__
7093d0f5
AD
229# define YYSTACK_ALLOC __builtin_alloca
230# endif
7093d0f5
AD
231# endif
232# endif
233# endif
234
235# ifdef YYSTACK_ALLOC
236 /* Pacify GCC's `empty if-body' warning. */
237# define YYSTACK_FREE(Ptr) do { /* empty */; } while (0)
238# else
45119af1
PE
239# if defined (__STDC__) || defined (__cplusplus)
240# include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
241# define YYSIZE_T size_t
7093d0f5 242# endif
45119af1
PE
243# define YYSTACK_ALLOC malloc
244# define YYSTACK_FREE free
7093d0f5 245# endif
cf44a9ae
PE
246#endif /* ! defined (yyoverflow) || YYERROR_VERBOSE */
247
248
249#if (! defined (yyoverflow) \
250 && (! defined (__cplusplus) \
1915f133 251 || (]b4_location_if([YYLTYPE_IS_TRIVIAL && ])[YYSTYPE_IS_TRIVIAL)))
7093d0f5 252
600f9b0c
PE
253/* A type that is properly aligned for any stack member. */
254union yyalloc
255{
2729e106
PE
256 short yyss;
257 YYSTYPE yyvs;
9c1e26bd 258 ]b4_location_if([ YYLTYPE yyls;
58612f1d 259])dnl
9c1e26bd 260[};
600f9b0c
PE
261
262/* The size of the maximum gap between one aligned stack and the next. */
17836590 263# define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1)
600f9b0c
PE
264
265/* The size of an array large to enough to hold all stacks, each with
266 N elements. */
9c1e26bd 267]b4_location_if(
58612f1d 268[# define YYSTACK_BYTES(N) \
cf44a9ae 269 ((N) * (sizeof (short) + sizeof (YYSTYPE) + sizeof (YYLTYPE)) \
17836590 270 + 2 * YYSTACK_GAP_MAXIMUM)],
58612f1d 271[# define YYSTACK_BYTES(N) \
cf44a9ae 272 ((N) * (sizeof (short) + sizeof (YYSTYPE)) \
17836590 273 + YYSTACK_GAP_MAXIMUM)])[
600f9b0c 274
5b041382
PE
275/* Copy COUNT objects from FROM to TO. The source and destination do
276 not overlap. */
277# ifndef YYCOPY
278# if 1 < __GNUC__
279# define YYCOPY(To, From, Count) \
280 __builtin_memcpy (To, From, (Count) * sizeof (*(From)))
281# else
282# define YYCOPY(To, From, Count) \
283 do \
284 { \
285 register YYSIZE_T yyi; \
286 for (yyi = 0; yyi < (Count); yyi++) \
9c1e26bd 287 (To)[yyi] = (From)[yyi]; \
5b041382
PE
288 } \
289 while (0)
290# endif
291# endif
292
293/* Relocate STACK from its old location to the new one. The
7093d0f5 294 local variables YYSIZE and YYSTACKSIZE give the old and new number of
600f9b0c
PE
295 elements in the stack, and YYPTR gives the new location of the
296 stack. Advance YYPTR to a properly aligned location for the next
297 stack. */
5b041382 298# define YYSTACK_RELOCATE(Stack) \
7093d0f5
AD
299 do \
300 { \
301 YYSIZE_T yynewbytes; \
5b041382 302 YYCOPY (&yyptr->Stack, Stack, yysize); \
2729e106 303 Stack = &yyptr->Stack; \
17836590 304 yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \
2729e106 305 yyptr += yynewbytes / sizeof (*yyptr); \
7093d0f5
AD
306 } \
307 while (0)
308
cf44a9ae 309#endif
8850be4b 310
768eb43f
PE
311#if defined (__STDC__) || defined (__cplusplus)
312 typedef signed char yysigned_char;
313#else
314 typedef short yysigned_char;
315#endif
316
7742ddeb 317/* YYFINAL -- State number of the termination state. */
9c1e26bd 318#define YYFINAL ]b4_final_state_number[
39912f52 319/* YYLAST -- Last index in YYTABLE. */
9c1e26bd 320#define YYLAST ]b4_last[
7742ddeb
AD
321
322/* YYNTOKENS -- Number of terminals. */
9c1e26bd 323#define YYNTOKENS ]b4_tokens_number[
7742ddeb 324/* YYNNTS -- Number of nonterminals. */
9c1e26bd 325#define YYNNTS ]b4_nterms_number[
7742ddeb 326/* YYNRULES -- Number of rules. */
9c1e26bd 327#define YYNRULES ]b4_rules_number[
7742ddeb 328/* YYNRULES -- Number of states. */
9c1e26bd 329#define YYNSTATES ]b4_states_number[
7742ddeb
AD
330
331/* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
9c1e26bd
AD
332#define YYUNDEFTOK ]b4_undef_token_number[
333#define YYMAXUTOK ]b4_user_token_number_max[
007a50a4 334
b0400cc6 335#define YYTRANSLATE(YYX) \
a20713a4 336 ((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK)
a8289c62 337
b0400cc6
AD
338/* YYTRANSLATE[YYLEX] -- Bison symbol number corresponding to YYLEX. */
339static const ]b4_int_type_for([b4_translate])[ yytranslate[] =
a8289c62 340{
c5e3e510 341 ]b4_translate[
a8289c62
RA
342};
343
344#if YYDEBUG
c5e3e510 345/* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in
7742ddeb 346 YYRHS. */
c5e3e510 347static const ]b4_int_type_for([b4_prhs])[ yyprhs[] =
a8289c62 348{
c5e3e510 349 ]b4_prhs[
a8289c62
RA
350};
351
3db472b9 352/* YYRHS -- A `-1'-separated list of the rules' RHS. */
c5e3e510 353static const ]b4_int_type_for([b4_rhs])[ yyrhs[] =
a8289c62 354{
c5e3e510 355 ]b4_rhs[
a8289c62
RA
356};
357
c5e3e510
AD
358/* YYRLINE[YYN] -- source line where rule number YYN was defined. */
359static const ]b4_int_type_for([b4_rline])[ yyrline[] =
a8289c62 360{
c5e3e510 361 ]b4_rline[
a8289c62
RA
362};
363#endif
364
5504898e 365#if YYDEBUG || YYERROR_VERBOSE
c5e3e510 366/* YYTNME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM.
7742ddeb 367 First, the terminals, then, starting at YYNTOKENS, nonterminals. */
c5e3e510 368static const char *const yytname[] =
a8289c62 369{
c5e3e510 370 ]b4_tname[
a8289c62
RA
371};
372#endif
373
c0ad8bf3 374# ifdef YYPRINT
c5e3e510 375/* YYTOKNUM[YYLEX-NUM] -- Internal token number corresponding to
769b430f 376 token YYLEX-NUM. */
c5e3e510 377static const ]b4_int_type_for([b4_toknum])[ yytoknum[] =
a8289c62 378{
c5e3e510 379 ]b4_toknum[
a8289c62 380};
c0ad8bf3 381# endif
a8289c62 382
c5e3e510
AD
383/* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */
384static const ]b4_int_type_for([b4_r1])[ yyr1[] =
a8289c62 385{
c5e3e510 386 ]b4_r1[
a8289c62
RA
387};
388
c5e3e510
AD
389/* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
390static const ]b4_int_type_for([b4_r2])[ yyr2[] =
a8289c62 391{
c5e3e510 392 ]b4_r2[
a8289c62
RA
393};
394
c5e3e510 395/* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state
5504898e
AD
396 STATE-NUM when YYTABLE doesn't specify something else to do. Zero
397 means the default is an error. */
c5e3e510 398static const ]b4_int_type_for([b4_defact])[ yydefact[] =
a8289c62 399{
c5e3e510 400 ]b4_defact[
a8289c62
RA
401};
402
c5e3e510
AD
403/* YYDEFGOTO[NTERM-NUM]. */
404static const ]b4_int_type_for([b4_defgoto])[ yydefgoto[] =
a8289c62 405{
c5e3e510 406 ]b4_defgoto[
a8289c62
RA
407};
408
c5e3e510 409/* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
7742ddeb 410 STATE-NUM. */
c5e3e510
AD
411#define YYPACT_NINF ]b4_pact_ninf[
412static const ]b4_int_type_for([b4_pact])[ yypact[] =
a8289c62 413{
c5e3e510 414 ]b4_pact[
a8289c62
RA
415};
416
c5e3e510
AD
417/* YYPGOTO[NTERM-NUM]. */
418static const ]b4_int_type_for([b4_pgoto])[ yypgoto[] =
a8289c62 419{
c5e3e510 420 ]b4_pgoto[
a8289c62
RA
421};
422
c5e3e510 423/* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If
7742ddeb 424 positive, shift that token. If negative, reduce the rule which
f50adbbd 425 number is the opposite. If zero, do what YYDEFACT says.
6e649e65 426 If YYTABLE_NINF, syntax error. */
c5e3e510
AD
427#define YYTABLE_NINF ]b4_table_ninf[
428static const ]b4_int_type_for([b4_table])[ yytable[] =
a8289c62 429{
c5e3e510 430 ]b4_table[
a8289c62
RA
431};
432
c5e3e510 433static const ]b4_int_type_for([b4_check])[ yycheck[] =
a8289c62 434{
c5e3e510 435 ]b4_check[
a8289c62
RA
436};
437
c5e3e510 438/* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
5504898e 439 symbol of state STATE-NUM. */
c5e3e510 440static const ]b4_int_type_for([b4_stos])[ yystos[] =
5504898e 441{
c5e3e510 442 ]b4_stos[
5504898e 443};
7093d0f5
AD
444
445#if ! defined (YYSIZE_T) && defined (__SIZE_TYPE__)
446# define YYSIZE_T __SIZE_TYPE__
447#endif
448#if ! defined (YYSIZE_T) && defined (size_t)
449# define YYSIZE_T size_t
450#endif
b7575ffe 451#if ! defined (YYSIZE_T)
45119af1
PE
452# if defined (__STDC__) || defined (__cplusplus)
453# include <stddef.h> /* INFRINGES ON USER NAME SPACE */
454# define YYSIZE_T size_t
b7575ffe 455# endif
7093d0f5
AD
456#endif
457#if ! defined (YYSIZE_T)
458# define YYSIZE_T unsigned int
459#endif
460
10fa2066 461#define yyerrok (yyerrstatus = 0)
a20713a4
PE
462#define yyclearin (yychar = YYEMPTY)
463#define YYEMPTY (-2)
10fa2066 464#define YYEOF 0
a8289c62 465
70ddf897 466#define YYACCEPT goto yyacceptlab
a8289c62 467#define YYABORT goto yyabortlab
10fa2066 468#define YYERROR goto yyerrlab1
a8289c62 469
71da9eea
AD
470/* Like YYERROR except do call yyerror. This remains here temporarily
471 to ease the transition to the new meaning of YYERROR, for GCC.
10fa2066 472 Once GCC version 2 has supplanted version 1, this can go. */
a8289c62 473
10fa2066 474#define YYFAIL goto yyerrlab
a8289c62 475
10fa2066 476#define YYRECOVERING() (!!yyerrstatus)
a8289c62 477
69b4e0c5 478#define YYBACKUP(Token, Value) \
10fa2066 479do \
a20713a4 480 if (yychar == YYEMPTY && yylen == 1) \
71da9eea 481 { \
17da6427 482 yychar = (Token); \
7742ddeb 483 yylval = (Value); \
b0400cc6 484 yytoken = YYTRANSLATE (yychar); \
10fa2066
RS
485 YYPOPSTACK; \
486 goto yybackup; \
487 } \
488 else \
71da9eea 489 { \
9c1e26bd 490 yyerror (]b4_yyerror_args["syntax error: cannot back up");\
71da9eea
AD
491 YYERROR; \
492 } \
10fa2066
RS
493while (0)
494
495#define YYTERROR 1
496#define YYERRCODE 256
497
3abcd459 498/* YYLLOC_DEFAULT -- Compute the default location (before the actions
b2d52318 499 are run). */
3abcd459
AD
500
501#ifndef YYLLOC_DEFAULT
9c1e26bd
AD
502# define YYLLOC_DEFAULT(Current, Rhs, N) \
503 Current.first_line = Rhs[1].first_line; \
504 Current.first_column = Rhs[1].first_column; \
505 Current.last_line = Rhs[N].last_line; \
506 Current.last_column = Rhs[N].last_column;
3abcd459
AD
507#endif
508
3abcd459 509/* YYLEX -- calling `yylex' with the right arguments. */
553e2b22 510
ae7453f2 511#ifdef YYLEX_PARAM
9c1e26bd 512# define YYLEX yylex (]b4_pure_if([&yylval[]b4_location_if([, &yylloc]), ])[YYLEX_PARAM)
74310291 513#else
9c1e26bd 514# define YYLEX ]b4_c_function_call([yylex], [int], b4_lex_param)[
ae7453f2 515#endif
553e2b22 516
5a35a6cb 517/* Enable debugging if requested. */
0d533154 518#if YYDEBUG
b7575ffe
PE
519
520# ifndef YYFPRINTF
45119af1
PE
521# include <stdio.h> /* INFRINGES ON USER NAME SPACE */
522# define YYFPRINTF fprintf
b7575ffe
PE
523# endif
524
5a35a6cb
AD
525# define YYDPRINTF(Args) \
526do { \
17da6427 527 if (yydebug) \
b7575ffe 528 YYFPRINTF Args; \
5a35a6cb 529} while (0)
c5e3e510 530
253862fd
AD
531# define YYDSYMPRINT(Args) \
532do { \
533 if (yydebug) \
534 yysymprint Args; \
535} while (0)
c5e3e510 536
9c1e26bd
AD
537# define YYDSYMPRINTF(Title, Token, Value, Location) \
538do { \
539 if (yydebug) \
540 { \
541 YYFPRINTF (stderr, "%s ", Title); \
542 yysymprint (stderr, \
543 Token, Value]b4_location_if([, Location])[); \
544 YYFPRINTF (stderr, "\n"); \
545 } \
546} while (0)
547
b0937b22
AD
548/*------------------------------------------------------------------.
549| yy_stack_print -- Print the state stack from its BOTTOM up to its |
550| TOP (cinluded). |
551`------------------------------------------------------------------*/
552
553]b4_c_function_def([yy_stack_print], [static void],
554 [[short *bottom], [bottom]],
555 [[short *top], [top]])[
556{
557 YYFPRINTF (stderr, "Stack now");
558 for (/* Nothing. */; bottom <= top; ++bottom)
559 YYFPRINTF (stderr, " %d", *bottom);
560 YYFPRINTF (stderr, "\n");
561}
562
563# define YY_STACK_PRINT(Bottom, Top) \
564do { \
565 if (yydebug) \
566 yy_stack_print ((Bottom), (Top)); \
567} while (0)
568
569
570/*------------------------------------------------.
571| Report that the YYRULE is going to be reduced. |
572`------------------------------------------------*/
573
574]b4_c_function_def([yy_reduce_print], [static void],
575 [[int yyrule], [yyrule]])[
576{
577 int yyi;
4f21fffe
PE
578 unsigned int yylineno = yyrline[yyrule];
579 YYFPRINTF (stderr, "Reducing stack by rule %d (line %u), ",
580 yyrule - 1, yylineno);
b0937b22
AD
581 /* Print the symbols being reduced, and their result. */
582 for (yyi = yyprhs[yyrule]; 0 <= yyrhs[yyi]; yyi++)
583 YYFPRINTF (stderr, "%s ", yytname [yyrhs[yyi]]);
584 YYFPRINTF (stderr, "-> %s\n", yytname [yyr1[yyrule]]);
585}
586
587# define YY_REDUCE_PRINT(Rule) \
588do { \
589 if (yydebug) \
590 yy_reduce_print (Rule); \
591} while (0)
592
cf44a9ae
PE
593/* Nonzero means print parse trace. It is left uninitialized so that
594 multiple parsers can coexist. */
17da6427 595int yydebug;
5a35a6cb
AD
596#else /* !YYDEBUG */
597# define YYDPRINTF(Args)
253862fd 598# define YYDSYMPRINT(Args)
9c1e26bd 599# define YYDSYMPRINTF(Title, Token, Value, Location)
b0937b22
AD
600# define YY_STACK_PRINT(Bottom, Top)
601# define YY_REDUCE_PRINT(Rule)
5a35a6cb
AD
602#endif /* !YYDEBUG */
603
b0937b22 604
5a35a6cb 605/* YYINITDEPTH -- initial size of the parser's stacks. */
10fa2066 606#ifndef YYINITDEPTH
9c1e26bd 607# define YYINITDEPTH ]b4_stack_depth_init[
10fa2066
RS
608#endif
609
5a35a6cb 610/* YYMAXDEPTH -- maximum size the stacks can grow to (effective only
600f9b0c
PE
611 if the built-in stack extension method is used).
612
613 Do not make this value too large; the results are undefined if
614 SIZE_MAX < YYSTACK_BYTES (YYMAXDEPTH)
615 evaluated with infinite-precision integer arithmetic. */
616
10fa2066 617#if YYMAXDEPTH == 0
b07b484a 618# undef YYMAXDEPTH
10fa2066
RS
619#endif
620
621#ifndef YYMAXDEPTH
9c1e26bd 622# define YYMAXDEPTH ]b4_stack_depth_max[
10fa2066 623#endif
a8289c62 624
10fa2066 625\f
a8289c62 626
7093d0f5
AD
627#if YYERROR_VERBOSE
628
629# ifndef yystrlen
630# if defined (__GLIBC__) && defined (_STRING_H)
631# define yystrlen strlen
632# else
633/* Return the length of YYSTR. */
634static YYSIZE_T
635# if defined (__STDC__) || defined (__cplusplus)
636yystrlen (const char *yystr)
637# else
638yystrlen (yystr)
639 const char *yystr;
640# endif
641{
642 register const char *yys = yystr;
643
644 while (*yys++ != '\0')
645 continue;
646
647 return yys - yystr - 1;
648}
649# endif
650# endif
651
652# ifndef yystpcpy
653# if defined (__GLIBC__) && defined (_STRING_H) && defined (_GNU_SOURCE)
654# define yystpcpy stpcpy
655# else
656/* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in
657 YYDEST. */
658static char *
f11966ff
PE
659# if defined (__STDC__) || defined (__cplusplus)
660yystpcpy (char *yydest, const char *yysrc)
661# else
7093d0f5
AD
662yystpcpy (yydest, yysrc)
663 char *yydest;
664 const char *yysrc;
7093d0f5
AD
665# endif
666{
667 register char *yyd = yydest;
668 register const char *yys = yysrc;
669
670 while ((*yyd++ = *yys++) != '\0')
671 continue;
672
673 return yyd - 1;
674}
675# endif
676# endif
677
678#endif /* !YYERROR_VERBOSE */
679
10fa2066 680\f
a8289c62 681
b8df3223 682#if YYDEBUG
9c1e26bd 683]b4_yysymprint_generate([b4_c_function_def])[
c5e3e510 684#endif /* ! YYDEBUG */
9c1e26bd 685]b4_yydestruct_generate([b4_c_function_def])
4a2a22f4
AD
686\f
687
0245f82d 688/* Prevent warnings from -Wmissing-prototypes. */
4a2a22f4
AD
689
690#ifdef YYPARSE_PARAM
691# if defined (__STDC__) || defined (__cplusplus)
0245f82d 692int yyparse (void *YYPARSE_PARAM);
4a2a22f4 693# else
0245f82d 694int yyparse ();
4a2a22f4 695# endif
0245f82d
AD
696#else /* ! YYPARSE_PARAM */
697b4_c_function_decl([yyparse], [int], b4_parse_param)
c5e3e510 698#endif /* ! YYPARSE_PARAM */
1b181651 699
0245f82d 700
74310291
AD
701m4_divert_push([KILL])# ======================== M4 code.
702# b4_declare_parser_variables
703# ---------------------------
704# Declare the variables that are global, or local to YYPARSE if
0245f82d 705# pure-parser.
74310291
AD
706m4_define([b4_declare_parser_variables],
707[/* The lookahead symbol. */
708int yychar;
709
710/* The semantic value of the lookahead symbol. */
711YYSTYPE yylval;
712
6e649e65 713/* Number of syntax errors so far. */
74310291
AD
714int yynerrs;b4_location_if([
715/* Location data for the lookahead symbol. */
58612f1d 716YYLTYPE yylloc;])
74310291
AD
717])
718m4_divert_pop([KILL])dnl# ====================== End of M4 code.
58612f1d 719
74310291
AD
720b4_pure_if([],
721 [b4_declare_parser_variables])
a35f64ea 722
0245f82d
AD
723
724/*----------.
725| yyparse. |
726`----------*/
727
728#ifdef YYPARSE_PARAM
729# if defined (__STDC__) || defined (__cplusplus)
730int yyparse (void *YYPARSE_PARAM)
731# else
732int yyparse (YYPARSE_PARAM)
733 void *YYPARSE_PARAM;
734# endif
735#else /* ! YYPARSE_PARAM */
736b4_c_function_def([yyparse], [int], b4_parse_param)
737#endif
be2a1a68 738{[
74310291 739 ]b4_pure_if([b4_declare_parser_variables])[
10fa2066
RS
740 register int yystate;
741 register int yyn;
600f9b0c 742 int yyresult;
b07b484a
AD
743 /* Number of tokens to shift before error messages enabled. */
744 int yyerrstatus;
745 /* Lookahead token as an internal (translated) token number. */
b0400cc6 746 int yytoken = 0;
10fa2066 747
bb10be54
AD
748 /* Three stacks and their tools:
749 `yyss': related to states,
e9e4c321 750 `yyvs': related to semantic values,
bb10be54
AD
751 `yyls': related to locations.
752
753 Refer to the stacks thru separate pointers, to allow yyoverflow
754 to reallocate them elsewhere. */
755
e8cb70b9 756 /* The state stack. */
b07b484a 757 short yyssa[YYINITDEPTH];
bb10be54
AD
758 short *yyss = yyssa;
759 register short *yyssp;
760
b07b484a
AD
761 /* The semantic value stack. */
762 YYSTYPE yyvsa[YYINITDEPTH];
b07b484a 763 YYSTYPE *yyvs = yyvsa;
bb10be54 764 register YYSTYPE *yyvsp;
10fa2066 765
58612f1d
AD
766]b4_location_if(
767[[ /* The location stack. */
b07b484a 768 YYLTYPE yylsa[YYINITDEPTH];
10fa2066 769 YYLTYPE *yyls = yylsa;
58612f1d 770 YYLTYPE *yylsp;]])[
10fa2066 771
58612f1d 772#define YYPOPSTACK (yyvsp--, yyssp--]b4_location_if([, yylsp--])[)
10fa2066 773
7093d0f5 774 YYSIZE_T yystacksize = YYINITDEPTH;
10fa2066 775
6666f98f
AD
776 /* The variables used to return semantic value and location from the
777 action routines. */
bb10be54 778 YYSTYPE yyval;
58612f1d 779]b4_location_if([ YYLTYPE yyloc;])[
10fa2066 780
6666f98f 781 /* When reducing, the number of symbols on the RHS of the reduced
e8cb70b9 782 rule. */
10fa2066
RS
783 int yylen;
784
7ea5e977 785 YYDPRINTF ((stderr, "Starting parse\n"));
10fa2066
RS
786
787 yystate = 0;
788 yyerrstatus = 0;
17da6427 789 yynerrs = 0;
a20713a4 790 yychar = YYEMPTY; /* Cause a token to be read. */
10fa2066
RS
791
792 /* Initialize stack pointers.
793 Waste one element of value and location stack
794 so that they stay on the same level as the state stack.
795 The wasted elements are never initialized. */
796
cbd89906 797 yyssp = yyss;
10fa2066 798 yyvsp = yyvs;
58612f1d 799]b4_location_if([ yylsp = yyls;])[
cbd89906 800 goto yysetstate;
10fa2066 801
71da9eea
AD
802/*------------------------------------------------------------.
803| yynewstate -- Push a new state, which is found in yystate. |
804`------------------------------------------------------------*/
342b8b6e 805 yynewstate:
71da9eea
AD
806 /* In all cases, when you get here, the value and location stacks
807 have just been pushed. so pushing a state here evens the stacks.
808 */
cbd89906
PE
809 yyssp++;
810
342b8b6e 811 yysetstate:
cbd89906 812 *yyssp = yystate;
10fa2066 813
39912f52 814 if (yyss + yystacksize - 1 <= yyssp)
10fa2066 815 {
10fa2066 816 /* Get the current used size of the three stacks, in elements. */
7093d0f5 817 YYSIZE_T yysize = yyssp - yyss + 1;
10fa2066
RS
818
819#ifdef yyoverflow
3d76b07d
AD
820 {
821 /* Give user a chance to reallocate the stack. Use copies of
822 these so that the &'s don't force the real ones into
823 memory. */
824 YYSTYPE *yyvs1 = yyvs;
825 short *yyss1 = yyss;
58612f1d 826]b4_location_if([ YYLTYPE *yyls1 = yyls;])[
3d76b07d
AD
827
828 /* Each stack pointer address is followed by the size of the
58612f1d
AD
829 data in use in that stack, in bytes. This used to be a
830 conditional around just the two extra args, but that might
831 be undefined if yyoverflow is a macro. */
3d76b07d 832 yyoverflow ("parser stack overflow",
7093d0f5
AD
833 &yyss1, yysize * sizeof (*yyssp),
834 &yyvs1, yysize * sizeof (*yyvsp),
58612f1d 835]b4_location_if([ &yyls1, yysize * sizeof (*yylsp),])[
3d76b07d 836 &yystacksize);
58612f1d 837]b4_location_if([ yyls = yyls1;])[
3d76b07d
AD
838 yyss = yyss1;
839 yyvs = yyvs1;
840 }
10fa2066 841#else /* no yyoverflow */
cf44a9ae
PE
842# ifndef YYSTACK_RELOCATE
843 goto yyoverflowlab;
844# else
10fa2066 845 /* Extend the stack our own way. */
39912f52 846 if (YYMAXDEPTH <= yystacksize)
600f9b0c 847 goto yyoverflowlab;
10fa2066 848 yystacksize *= 2;
39912f52 849 if (YYMAXDEPTH < yystacksize)
10fa2066 850 yystacksize = YYMAXDEPTH;
e9e4c321 851
600f9b0c
PE
852 {
853 short *yyss1 = yyss;
2729e106
PE
854 union yyalloc *yyptr =
855 (union yyalloc *) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize));
600f9b0c
PE
856 if (! yyptr)
857 goto yyoverflowlab;
5b041382
PE
858 YYSTACK_RELOCATE (yyss);
859 YYSTACK_RELOCATE (yyvs);
58612f1d 860]b4_location_if([ YYSTACK_RELOCATE (yyls);])[
cf44a9ae 861# undef YYSTACK_RELOCATE
600f9b0c
PE
862 if (yyss1 != yyssa)
863 YYSTACK_FREE (yyss1);
864 }
cf44a9ae 865# endif
10fa2066
RS
866#endif /* no yyoverflow */
867
7093d0f5
AD
868 yyssp = yyss + yysize - 1;
869 yyvsp = yyvs + yysize - 1;
58612f1d 870]b4_location_if([ yylsp = yyls + yysize - 1;])[
10fa2066 871
7ea5e977 872 YYDPRINTF ((stderr, "Stack size increased to %lu\n",
600f9b0c 873 (unsigned long int) yystacksize));
10fa2066 874
39912f52 875 if (yyss + yystacksize - 1 <= yyssp)
10fa2066
RS
876 YYABORT;
877 }
878
7ea5e977 879 YYDPRINTF ((stderr, "Entering state %d\n", yystate));
10fa2066
RS
880
881 goto yybackup;
71da9eea 882
71da9eea
AD
883/*-----------.
884| yybackup. |
885`-----------*/
886yybackup:
10fa2066
RS
887
888/* Do appropriate processing given the current state. */
889/* Read a lookahead token if we need one and don't already have one. */
890/* yyresume: */
891
892 /* First try to decide what to do without reference to lookahead token. */
893
894 yyn = yypact[yystate];
12b0043a 895 if (yyn == YYPACT_NINF)
10fa2066
RS
896 goto yydefault;
897
898 /* Not known => get a lookahead token if don't already have one. */
899
a20713a4
PE
900 /* YYCHAR is either YYEMPTY or YYEOF or a valid lookahead symbol. */
901 if (yychar == YYEMPTY)
10fa2066 902 {
7ea5e977 903 YYDPRINTF ((stderr, "Reading a token: "));
17da6427 904 yychar = YYLEX;
10fa2066
RS
905 }
906
a20713a4 907 if (yychar <= YYEOF)
10fa2066 908 {
a20713a4 909 yychar = yytoken = YYEOF;
7ea5e977 910 YYDPRINTF ((stderr, "Now at end of input.\n"));
10fa2066
RS
911 }
912 else
913 {
a20713a4 914 yytoken = YYTRANSLATE (yychar);
9c1e26bd 915 YYDSYMPRINTF ("Next token is", yytoken, &yylval, &yylloc);
10fa2066
RS
916 }
917
b0400cc6 918 /* If the proper action on seeing token YYTOKEN is to reduce or to
e5cfd9d8 919 detect an error, take that action. */
b0400cc6
AD
920 yyn += yytoken;
921 if (yyn < 0 || YYLAST < yyn || yycheck[yyn] != yytoken)
e5cfd9d8
PE
922 goto yydefault;
923 yyn = yytable[yyn];
924 if (yyn <= 0)
10fa2066 925 {
e5cfd9d8
PE
926 if (yyn == 0 || yyn == YYTABLE_NINF)
927 goto yyerrlab;
10fa2066
RS
928 yyn = -yyn;
929 goto yyreduce;
930 }
10fa2066
RS
931
932 if (yyn == YYFINAL)
933 YYACCEPT;
934
935 /* Shift the lookahead token. */
9c1e26bd 936 YYDPRINTF ((stderr, "Shifting token %s, ", yytname[yytoken]));
10fa2066
RS
937
938 /* Discard the token being shifted unless it is eof. */
a20713a4
PE
939 if (yychar != YYEOF)
940 yychar = YYEMPTY;
10fa2066 941
17da6427 942 *++yyvsp = yylval;
58612f1d 943]b4_location_if([ *++yylsp = yylloc;])[
10fa2066 944
71da9eea
AD
945 /* Count tokens shifted since error; after three, turn off error
946 status. */
947 if (yyerrstatus)
948 yyerrstatus--;
10fa2066
RS
949
950 yystate = yyn;
951 goto yynewstate;
952
10fa2066 953
71da9eea
AD
954/*-----------------------------------------------------------.
955| yydefault -- do the default action for the current state. |
956`-----------------------------------------------------------*/
957yydefault:
10fa2066
RS
958 yyn = yydefact[yystate];
959 if (yyn == 0)
960 goto yyerrlab;
71da9eea 961 goto yyreduce;
10fa2066 962
71da9eea
AD
963
964/*-----------------------------.
965| yyreduce -- Do a reduction. |
966`-----------------------------*/
10fa2066 967yyreduce:
71da9eea 968 /* yyn is the number of a rule to reduce with. */
10fa2066 969 yylen = yyr2[yyn];
da9abf43
AD
970
971 /* If YYLEN is nonzero, implement the default value of the action:
573c1d9f 972 `$$ = $1'.
da9abf43 973
accea6db
PE
974 Otherwise, the following line sets YYVAL to garbage.
975 This behavior is undocumented and Bison
da9abf43
AD
976 users should not rely upon it. Assigning to YYVAL
977 unconditionally makes the parser a bit smaller, and it avoids a
978 GCC warning that YYVAL may be used uninitialized. */
979 yyval = yyvsp[1-yylen];
3abcd459 980
58612f1d
AD
981]b4_location_if(
982[ /* Default location. */
983 YYLLOC_DEFAULT (yyloc, (yylsp - yylen), yylen);])[
b0937b22 984 YY_REDUCE_PRINT (yyn);
a8289c62 985 switch (yyn)
be2a1a68
AD
986 ]{
987 b4_actions
a8289c62 988 }
897668ee 989
996b1c7e 990/* Line __line__ of yacc.c. */
947427ae 991b4_syncline([@oline@], [@ofile@])
10fa2066 992\f
be2a1a68 993[ yyvsp -= yylen;
10fa2066 994 yyssp -= yylen;
58612f1d 995]b4_location_if([ yylsp -= yylen;])[
10fa2066 996
b0937b22 997 YY_STACK_PRINT (yyss, yyssp);
10fa2066
RS
998
999 *++yyvsp = yyval;
58612f1d 1000]b4_location_if([ *++yylsp = yyloc;])[
10fa2066 1001
41aca2e0
AD
1002 /* Now `shift' the result of the reduction. Determine what state
1003 that goes to, based on the state we popped back to and the rule
1004 number reduced by. */
10fa2066
RS
1005
1006 yyn = yyr1[yyn];
1007
7742ddeb 1008 yystate = yypgoto[yyn - YYNTOKENS] + *yyssp;
12b0043a 1009 if (0 <= yystate && yystate <= YYLAST && yycheck[yystate] == *yyssp)
10fa2066
RS
1010 yystate = yytable[yystate];
1011 else
7742ddeb 1012 yystate = yydefgoto[yyn - YYNTOKENS];
10fa2066
RS
1013
1014 goto yynewstate;
1015
10fa2066 1016
71da9eea
AD
1017/*------------------------------------.
1018| yyerrlab -- here on detecting error |
1019`------------------------------------*/
1020yyerrlab:
1021 /* If not already recovering from an error, report this error. */
1022 if (!yyerrstatus)
10fa2066 1023 {
17da6427 1024 ++yynerrs;
df5aed8c
PE
1025#if YYERROR_VERBOSE
1026 yyn = yypact[yystate];
1027
1028 if (YYPACT_NINF < yyn && yyn < YYLAST)
1029 {
1030 YYSIZE_T yysize = 0;
1031 int yytype = YYTRANSLATE (yychar);
1032 char *yymsg;
1033 int yyx, yycount;
1034
1035 yycount = 0;
1036 /* Start YYX at -YYN if negative to avoid negative indexes in
1037 YYCHECK. */
1038 for (yyx = yyn < 0 ? -yyn : 0;
1039 yyx < (int) (sizeof (yytname) / sizeof (char *)); yyx++)
1040 if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR)
1041 yysize += yystrlen (yytname[yyx]) + 15, yycount++;
6e649e65 1042 yysize += yystrlen ("syntax error, unexpected ") + 1;
df5aed8c
PE
1043 yysize += yystrlen (yytname[yytype]);
1044 yymsg = (char *) YYSTACK_ALLOC (yysize);
1045 if (yymsg != 0)
1046 {
6e649e65 1047 char *yyp = yystpcpy (yymsg, "syntax error, unexpected ");
df5aed8c
PE
1048 yyp = yystpcpy (yyp, yytname[yytype]);
1049
1050 if (yycount < 5)
1051 {
1052 yycount = 0;
1053 for (yyx = yyn < 0 ? -yyn : 0;
1054 yyx < (int) (sizeof (yytname) / sizeof (char *));
1055 yyx++)
1056 if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR)
1057 {
1058 const char *yyq = ! yycount ? ", expecting " : " or ";
1059 yyp = yystpcpy (yyp, yyq);
1060 yyp = yystpcpy (yyp, yytname[yyx]);
1061 yycount++;
1062 }
1063 }
93724f13 1064 yyerror (]b4_yyerror_args[yymsg);
df5aed8c
PE
1065 YYSTACK_FREE (yymsg);
1066 }
1067 else
6e649e65 1068 yyerror (]b4_yyerror_args["syntax error; also virtual memory exhausted");
df5aed8c
PE
1069 }
1070 else
1071#endif /* YYERROR_VERBOSE */
6e649e65 1072 yyerror (]b4_yyerror_args["syntax error");
10fa2066 1073 }
71da9eea 1074
10fa2066
RS
1075 if (yyerrstatus == 3)
1076 {
71da9eea
AD
1077 /* If just tried and failed to reuse lookahead token after an
1078 error, discard it. */
10fa2066 1079
e8cb70b9 1080 /* Return failure if at end of input. */
a20713a4 1081 if (yychar == YYEOF)
5719c109
AD
1082 {
1083 /* Pop the error token. */
1084 YYPOPSTACK;
1085 /* Pop the rest of the stack. */
39912f52 1086 while (yyss < yyssp)
5719c109 1087 {
9c1e26bd 1088 YYDSYMPRINTF ("Error: popping", yystos[*yyssp], yyvsp, yylsp);
7bd6c77e 1089 yydestruct (yystos[*yyssp], yyvsp]b4_location_if([, yylsp])[);
5719c109
AD
1090 YYPOPSTACK;
1091 }
1092 YYABORT;
1093 }
1094
9c1e26bd 1095 YYDSYMPRINTF ("Error: discarding", yytoken, &yylval, &yylloc);
7bd6c77e 1096 yydestruct (yytoken, &yylval]b4_location_if([, &yylloc])[);
a20713a4 1097 yychar = YYEMPTY;
10fa2066
RS
1098 }
1099
71da9eea
AD
1100 /* Else will try to reuse lookahead token after shifting the error
1101 token. */
300a7966
PE
1102 goto yyerrlab1;
1103
10fa2066 1104
300a7966
PE
1105/*----------------------------------------------------.
1106| yyerrlab1 -- error raised explicitly by an action. |
1107`----------------------------------------------------*/
1108yyerrlab1:
cf44a9ae 1109 yyerrstatus = 3; /* Each real token shifted decrements this. */
10fa2066 1110
660bc8dd
PE
1111 for (;;)
1112 {
1113 yyn = yypact[yystate];
12b0043a 1114 if (yyn != YYPACT_NINF)
660bc8dd
PE
1115 {
1116 yyn += YYTERROR;
1117 if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR)
1118 {
1119 yyn = yytable[yyn];
1120 if (0 < yyn)
1121 break;
1122 }
1123 }
10fa2066 1124
660bc8dd
PE
1125 /* Pop the current state because it cannot handle the error token. */
1126 if (yyssp == yyss)
1127 YYABORT;
5504898e 1128
9c1e26bd 1129 YYDSYMPRINTF ("Error: popping", yystos[*yyssp], yyvsp, yylsp);
7bd6c77e 1130 yydestruct (yystos[yystate], yyvsp]b4_location_if([, yylsp])[);
660bc8dd
PE
1131 yyvsp--;
1132 yystate = *--yyssp;
58612f1d 1133]b4_location_if([ yylsp--;])[
b0937b22 1134 YY_STACK_PRINT (yyss, yyssp);
10fa2066 1135 }
10fa2066
RS
1136
1137 if (yyn == YYFINAL)
1138 YYACCEPT;
1139
7ea5e977 1140 YYDPRINTF ((stderr, "Shifting error token, "));
10fa2066 1141
17da6427 1142 *++yyvsp = yylval;
58612f1d 1143]b4_location_if([ *++yylsp = yylloc;])[
10fa2066
RS
1144
1145 yystate = yyn;
1146 goto yynewstate;
70ddf897 1147
71da9eea
AD
1148
1149/*-------------------------------------.
1150| yyacceptlab -- YYACCEPT comes here. |
1151`-------------------------------------*/
1152yyacceptlab:
600f9b0c
PE
1153 yyresult = 0;
1154 goto yyreturn;
71da9eea
AD
1155
1156/*-----------------------------------.
1157| yyabortlab -- YYABORT comes here. |
1158`-----------------------------------*/
1159yyabortlab:
600f9b0c
PE
1160 yyresult = 1;
1161 goto yyreturn;
1162
0bfb02ff 1163#ifndef yyoverflow
ca98bf57
AD
1164/*----------------------------------------------.
1165| yyoverflowlab -- parser overflow comes here. |
1166`----------------------------------------------*/
600f9b0c 1167yyoverflowlab:
93724f13 1168 yyerror (]b4_yyerror_args["parser stack overflow");
600f9b0c
PE
1169 yyresult = 2;
1170 /* Fall through. */
0bfb02ff 1171#endif
600f9b0c
PE
1172
1173yyreturn:
1174#ifndef yyoverflow
1175 if (yyss != yyssa)
1176 YYSTACK_FREE (yyss);
70ddf897 1177#endif
600f9b0c 1178 return yyresult;
be2a1a68
AD
1179]}
1180
24c0aad7 1181
be2a1a68
AD
1182b4_epilogue
1183m4_if(b4_defines_flag, 0, [],
947427ae 1184[@output @output_header_name@
c76e14da 1185b4_copyright([Skeleton parser for Yacc-like parsing with Bison],
0252b55c
PE
1186 [1984, 1989, 1990, 2000, 2001, 2002])
1187
1188/* As a special exception, when this file is copied by Bison into a
1189 Bison output file, you may use that output file without restriction.
1190 This special exception was added by the Free Software Foundation
1191 in version 1.24 of Bison. */
c76e14da 1192
0d8bed56 1193b4_token_defines(b4_tokens)
be2a1a68 1194
050c471b 1195#if ! defined (YYSTYPE) && ! defined (YYSTYPE_IS_DECLARED)
e9955c83 1196m4_ifdef([b4_stype],
437c2d80 1197[b4_syncline([b4_stype_line], [b4_filename])
050c471b 1198typedef union m4_bregexp(b4_stype, [^{], [YYSTYPE ])b4_stype YYSTYPE;
996b1c7e 1199/* Line __line__ of yacc.c. */
947427ae 1200b4_syncline([@oline@], [@ofile@])],
050c471b
PE
1201[typedef int YYSTYPE;])
1202# define yystype YYSTYPE /* obsolescent; will be withdrawn */
1203# define YYSTYPE_IS_DECLARED 1
947427ae 1204# define YYSTYPE_IS_TRIVIAL 1
be2a1a68
AD
1205#endif
1206
74310291 1207b4_pure_if([],
be2a1a68
AD
1208[extern YYSTYPE b4_prefix[]lval;])
1209
58612f1d 1210b4_location_if(
050c471b
PE
1211[#if ! defined (YYLTYPE) && ! defined (YYLTYPE_IS_DECLARED)
1212typedef struct YYLTYPE
be2a1a68
AD
1213{
1214 int first_line;
1215 int first_column;
1216 int last_line;
1217 int last_column;
050c471b
PE
1218} YYLTYPE;
1219# define yyltype YYLTYPE /* obsolescent; will be withdrawn */
1220# define YYLTYPE_IS_DECLARED 1
1221# define YYLTYPE_IS_TRIVIAL 1
be2a1a68 1222#endif
ff48177d 1223
be2a1a68
AD
1224m4_if(b4_pure, [0],
1225[extern YYLTYPE b4_prefix[]lloc;])
1226])
be2a1a68 1227])