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