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