]> git.saurik.com Git - bison.git/blame - data/yacc.c
Convert underscores to dashes in some %define variable names.
[bison.git] / data / yacc.c
CommitLineData
08af01c2 1 -*- C -*-
a8289c62 2
60491a94 3# Yacc compatible skeleton for Bison
c7a65b99 4
945e396c 5# Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006,
620b5727 6# 2007, 2008, 2009 Free Software Foundation, Inc.
60491a94 7
f16b0819 8# This program is free software: you can redistribute it and/or modify
60491a94 9# it under the terms of the GNU General Public License as published by
f16b0819 10# the Free Software Foundation, either version 3 of the License, or
60491a94 11# (at your option) any later version.
f16b0819 12#
60491a94
AD
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.
f16b0819 17#
60491a94 18# You should have received a copy of the GNU General Public License
f16b0819 19# along with this program. If not, see <http://www.gnu.org/licenses/>.
60491a94 20
812775a0
JD
21# Check the value of %define api.push-pull.
22b4_percent_define_default([[api.push-pull]], [[pull]])
23b4_percent_define_check_values([[[[api.push-pull]],
9ca7f077
JD
24 [[pull]], [[push]], [[both]]]])
25b4_define_flag_if([pull]) m4_define([b4_pull_flag], [[1]])
26b4_define_flag_if([push]) m4_define([b4_push_flag], [[1]])
812775a0 27m4_case(b4_percent_define_get([[api.push-pull]]),
9ca7f077
JD
28 [pull], [m4_define([b4_push_flag], [[0]])],
29 [push], [m4_define([b4_pull_flag], [[0]])])
30
31# Handle BISON_USE_PUSH_FOR_PULL for the test suite. So that push parsing
32# tests function as written, don't let BISON_USE_PUSH_FOR_PULL modify Bison's
33# behavior at all when push parsing is already requested.
34b4_define_flag_if([use_push_for_pull])
35b4_use_push_for_pull_if([
36 b4_push_if([m4_define([b4_use_push_for_pull_flag], [[0]])],
37 [m4_define([b4_push_flag], [[1]])])])
945e396c 38
0a96ba81 39m4_include(b4_pkgdatadir/[c.m4])
7eb8a0bc 40
66d30cd4
AD
41## ---------------- ##
42## Default values. ##
43## ---------------- ##
44
45# Stack parameters.
46m4_define_default([b4_stack_depth_max], [10000])
47m4_define_default([b4_stack_depth_init], [200])
48
2a8d363a
AD
49
50## ------------------------ ##
51## Pure/impure interfaces. ##
52## ------------------------ ##
53
d9df47b6
JD
54b4_percent_define_default([[api.pure]], [[false]])
55b4_define_flag_if([pure])
56m4_define([b4_pure_flag],
57 [b4_percent_define_flag_if([[api.pure]], [[1]], [[0]])])
2a8d363a 58
4b367315
AD
59# b4_yacc_pure_if(IF-TRUE, IF-FALSE)
60# ----------------------------------
2a8d363a 61# Expand IF-TRUE, if %pure-parser and %parse-param, IF-FALSE otherwise.
4b367315 62m4_define([b4_yacc_pure_if],
2a8d363a 63[b4_pure_if([m4_ifset([b4_parse_param],
02650b7f
PE
64 [$1], [$2])],
65 [$2])])
2a8d363a
AD
66
67
93724f13
AD
68# b4_yyerror_args
69# ---------------
2a8d363a 70# Arguments passed to yyerror: user args plus yylloc.
93724f13 71m4_define([b4_yyerror_args],
327afc7c 72[b4_yacc_pure_if([b4_locations_if([&yylloc, ])])dnl
93724f13 73m4_ifset([b4_parse_param], [b4_c_args(b4_parse_param), ])])
2a8d363a
AD
74
75
76# b4_lex_param
77# ------------
d42f69cd 78# Accumulate in b4_lex_param all the yylex arguments.
2a8d363a 79# b4_lex_param arrives quoted twice, but we want to keep only one level.
21964f43
AD
80m4_define([b4_lex_param],
81m4_dquote(b4_pure_if([[[[YYSTYPE *]], [[&yylval]]][]dnl
327afc7c 82b4_locations_if([, [[YYLTYPE *], [&yylloc]]])m4_ifdef([b4_lex_param], [, ])])dnl
68cdf747 83m4_ifdef([b4_lex_param], b4_lex_param)))
66d30cd4
AD
84
85
f1886bb2
AD
86## ------------ ##
87## Data Types. ##
88## ------------ ##
89
90# b4_int_type(MIN, MAX)
91# ---------------------
92# Return the smallest int type able to handle numbers ranging from
d42cf844
PE
93# MIN to MAX (included). Overwrite the version from c.m4, which
94# uses only C89 types, so that the user can override the shorter
95# types, and so that pre-C89 compilers are handled correctly.
f1886bb2 96m4_define([b4_int_type],
d42cf844
PE
97[m4_if(b4_ints_in($@, [0], [255]), [1], [yytype_uint8],
98 b4_ints_in($@, [-128], [127]), [1], [yytype_int8],
f1886bb2 99
d42cf844
PE
100 b4_ints_in($@, [0], [65535]), [1], [yytype_uint16],
101 b4_ints_in($@, [-32768], [32767]), [1], [yytype_int16],
f1886bb2
AD
102
103 m4_eval([0 <= $1]), [1], [unsigned int],
104
02650b7f 105 [int])])
f1886bb2
AD
106
107
66d30cd4
AD
108## ----------------- ##
109## Semantic Values. ##
110## ----------------- ##
111
112
82b6cb3f
AD
113# b4_lhs_value([TYPE])
114# --------------------
115# Expansion of $<TYPE>$.
116m4_define([b4_lhs_value],
bc82c5a5 117[(yyval[]m4_ifval([$1], [.$1]))])
82b6cb3f
AD
118
119
120# b4_rhs_value(RULE-LENGTH, NUM, [TYPE])
121# --------------------------------------
122# Expansion of $<TYPE>NUM, where the current rule has RULE-LENGTH
123# symbols on RHS.
124m4_define([b4_rhs_value],
d1ff7a7c 125[(yyvsp@{($2) - ($1)@}m4_ifval([$3], [.$3]))])
82b6cb3f
AD
126
127
58612f1d
AD
128
129## ----------- ##
130## Locations. ##
131## ----------- ##
132
82b6cb3f
AD
133# b4_lhs_location()
134# -----------------
135# Expansion of @$.
136m4_define([b4_lhs_location],
bc82c5a5 137[(yyloc)])
82b6cb3f
AD
138
139
140# b4_rhs_location(RULE-LENGTH, NUM)
141# ---------------------------------
142# Expansion of @NUM, where the current rule has RULE-LENGTH symbols
143# on RHS.
144m4_define([b4_rhs_location],
d1ff7a7c 145[(yylsp@{($2) - ($1)@})])
be2a1a68 146
0d8bed56 147
0d8bed56 148
1ae72863
AD
149## --------------------------------------------------------- ##
150## Defining symbol actions, e.g., printers and destructors. ##
151## --------------------------------------------------------- ##
152
b526ee61
AD
153# We do want M4 expansion after # for CPP macros.
154m4_changecom()
08af01c2 155m4_divert_push(0)dnl
0d2b2ab0 156@output(b4_parser_file_name@)@
327afc7c 157b4_copyright([Skeleton implementation for Bison's Yacc-like parsers in C],dnl '
620b5727
JD
158 [1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008,
159 2009])[
af3412cd
PE
160
161/* C LALR(1) parser skeleton written by Richard Stallman, by
162 simplifying the original so-called "semantic" parser. */
444fbf65 163
cf44a9ae
PE
164/* All symbols defined below should begin with yy or YY, to avoid
165 infringing on user name space. This should be done even for local
166 variables, as they might otherwise be expanded by user macros.
167 There are some unavoidable exceptions within include files to
168 define necessary library symbols; they are noted "INFRINGES ON
169 USER NAME SPACE" below. */
170
9c1e26bd 171]b4_identification
a4e25e1d 172b4_percent_code_get([[top]])[]dnl
aa08666d 173m4_if(b4_prefix, [yy], [],
9ca7f077
JD
174[[/* Substitute the variable and function names. */
175]b4_pull_if([[#define yyparse ]b4_prefix[parse
176]])b4_push_if([[#define yypush_parse ]b4_prefix[push_parse
177]b4_pull_if([[#define yypull_parse ]b4_prefix[pull_parse
178]])[#define yypstate_new ]b4_prefix[pstate_new
179#define yypstate_delete ]b4_prefix[pstate_delete
180#define yypstate ]b4_prefix[pstate
181]])[#define yylex ]b4_prefix[lex
182#define yyerror ]b4_prefix[error
183#define yylval ]b4_prefix[lval
184#define yychar ]b4_prefix[char
185#define yydebug ]b4_prefix[debug
186#define yynerrs ]b4_prefix[nerrs
187]b4_locations_if([[#define yylloc ]b4_prefix[lloc]])])[
17da6427 188
0dd1580a 189/* Copy the first part of user declarations. */
136a0f76 190]b4_user_pre_prologue[
cce71710 191
d99361e6
AD
192/* Enabling traces. */
193#ifndef YYDEBUG
327afc7c 194# define YYDEBUG ]b4_debug_flag[
d99361e6
AD
195#endif
196
197/* Enabling verbose error messages. */
198#ifdef YYERROR_VERBOSE
199# undef YYERROR_VERBOSE
200# define YYERROR_VERBOSE 1
201#else
327afc7c 202# define YYERROR_VERBOSE ]b4_error_verbose_flag[
d99361e6
AD
203#endif
204
141f5793
PE
205/* Enabling the token table. */
206#ifndef YYTOKEN_TABLE
207# define YYTOKEN_TABLE ]b4_token_table[
208#endif
209
a4e25e1d 210]b4_percent_code_get([[requires]])[]dnl
9bc0dd67
JD
211
212b4_token_enums_defines(b4_tokens)[
213
02650b7f 214#if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED
9c1e26bd 215]m4_ifdef([b4_stype],
ddc8ede1 216[[typedef union ]b4_union_name[
7ecec4dd 217{
ddc8ede1 218]b4_user_stype[
7ecec4dd 219} YYSTYPE;
ddc8ede1
PE
220# define YYSTYPE_IS_TRIVIAL 1]],
221[m4_if(b4_tag_seen_flag, 0,
222[[typedef int YYSTYPE;
223# define YYSTYPE_IS_TRIVIAL 1]])])[
050c471b
PE
224# define yystype YYSTYPE /* obsolescent; will be withdrawn */
225# define YYSTYPE_IS_DECLARED 1
9ca7f077 226#endif]b4_locations_if([[
fd51e5ff 227
9ca7f077 228#if ! defined YYLTYPE && ! defined YYLTYPE_IS_DECLARED
050c471b 229typedef struct YYLTYPE
fd51e5ff
AD
230{
231 int first_line;
232 int first_column;
233 int last_line;
234 int last_column;
050c471b
PE
235} YYLTYPE;
236# define yyltype YYLTYPE /* obsolescent; will be withdrawn */
237# define YYLTYPE_IS_DECLARED 1
71cd15d4 238# define YYLTYPE_IS_TRIVIAL 1
9ca7f077
JD
239#endif]])b4_push_if([[
240
241#ifndef YYPUSH_DECLS
242# define YYPUSH_DECLS
243struct yypstate;
244typedef struct yypstate yypstate;
245enum { YYPUSH_MORE = 4 };
246
247]b4_pull_if([b4_c_function_decl([[yyparse]], [[int]], b4_parse_param)
248])b4_c_function_decl([[yypush_parse]], [[int]],
249 [[[yypstate *yyps]], [[yyps]]]b4_pure_if([,
250 [[[int yypushed_char]], [[yypushed_char]]],
251 [[[YYSTYPE const *yypushed_val]], [[yypushed_val]]]b4_locations_if([,
252 [[[YYLTYPE const *yypushed_loc]], [[yypushed_loc]]]])])m4_ifset([b4_parse_param], [,
253 b4_parse_param]))
254b4_pull_if([b4_c_function_decl([[yypull_parse]], [[int]],
255 [[[yypstate *yyps]], [[yyps]]]m4_ifset([b4_parse_param], [,
256 b4_parse_param]))])
257b4_c_function_decl([[yypstate_new]], [[yypstate *]], [[[void]], []])
258b4_c_function_decl([[yypstate_delete]], [[void]],
259 [[[yypstate *yyps]], [[yyps]]])[
260#endif]])
fd51e5ff 261
a4e25e1d 262b4_percent_code_get([[provides]])[]dnl
9bc0dd67
JD
263
264[/* Copy the second part of user declarations. */
8e0a5e9e 265]b4_user_post_prologue
a4e25e1d 266b4_percent_code_get[]dnl
7093d0f5 267
8e0a5e9e 268[#ifdef short
d42cf844
PE
269# undef short
270#endif
271
272#ifdef YYTYPE_UINT8
273typedef YYTYPE_UINT8 yytype_uint8;
274#else
275typedef unsigned char yytype_uint8;
276#endif
277
278#ifdef YYTYPE_INT8
279typedef YYTYPE_INT8 yytype_int8;
280#elif ]b4_c_modern[
281typedef signed char yytype_int8;
282#else
283typedef short int yytype_int8;
284#endif
285
286#ifdef YYTYPE_UINT16
287typedef YYTYPE_UINT16 yytype_uint16;
288#else
289typedef unsigned short int yytype_uint16;
290#endif
291
292#ifdef YYTYPE_INT16
293typedef YYTYPE_INT16 yytype_int16;
294#else
295typedef short int yytype_int16;
296#endif
297
55289366 298#ifndef YYSIZE_T
02650b7f 299# ifdef __SIZE_TYPE__
55289366 300# define YYSIZE_T __SIZE_TYPE__
02650b7f 301# elif defined size_t
55289366 302# define YYSIZE_T size_t
02650b7f 303# elif ! defined YYSIZE_T && ]b4_c_modern[
55289366
PE
304# include <stddef.h> /* INFRINGES ON USER NAME SPACE */
305# define YYSIZE_T size_t
306# else
307# define YYSIZE_T unsigned int
308# endif
bedf57f5 309#endif
7093d0f5 310
b4c1f9d2
PE
311#define YYSIZE_MAXIMUM ((YYSIZE_T) -1)
312
30757c8c
PE
313#ifndef YY_
314# if YYENABLE_NLS
315# if ENABLE_NLS
316# include <libintl.h> /* INFRINGES ON USER NAME SPACE */
317# define YY_(msgid) dgettext ("bison-runtime", msgid)
318# endif
319# endif
320# ifndef YY_
321# define YY_(msgid) msgid
322# endif
323#endif
324
2a4647a3 325/* Suppress unused-variable warnings by "using" E. */
02650b7f 326#if ! defined lint || defined __GNUC__
12ce2df6
PE
327# define YYUSE(e) ((void) (e))
328#else
329# define YYUSE(e) /* empty */
330#endif
331
332/* Identity function, used to suppress warnings about constant conditions. */
333#ifndef lint
334# define YYID(n) (n)
335#else
cd9e1ba2 336]b4_c_function_def([YYID], [static int], [[int yyi], [yyi]])[
12ce2df6 337{
cd9e1ba2 338 return yyi;
12ce2df6
PE
339}
340#endif
2a4647a3 341
02650b7f 342#if ! defined yyoverflow || YYERROR_VERBOSE
2779e383 343
9ca7f077
JD
344]b4_push_if([],
345[[/* The parser invokes alloca or malloc; define the necessary symbols. */
7093d0f5 346
b929851a
PE
347# ifdef YYSTACK_USE_ALLOCA
348# if YYSTACK_USE_ALLOCA
b929851a
PE
349# ifdef __GNUC__
350# define YYSTACK_ALLOC __builtin_alloca
02650b7f 351# elif defined __BUILTIN_VA_ARG_INCR
55289366 352# include <alloca.h> /* INFRINGES ON USER NAME SPACE */
02650b7f 353# elif defined _AIX
55289366 354# define YYSTACK_ALLOC __alloca
02650b7f 355# elif defined _MSC_VER
55289366
PE
356# include <malloc.h> /* INFRINGES ON USER NAME SPACE */
357# define alloca _alloca
d7e14fc0
PE
358# else
359# define YYSTACK_ALLOC alloca
02650b7f 360# if ! defined _ALLOCA_H && ! defined _STDLIB_H && ]b4_c_modern[
bedf57f5 361# include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
55289366
PE
362# ifndef _STDLIB_H
363# define _STDLIB_H 1
364# endif
bedf57f5 365# endif
7093d0f5
AD
366# endif
367# endif
368# endif
369
9ca7f077
JD
370]])dnl
371[# ifdef YYSTACK_ALLOC
9d9b8b70 372 /* Pacify GCC's `empty if-body' warning. */
12ce2df6 373# define YYSTACK_FREE(Ptr) do { /* empty */; } while (YYID (0))
506ffb1f 374# ifndef YYSTACK_ALLOC_MAXIMUM
b9c9f761
PE
375 /* The OS might guarantee only one guard page at the bottom of the stack,
376 and a page size can be as small as 4096 bytes. So we cannot safely
377 invoke alloca (N) if N exceeds 4096. Use a slightly smaller number
378 to allow for a few compiler-allocated temporary stack slots. */
e2a21b6f 379# define YYSTACK_ALLOC_MAXIMUM 4032 /* reasonable circa 2006 */
506ffb1f 380# endif
7093d0f5 381# else
2779e383
PE
382# define YYSTACK_ALLOC YYMALLOC
383# define YYSTACK_FREE YYFREE
506ffb1f 384# ifndef YYSTACK_ALLOC_MAXIMUM
b4c1f9d2 385# define YYSTACK_ALLOC_MAXIMUM YYSIZE_MAXIMUM
506ffb1f 386# endif
fc3f467f
PE
387# if (defined __cplusplus && ! defined _STDLIB_H \
388 && ! ((defined YYMALLOC || defined malloc) \
389 && (defined YYFREE || defined free)))
390# include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
391# ifndef _STDLIB_H
392# define _STDLIB_H 1
393# endif
0925ebb4 394# endif
bedf57f5
PE
395# ifndef YYMALLOC
396# define YYMALLOC malloc
02650b7f 397# if ! defined malloc && ! defined _STDLIB_H && ]b4_c_modern[
bedf57f5
PE
398void *malloc (YYSIZE_T); /* INFRINGES ON USER NAME SPACE */
399# endif
400# endif
401# ifndef YYFREE
402# define YYFREE free
02650b7f 403# if ! defined free && ! defined _STDLIB_H && ]b4_c_modern[
bedf57f5
PE
404void free (void *); /* INFRINGES ON USER NAME SPACE */
405# endif
406# endif
7093d0f5 407# endif
02650b7f 408#endif /* ! defined yyoverflow || YYERROR_VERBOSE */
cf44a9ae
PE
409
410
02650b7f
PE
411#if (! defined yyoverflow \
412 && (! defined __cplusplus \
327afc7c 413 || (]b4_locations_if([[defined YYLTYPE_IS_TRIVIAL && YYLTYPE_IS_TRIVIAL \
02650b7f 414 && ]])[defined YYSTYPE_IS_TRIVIAL && YYSTYPE_IS_TRIVIAL)))
7093d0f5 415
600f9b0c
PE
416/* A type that is properly aligned for any stack member. */
417union yyalloc
418{
9ca7f077
JD
419 yytype_int16 yyss_alloc;
420 YYSTYPE yyvs_alloc;]b4_locations_if([
421 YYLTYPE yyls_alloc;])[
422};
600f9b0c
PE
423
424/* The size of the maximum gap between one aligned stack and the next. */
17836590 425# define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1)
600f9b0c
PE
426
427/* The size of an array large to enough to hold all stacks, each with
428 N elements. */
327afc7c 429]b4_locations_if(
58612f1d 430[# define YYSTACK_BYTES(N) \
d42cf844 431 ((N) * (sizeof (yytype_int16) + sizeof (YYSTYPE) + sizeof (YYLTYPE)) \
17836590 432 + 2 * YYSTACK_GAP_MAXIMUM)],
58612f1d 433[# define YYSTACK_BYTES(N) \
d42cf844 434 ((N) * (sizeof (yytype_int16) + sizeof (YYSTYPE)) \
17836590 435 + YYSTACK_GAP_MAXIMUM)])[
600f9b0c 436
5b041382
PE
437/* Copy COUNT objects from FROM to TO. The source and destination do
438 not overlap. */
439# ifndef YYCOPY
02650b7f 440# if defined __GNUC__ && 1 < __GNUC__
5b041382
PE
441# define YYCOPY(To, From, Count) \
442 __builtin_memcpy (To, From, (Count) * sizeof (*(From)))
443# else
444# define YYCOPY(To, From, Count) \
445 do \
446 { \
cb530ce9 447 YYSIZE_T yyi; \
5b041382 448 for (yyi = 0; yyi < (Count); yyi++) \
9c1e26bd 449 (To)[yyi] = (From)[yyi]; \
5b041382 450 } \
12ce2df6 451 while (YYID (0))
5b041382
PE
452# endif
453# endif
454
455/* Relocate STACK from its old location to the new one. The
7093d0f5 456 local variables YYSIZE and YYSTACKSIZE give the old and new number of
600f9b0c
PE
457 elements in the stack, and YYPTR gives the new location of the
458 stack. Advance YYPTR to a properly aligned location for the next
459 stack. */
9ca7f077 460# define YYSTACK_RELOCATE(Stack_alloc, Stack) \
7093d0f5
AD
461 do \
462 { \
463 YYSIZE_T yynewbytes; \
9ca7f077
JD
464 YYCOPY (&yyptr->Stack_alloc, Stack, yysize); \
465 Stack = &yyptr->Stack_alloc; \
17836590 466 yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \
2729e106 467 yyptr += yynewbytes / sizeof (*yyptr); \
7093d0f5 468 } \
12ce2df6 469 while (YYID (0))
7093d0f5 470
cf44a9ae 471#endif
8850be4b 472
9d9b8b70 473/* YYFINAL -- State number of the termination state. */
9c1e26bd 474#define YYFINAL ]b4_final_state_number[
39912f52 475/* YYLAST -- Last index in YYTABLE. */
9c1e26bd 476#define YYLAST ]b4_last[
7742ddeb 477
9d9b8b70 478/* YYNTOKENS -- Number of terminals. */
9c1e26bd 479#define YYNTOKENS ]b4_tokens_number[
9d9b8b70 480/* YYNNTS -- Number of nonterminals. */
9c1e26bd 481#define YYNNTS ]b4_nterms_number[
9d9b8b70 482/* YYNRULES -- Number of rules. */
9c1e26bd 483#define YYNRULES ]b4_rules_number[
9d9b8b70 484/* YYNRULES -- Number of states. */
9c1e26bd 485#define YYNSTATES ]b4_states_number[
7742ddeb
AD
486
487/* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
9c1e26bd
AD
488#define YYUNDEFTOK ]b4_undef_token_number[
489#define YYMAXUTOK ]b4_user_token_number_max[
007a50a4 490
04098407 491#define YYTRANSLATE(YYX) \
a20713a4 492 ((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK)
a8289c62 493
b0400cc6
AD
494/* YYTRANSLATE[YYLEX] -- Bison symbol number corresponding to YYLEX. */
495static const ]b4_int_type_for([b4_translate])[ yytranslate[] =
a8289c62 496{
c5e3e510 497 ]b4_translate[
a8289c62
RA
498};
499
500#if YYDEBUG
c5e3e510 501/* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in
7742ddeb 502 YYRHS. */
c5e3e510 503static const ]b4_int_type_for([b4_prhs])[ yyprhs[] =
a8289c62 504{
c5e3e510 505 ]b4_prhs[
a8289c62
RA
506};
507
9d9b8b70 508/* YYRHS -- A `-1'-separated list of the rules' RHS. */
c5e3e510 509static const ]b4_int_type_for([b4_rhs])[ yyrhs[] =
a8289c62 510{
c5e3e510 511 ]b4_rhs[
a8289c62
RA
512};
513
c5e3e510
AD
514/* YYRLINE[YYN] -- source line where rule number YYN was defined. */
515static const ]b4_int_type_for([b4_rline])[ yyrline[] =
a8289c62 516{
c5e3e510 517 ]b4_rline[
a8289c62
RA
518};
519#endif
520
141f5793 521#if YYDEBUG || YYERROR_VERBOSE || YYTOKEN_TABLE
9e0876fb 522/* YYTNAME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM.
9d9b8b70 523 First, the terminals, then, starting at YYNTOKENS, nonterminals. */
c5e3e510 524static const char *const yytname[] =
a8289c62 525{
c5e3e510 526 ]b4_tname[
a8289c62
RA
527};
528#endif
529
c0ad8bf3 530# ifdef YYPRINT
c5e3e510 531/* YYTOKNUM[YYLEX-NUM] -- Internal token number corresponding to
769b430f 532 token YYLEX-NUM. */
c5e3e510 533static const ]b4_int_type_for([b4_toknum])[ yytoknum[] =
a8289c62 534{
c5e3e510 535 ]b4_toknum[
a8289c62 536};
c0ad8bf3 537# endif
a8289c62 538
c5e3e510
AD
539/* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */
540static const ]b4_int_type_for([b4_r1])[ yyr1[] =
a8289c62 541{
c5e3e510 542 ]b4_r1[
a8289c62
RA
543};
544
c5e3e510
AD
545/* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
546static const ]b4_int_type_for([b4_r2])[ yyr2[] =
a8289c62 547{
c5e3e510 548 ]b4_r2[
a8289c62
RA
549};
550
620b5727
JD
551/* YYDEFACT[STATE-NAME] -- Default reduction number in state STATE-NUM.
552 Performed when YYTABLE doesn't specify something else to do. Zero
5504898e 553 means the default is an error. */
c5e3e510 554static const ]b4_int_type_for([b4_defact])[ yydefact[] =
a8289c62 555{
c5e3e510 556 ]b4_defact[
a8289c62
RA
557};
558
9d9b8b70 559/* YYDEFGOTO[NTERM-NUM]. */
c5e3e510 560static const ]b4_int_type_for([b4_defgoto])[ yydefgoto[] =
a8289c62 561{
c5e3e510 562 ]b4_defgoto[
a8289c62
RA
563};
564
c5e3e510 565/* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
7742ddeb 566 STATE-NUM. */
c5e3e510
AD
567#define YYPACT_NINF ]b4_pact_ninf[
568static const ]b4_int_type_for([b4_pact])[ yypact[] =
a8289c62 569{
c5e3e510 570 ]b4_pact[
a8289c62
RA
571};
572
c5e3e510
AD
573/* YYPGOTO[NTERM-NUM]. */
574static const ]b4_int_type_for([b4_pgoto])[ yypgoto[] =
a8289c62 575{
c5e3e510 576 ]b4_pgoto[
a8289c62
RA
577};
578
c5e3e510 579/* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If
7742ddeb 580 positive, shift that token. If negative, reduce the rule which
f50adbbd 581 number is the opposite. If zero, do what YYDEFACT says.
6e649e65 582 If YYTABLE_NINF, syntax error. */
c5e3e510
AD
583#define YYTABLE_NINF ]b4_table_ninf[
584static const ]b4_int_type_for([b4_table])[ yytable[] =
a8289c62 585{
c5e3e510 586 ]b4_table[
a8289c62
RA
587};
588
c5e3e510 589static const ]b4_int_type_for([b4_check])[ yycheck[] =
a8289c62 590{
c5e3e510 591 ]b4_check[
a8289c62
RA
592};
593
c5e3e510 594/* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
5504898e 595 symbol of state STATE-NUM. */
c5e3e510 596static const ]b4_int_type_for([b4_stos])[ yystos[] =
5504898e 597{
c5e3e510 598 ]b4_stos[
5504898e 599};
7093d0f5 600
10fa2066 601#define yyerrok (yyerrstatus = 0)
a20713a4
PE
602#define yyclearin (yychar = YYEMPTY)
603#define YYEMPTY (-2)
10fa2066 604#define YYEOF 0
a8289c62 605
70ddf897 606#define YYACCEPT goto yyacceptlab
a8289c62 607#define YYABORT goto yyabortlab
a6b89bb2 608#define YYERROR goto yyerrorlab
8a3eb3c8 609
a8289c62 610
71da9eea
AD
611/* Like YYERROR except do call yyerror. This remains here temporarily
612 to ease the transition to the new meaning of YYERROR, for GCC.
10fa2066 613 Once GCC version 2 has supplanted version 1, this can go. */
a8289c62 614
10fa2066 615#define YYFAIL goto yyerrlab
a8289c62 616
10fa2066 617#define YYRECOVERING() (!!yyerrstatus)
a8289c62 618
69b4e0c5 619#define YYBACKUP(Token, Value) \
10fa2066 620do \
a20713a4 621 if (yychar == YYEMPTY && yylen == 1) \
71da9eea 622 { \
17da6427 623 yychar = (Token); \
7742ddeb 624 yylval = (Value); \
b0400cc6 625 yytoken = YYTRANSLATE (yychar); \
a85284cf 626 YYPOPSTACK (1); \
10fa2066
RS
627 goto yybackup; \
628 } \
629 else \
04098407 630 { \
30757c8c 631 yyerror (]b4_yyerror_args[YY_("syntax error: cannot back up")); \
71da9eea
AD
632 YYERROR; \
633 } \
12ce2df6 634while (YYID (0))
10fa2066 635
3fc16193 636
10fa2066
RS
637#define YYTERROR 1
638#define YYERRCODE 256
639
3fc16193 640
b4a20338
AD
641/* YYLLOC_DEFAULT -- Set CURRENT to span from RHS[1] to RHS[N].
642 If N is 0, then set CURRENT to the empty location which ends
643 the previous symbol: RHS[0] (always defined). */
3abcd459 644
24e0cbd0 645#define YYRHSLOC(Rhs, K) ((Rhs)[K])
3abcd459 646#ifndef YYLLOC_DEFAULT
24e0cbd0
PE
647# define YYLLOC_DEFAULT(Current, Rhs, N) \
648 do \
d6cff4dc 649 if (YYID (N)) \
24e0cbd0 650 { \
9bec482e
PE
651 (Current).first_line = YYRHSLOC (Rhs, 1).first_line; \
652 (Current).first_column = YYRHSLOC (Rhs, 1).first_column; \
653 (Current).last_line = YYRHSLOC (Rhs, N).last_line; \
654 (Current).last_column = YYRHSLOC (Rhs, N).last_column; \
24e0cbd0
PE
655 } \
656 else \
657 { \
658 (Current).first_line = (Current).last_line = \
9bec482e 659 YYRHSLOC (Rhs, 0).last_line; \
24e0cbd0 660 (Current).first_column = (Current).last_column = \
9bec482e 661 YYRHSLOC (Rhs, 0).last_column; \
24e0cbd0 662 } \
12ce2df6 663 while (YYID (0))
b8458aa5
AD
664#endif
665
3fc16193
AD
666
667/* YY_LOCATION_PRINT -- Print the location on the stream.
668 This macro was not mandated originally: define only if we know
669 we won't break user code: when these are the locations we know. */
670
3fc16193 671#ifndef YY_LOCATION_PRINT
b8458aa5
AD
672# if YYLTYPE_IS_TRIVIAL
673# define YY_LOCATION_PRINT(File, Loc) \
674 fprintf (File, "%d.%d-%d.%d", \
02650b7f
PE
675 (Loc).first_line, (Loc).first_column, \
676 (Loc).last_line, (Loc).last_column)
0dcca5c2
AD
677# else
678# define YY_LOCATION_PRINT(File, Loc) ((void) 0)
b8458aa5 679# endif
3abcd459
AD
680#endif
681
3fc16193 682
3abcd459 683/* YYLEX -- calling `yylex' with the right arguments. */
553e2b22 684
ae7453f2 685#ifdef YYLEX_PARAM
327afc7c 686# define YYLEX yylex (]b4_pure_if([&yylval[]b4_locations_if([, &yylloc]), ])[YYLEX_PARAM)
74310291 687#else
9c1e26bd 688# define YYLEX ]b4_c_function_call([yylex], [int], b4_lex_param)[
ae7453f2 689#endif
553e2b22 690
5a35a6cb 691/* Enable debugging if requested. */
0d533154 692#if YYDEBUG
b7575ffe 693
2f4f028d 694# ifndef YYFPRINTF
45119af1
PE
695# include <stdio.h> /* INFRINGES ON USER NAME SPACE */
696# define YYFPRINTF fprintf
b7575ffe
PE
697# endif
698
5a35a6cb
AD
699# define YYDPRINTF(Args) \
700do { \
17da6427 701 if (yydebug) \
b7575ffe 702 YYFPRINTF Args; \
12ce2df6 703} while (YYID (0))
c5e3e510 704
4b367315
AD
705# define YY_SYMBOL_PRINT(Title, Type, Value, Location) \
706do { \
707 if (yydebug) \
708 { \
709 YYFPRINTF (stderr, "%s ", Title); \
a0af42fc 710 yy_symbol_print (stderr, \
327afc7c 711 Type, Value]b4_locations_if([, Location])[]b4_user_args[); \
4b367315
AD
712 YYFPRINTF (stderr, "\n"); \
713 } \
12ce2df6 714} while (YYID (0))
9c1e26bd 715
a0af42fc 716]b4_yy_symbol_print_generate([b4_c_function_def])[
d1ff7a7c 717
b0937b22
AD
718/*------------------------------------------------------------------.
719| yy_stack_print -- Print the state stack from its BOTTOM up to its |
5348bfbe 720| TOP (included). |
b0937b22
AD
721`------------------------------------------------------------------*/
722
723]b4_c_function_def([yy_stack_print], [static void],
cd9e1ba2
PE
724 [[yytype_int16 *yybottom], [yybottom]],
725 [[yytype_int16 *yytop], [yytop]])[
b0937b22 726{
2f4f028d 727 YYFPRINTF (stderr, "Stack now");
cd9e1ba2
PE
728 for (; yybottom <= yytop; yybottom++)
729 {
730 int yybot = *yybottom;
731 YYFPRINTF (stderr, " %d", yybot);
732 }
2f4f028d 733 YYFPRINTF (stderr, "\n");
b0937b22
AD
734}
735
736# define YY_STACK_PRINT(Bottom, Top) \
737do { \
738 if (yydebug) \
739 yy_stack_print ((Bottom), (Top)); \
12ce2df6 740} while (YYID (0))
b0937b22
AD
741
742
743/*------------------------------------------------.
744| Report that the YYRULE is going to be reduced. |
745`------------------------------------------------*/
746
747]b4_c_function_def([yy_reduce_print], [static void],
02650b7f 748 [[YYSTYPE *yyvsp], [yyvsp]],
aefef0d6
PE
749 b4_locations_if([[[YYLTYPE *yylsp], [yylsp]],
750 ])[[int yyrule], [yyrule]]m4_ifset([b4_parse_param], [,
9ca7f077 751 b4_parse_param]))[
b0937b22 752{
d1ff7a7c 753 int yynrhs = yyr2[yyrule];
b0937b22 754 int yyi;
30757c8c 755 unsigned long int yylno = yyrline[yyrule];
d1ff7a7c 756 YYFPRINTF (stderr, "Reducing stack by rule %d (line %lu):\n",
02650b7f 757 yyrule - 1, yylno);
d1ff7a7c
AD
758 /* The symbols being reduced. */
759 for (yyi = 0; yyi < yynrhs; yyi++)
760 {
f57a7536 761 YYFPRINTF (stderr, " $%d = ", yyi + 1);
a0af42fc 762 yy_symbol_print (stderr, yyrhs[yyprhs[yyrule] + yyi],
02650b7f 763 &]b4_rhs_value(yynrhs, yyi + 1)[
327afc7c 764 ]b4_locations_if([, &]b4_rhs_location(yynrhs, yyi + 1))[]dnl
02650b7f 765 b4_user_args[);
f57a7536 766 YYFPRINTF (stderr, "\n");
d1ff7a7c 767 }
b0937b22
AD
768}
769
d9963c85
PE
770# define YY_REDUCE_PRINT(Rule) \
771do { \
772 if (yydebug) \
327afc7c 773 yy_reduce_print (yyvsp, ]b4_locations_if([yylsp, ])[Rule]b4_user_args[); \
12ce2df6 774} while (YYID (0))
b0937b22 775
cf44a9ae
PE
776/* Nonzero means print parse trace. It is left uninitialized so that
777 multiple parsers can coexist. */
17da6427 778int yydebug;
5a35a6cb
AD
779#else /* !YYDEBUG */
780# define YYDPRINTF(Args)
284acc8b 781# define YY_SYMBOL_PRINT(Title, Type, Value, Location)
b0937b22 782# define YY_STACK_PRINT(Bottom, Top)
d9963c85 783# define YY_REDUCE_PRINT(Rule)
5a35a6cb
AD
784#endif /* !YYDEBUG */
785
b0937b22 786
5a35a6cb 787/* YYINITDEPTH -- initial size of the parser's stacks. */
10fa2066 788#ifndef YYINITDEPTH
9c1e26bd 789# define YYINITDEPTH ]b4_stack_depth_init[
10fa2066
RS
790#endif
791
5a35a6cb 792/* YYMAXDEPTH -- maximum size the stacks can grow to (effective only
600f9b0c
PE
793 if the built-in stack extension method is used).
794
795 Do not make this value too large; the results are undefined if
506ffb1f 796 YYSTACK_ALLOC_MAXIMUM < YYSTACK_BYTES (YYMAXDEPTH)
600f9b0c
PE
797 evaluated with infinite-precision integer arithmetic. */
798
10fa2066 799#ifndef YYMAXDEPTH
9c1e26bd 800# define YYMAXDEPTH ]b4_stack_depth_max[
10fa2066 801#endif
a8289c62 802
10fa2066 803\f
a8289c62 804
7093d0f5
AD
805#if YYERROR_VERBOSE
806
807# ifndef yystrlen
02650b7f 808# if defined __GLIBC__ && defined _STRING_H
7093d0f5
AD
809# define yystrlen strlen
810# else
811/* Return the length of YYSTR. */
1b9c21fb
PE
812]b4_c_function_def([yystrlen], [static YYSIZE_T],
813 [[const char *yystr], [yystr]])[
7093d0f5 814{
12ce2df6
PE
815 YYSIZE_T yylen;
816 for (yylen = 0; yystr[yylen]; yylen++)
7093d0f5 817 continue;
12ce2df6 818 return yylen;
7093d0f5
AD
819}
820# endif
821# endif
822
823# ifndef yystpcpy
02650b7f 824# if defined __GLIBC__ && defined _STRING_H && defined _GNU_SOURCE
7093d0f5
AD
825# define yystpcpy stpcpy
826# else
827/* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in
828 YYDEST. */
1b9c21fb
PE
829]b4_c_function_def([yystpcpy], [static char *],
830 [[char *yydest], [yydest]], [[const char *yysrc], [yysrc]])[
7093d0f5 831{
cb530ce9
PE
832 char *yyd = yydest;
833 const char *yys = yysrc;
7093d0f5
AD
834
835 while ((*yyd++ = *yys++) != '\0')
836 continue;
837
838 return yyd - 1;
839}
840# endif
841# endif
842
9e0876fb
PE
843# ifndef yytnamerr
844/* Copy to YYRES the contents of YYSTR after stripping away unnecessary
845 quotes and backslashes, so that it's suitable for yyerror. The
846 heuristic is that double-quoting is unnecessary unless the string
847 contains an apostrophe, a comma, or backslash (other than
848 backslash-backslash). YYSTR is taken from yytname. If YYRES is
849 null, do not copy; instead, return the length of what the result
850 would have been. */
851static YYSIZE_T
852yytnamerr (char *yyres, const char *yystr)
853{
854 if (*yystr == '"')
855 {
276f48df 856 YYSIZE_T yyn = 0;
9e0876fb
PE
857 char const *yyp = yystr;
858
859 for (;;)
860 switch (*++yyp)
861 {
862 case '\'':
863 case ',':
864 goto do_not_strip_quotes;
865
866 case '\\':
867 if (*++yyp != '\\')
868 goto do_not_strip_quotes;
869 /* Fall through. */
870 default:
871 if (yyres)
872 yyres[yyn] = *yyp;
873 yyn++;
874 break;
875
876 case '"':
877 if (yyres)
878 yyres[yyn] = '\0';
879 return yyn;
880 }
881 do_not_strip_quotes: ;
882 }
883
884 if (! yyres)
885 return yystrlen (yystr);
886
887 return yystpcpy (yyres, yystr) - yyres;
888}
889# endif
890
b4c1f9d2
PE
891/* Copy into YYRESULT an error message about the unexpected token
892 YYCHAR while in state YYSTATE. Return the number of bytes copied,
893 including the terminating null byte. If YYRESULT is null, do not
894 copy anything; just return the number of bytes that would be
895 copied. As a special case, return 0 if an ordinary "syntax error"
896 message will do. Return YYSIZE_MAXIMUM if overflow occurs during
897 size calculation. */
898static YYSIZE_T
899yysyntax_error (char *yyresult, int yystate, int yychar)
900{
901 int yyn = yypact[yystate];
7093d0f5 902
d6645148 903 if (! (YYPACT_NINF < yyn && yyn <= YYLAST))
b4c1f9d2
PE
904 return 0;
905 else
906 {
907 int yytype = YYTRANSLATE (yychar);
908 YYSIZE_T yysize0 = yytnamerr (0, yytname[yytype]);
909 YYSIZE_T yysize = yysize0;
910 YYSIZE_T yysize1;
911 int yysize_overflow = 0;
912 enum { YYERROR_VERBOSE_ARGS_MAXIMUM = 5 };
913 char const *yyarg[YYERROR_VERBOSE_ARGS_MAXIMUM];
914 int yyx;
915
916# if 0
917 /* This is so xgettext sees the translatable formats that are
02650b7f 918 constructed on the fly. */
b4c1f9d2
PE
919 YY_("syntax error, unexpected %s");
920 YY_("syntax error, unexpected %s, expecting %s");
921 YY_("syntax error, unexpected %s, expecting %s or %s");
922 YY_("syntax error, unexpected %s, expecting %s or %s or %s");
923 YY_("syntax error, unexpected %s, expecting %s or %s or %s or %s");
924# endif
925 char *yyfmt;
926 char const *yyf;
927 static char const yyunexpected[] = "syntax error, unexpected %s";
928 static char const yyexpecting[] = ", expecting %s";
929 static char const yyor[] = " or %s";
930 char yyformat[sizeof yyunexpected
02650b7f
PE
931 + sizeof yyexpecting - 1
932 + ((YYERROR_VERBOSE_ARGS_MAXIMUM - 2)
933 * (sizeof yyor - 1))];
b4c1f9d2
PE
934 char const *yyprefix = yyexpecting;
935
936 /* Start YYX at -YYN if negative to avoid negative indexes in
02650b7f 937 YYCHECK. */
b4c1f9d2
PE
938 int yyxbegin = yyn < 0 ? -yyn : 0;
939
940 /* Stay within bounds of both yycheck and yytname. */
d6645148 941 int yychecklim = YYLAST - yyn + 1;
b4c1f9d2
PE
942 int yyxend = yychecklim < YYNTOKENS ? yychecklim : YYNTOKENS;
943 int yycount = 1;
944
945 yyarg[0] = yytname[yytype];
946 yyfmt = yystpcpy (yyformat, yyunexpected);
947
948 for (yyx = yyxbegin; yyx < yyxend; ++yyx)
34ec3579 949 if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR)
02650b7f
PE
950 {
951 if (yycount == YYERROR_VERBOSE_ARGS_MAXIMUM)
952 {
953 yycount = 1;
954 yysize = yysize0;
955 yyformat[sizeof yyunexpected - 1] = '\0';
956 break;
957 }
958 yyarg[yycount++] = yytname[yyx];
959 yysize1 = yysize + yytnamerr (0, yytname[yyx]);
960 yysize_overflow |= (yysize1 < yysize);
961 yysize = yysize1;
962 yyfmt = yystpcpy (yyfmt, yyprefix);
963 yyprefix = yyor;
964 }
b4c1f9d2
PE
965
966 yyf = YY_(yyformat);
967 yysize1 = yysize + yystrlen (yyf);
12ce2df6 968 yysize_overflow |= (yysize1 < yysize);
b4c1f9d2
PE
969 yysize = yysize1;
970
971 if (yysize_overflow)
972 return YYSIZE_MAXIMUM;
973
974 if (yyresult)
975 {
02650b7f
PE
976 /* Avoid sprintf, as that infringes on the user's name space.
977 Don't have undefined behavior even if the translation
978 produced a string with the wrong number of "%s"s. */
979 char *yyp = yyresult;
980 int yyi = 0;
981 while ((*yyp = *yyf) != '\0')
982 {
983 if (*yyp == '%' && yyf[1] == 's' && yyi < yycount)
984 {
985 yyp += yytnamerr (yyp, yyarg[yyi++]);
986 yyf += 2;
987 }
988 else
989 {
990 yyp++;
991 yyf++;
992 }
993 }
994 }
b4c1f9d2
PE
995 return yysize;
996 }
997}
998#endif /* YYERROR_VERBOSE */
10fa2066 999\f
a8289c62 1000
d1ff7a7c 1001]b4_yydestruct_generate([b4_c_function_def])[
4a2a22f4 1002
9ca7f077
JD
1003]b4_push_if([],
1004[[/* Prevent warnings from -Wmissing-prototypes. */
4a2a22f4 1005#ifdef YYPARSE_PARAM
1b9c21fb
PE
1006]b4_c_function_decl([yyparse], [int],
1007 [[void *YYPARSE_PARAM], [YYPARSE_PARAM]])[
0245f82d 1008#else /* ! YYPARSE_PARAM */
d1ff7a7c 1009]b4_c_function_decl([yyparse], [int], b4_parse_param)[
9ca7f077 1010#endif /* ! YYPARSE_PARAM */]])
0245f82d 1011
9ca7f077
JD
1012m4_divert_push([KILL])# ======================== M4 code.
1013# b4_declare_scanner_communication_variables
1014# ------------------------------------------
74310291 1015# Declare the variables that are global, or local to YYPARSE if
0245f82d 1016# pure-parser.
9ca7f077
JD
1017m4_define([b4_declare_scanner_communication_variables],
1018[[/* The lookahead symbol. */
74310291
AD
1019int yychar;
1020
742e4900 1021/* The semantic value of the lookahead symbol. */
74310291 1022YYSTYPE yylval;
9ca7f077 1023]b4_locations_if([[
742e4900 1024/* Location data for the lookahead symbol. */
9ca7f077
JD
1025YYLTYPE yylloc;
1026]])b4_pure_if([], [[
1027/* Number of syntax errors so far. */
1028int yynerrs;
1029]])])
1030
1031# b4_declare_parser_state_variables
1032# ---------------------------------
1033# Declare all the variables that are needed to maintain the parser state
1034# between calls to yypush_parse.
1035m4_define([b4_declare_parser_state_variables],
1036[b4_pure_if([[ /* Number of syntax errors so far. */
1037 int yynerrs;
1038]])[
1039 int yystate;
1040 /* Number of tokens to shift before error messages enabled. */
1041 int yyerrstatus;
1042
1043 /* The stacks and their tools:
1044 `yyss': related to states.
1045 `yyvs': related to semantic values.]b4_locations_if([[
1046 `yyls': related to locations.]])[
1047
1048 Refer to the stacks thru separate pointers, to allow yyoverflow
1049 to reallocate them elsewhere. */
1050
1051 /* The state stack. */
1052 yytype_int16 yyssa[YYINITDEPTH];
1053 yytype_int16 *yyss;
1054 yytype_int16 *yyssp;
1055
1056 /* The semantic value stack. */
1057 YYSTYPE yyvsa[YYINITDEPTH];
1058 YYSTYPE *yyvs;
1059 YYSTYPE *yyvsp;
1060]b4_locations_if([[
1061 /* The location stack. */
1062 YYLTYPE yylsa[YYINITDEPTH];
1063 YYLTYPE *yyls;
1064 YYLTYPE *yylsp;
1065
1066 /* The locations where the error started and ended. */
1067 YYLTYPE yyerror_range[2];
1068]])[
1069 YYSIZE_T yystacksize;
1070]])
1071
74310291 1072m4_divert_pop([KILL])dnl# ====================== End of M4 code.
58612f1d 1073
9ca7f077
JD
1074b4_pure_if([], [b4_declare_scanner_communication_variables])
1075
1076b4_push_if(
1077[[struct yypstate
1078 {
1079 ]b4_declare_parser_state_variables[
1080 /* Used to determine if this is the first time this instance has
1081 been used. */
1082 int yynew;
333e670c 1083 };]b4_pure_if([], [[
a35f64ea 1084
333e670c
JD
1085static char yypstate_allocated = 0;]])b4_pull_if([
1086
1087b4_c_function_def([[yyparse]], [[int]], b4_parse_param)[
9ca7f077
JD
1088{
1089 return yypull_parse (0]m4_ifset([b4_parse_param],
1090 [[, ]b4_c_args(b4_parse_param)])[);
333e670c 1091}
0245f82d 1092
9ca7f077
JD
1093]b4_c_function_def([[yypull_parse]], [[int]],
1094 [[[yypstate *yyps]], [[yyps]]]m4_ifset([b4_parse_param], [,
1095 b4_parse_param]))[
1096{
1097 int yystatus;
333e670c
JD
1098 yypstate *yyps_local;]b4_pure_if([[
1099 int yychar;
1100 YYSTYPE yylval;]b4_locations_if([[
1101 YYLTYPE yylloc;]])])[
9ca7f077
JD
1102 if (yyps == 0)
1103 {
1104 yyps_local = yypstate_new ();
1105 if (!yyps_local)
1106 {]b4_pure_if([[
1107 yyerror (]b4_yyerror_args[YY_("memory exhausted"));]], [[
1108 if (!yypstate_allocated)
1109 yyerror (]b4_yyerror_args[YY_("memory exhausted"));]])[
1110 return 2;
1111 }
1112 }
1113 else
1114 yyps_local = yyps;
1115 do {
1116 yychar = YYLEX;
1117 yystatus =
1118 yypush_parse (yyps_local]b4_pure_if([[, yychar, &yylval]b4_locations_if([[, &yylloc]])])m4_ifset([b4_parse_param], [, b4_c_args(b4_parse_param)])[);
1119 } while (yystatus == YYPUSH_MORE);
1120 if (yyps == 0)
1121 yypstate_delete (yyps_local);
1122 return yystatus;
333e670c
JD
1123}]])[
1124
9ca7f077
JD
1125/* Initialize the parser data structure. */
1126]b4_c_function_def([[yypstate_new]], [[yypstate *]])[
1127{
1128 yypstate *yyps;]b4_pure_if([], [[
1129 if (yypstate_allocated)
333e670c 1130 return 0;]])[
9ca7f077
JD
1131 yyps = (yypstate *) malloc (sizeof *yyps);
1132 if (!yyps)
1133 return 0;
1134 yyps->yynew = 1;]b4_pure_if([], [[
1135 yypstate_allocated = 1;]])[
1136 return yyps;
1137}
1138
1139]b4_c_function_def([[yypstate_delete]], [[void]],
1140 [[[yypstate *yyps]], [[yyps]]])[
1141{
1142#ifndef yyoverflow
1143 /* If the stack was reallocated but the parse did not complete, then the
1144 stack still needs to be freed. */
1145 if (!yyps->yynew && yyps->yyss != yyps->yyssa)
1146 YYSTACK_FREE (yyps->yyss);
1147#endif
1148 free (yyps);]b4_pure_if([], [[
1149 yypstate_allocated = 0;]])[
1150}
1151
1152]b4_pure_if([[#define ]b4_prefix[nerrs yyps->]b4_prefix[nerrs
1153]])[#define yystate yyps->yystate
1154#define yyerrstatus yyps->yyerrstatus
1155#define yyssa yyps->yyssa
1156#define yyss yyps->yyss
1157#define yyssp yyps->yyssp
1158#define yyvsa yyps->yyvsa
1159#define yyvs yyps->yyvs
1160#define yyvsp yyps->yyvsp
1161]b4_locations_if([[#define yylsa yyps->yylsa
1162#define yyls yyps->yyls
1163#define yylsp yyps->yylsp
1164#define yyerror_range yyps->yyerror_range
1165]])[#define yystacksize yyps->yystacksize
1166]])[
1167/*-------------------------.
1168| yyparse or yypush_parse. |
1169`-------------------------*/
1170]b4_push_if([
1171b4_c_function_def([[yypush_parse]], [[int]],
1172 [[[yypstate *yyps]], [[yyps]]]b4_pure_if([,
1173 [[[int yypushed_char]], [[yypushed_char]]],
1174 [[[YYSTYPE const *yypushed_val]], [[yypushed_val]]]b4_locations_if([,
1175 [[[YYLTYPE const *yypushed_loc]], [[yypushed_loc]]]])])m4_ifset([b4_parse_param], [,
1176 b4_parse_param]))], [
0245f82d 1177#ifdef YYPARSE_PARAM
1b9c21fb 1178b4_c_function_def([yyparse], [int], [[void *YYPARSE_PARAM], [YYPARSE_PARAM]])
0245f82d
AD
1179#else /* ! YYPARSE_PARAM */
1180b4_c_function_def([yyparse], [int], b4_parse_param)
9ca7f077
JD
1181#endif])[
1182{
1183]b4_pure_if([b4_declare_scanner_communication_variables])
1184b4_push_if([b4_pure_if([], [[ int yypushed_char = yychar;
1185 YYSTYPE yypushed_val = yylval;
1186 ]b4_locations_if([[YYLTYPE yypushed_loc = yylloc;
1187]])])],
1188 [b4_declare_parser_state_variables])[
cb530ce9 1189 int yyn;
600f9b0c 1190 int yyresult;
742e4900 1191 /* Lookahead token as an internal (translated) token number. */
9ca7f077
JD
1192 int yytoken;
1193 /* The variables used to return semantic value and location from the
1194 action routines. */
fa6aa7b3
JD
1195 YYSTYPE yyval;]b4_locations_if([[
1196 YYLTYPE yyloc;]])[
1197
b4c1f9d2
PE
1198#if YYERROR_VERBOSE
1199 /* Buffer for error messages, and its allocated size. */
1200 char yymsgbuf[128];
1201 char *yymsg = yymsgbuf;
1202 YYSIZE_T yymsg_alloc = sizeof yymsgbuf;
1203#endif
10fa2066 1204
327afc7c 1205#define YYPOPSTACK(N) (yyvsp -= (N), yyssp -= (N)]b4_locations_if([, yylsp -= (N)])[)
10fa2066 1206
a85284cf 1207 /* The number of symbols on the RHS of the reduced rule.
9d9b8b70 1208 Keep to zero when no symbol should be popped. */
fa6aa7b3
JD
1209 int yylen = 0;]b4_push_if([[
1210
9ca7f077
JD
1211 if (!yyps->yynew)
1212 {
1213 yyn = yypact[yystate];
1214 goto yyread_pushed_token;
fa6aa7b3
JD
1215 }]])[
1216
9ca7f077
JD
1217 yytoken = 0;
1218 yyss = yyssa;
fa6aa7b3
JD
1219 yyvs = yyvsa;]b4_locations_if([[
1220 yyls = yylsa;]])[
9ca7f077 1221 yystacksize = YYINITDEPTH;
10fa2066 1222
2f4f028d 1223 YYDPRINTF ((stderr, "Starting parse\n"));
10fa2066
RS
1224
1225 yystate = 0;
1226 yyerrstatus = 0;
17da6427 1227 yynerrs = 0;
9ca7f077 1228 yychar = YYEMPTY; /* Cause a token to be read. */
10fa2066
RS
1229
1230 /* Initialize stack pointers.
1231 Waste one element of value and location stack
1232 so that they stay on the same level as the state stack.
1233 The wasted elements are never initialized. */
cbd89906 1234 yyssp = yyss;
9ca7f077
JD
1235 yyvsp = yyvs;]b4_locations_if([[
1236 yylsp = yyls;
1237
b8458aa5
AD
1238#if YYLTYPE_IS_TRIVIAL
1239 /* Initialize the default location before parsing starts. */
cd48d21d
AD
1240 yylloc.first_line = yylloc.last_line = ]b4_location_initial_line[;
1241 yylloc.first_column = yylloc.last_column = ]b4_location_initial_column[;
9ca7f077
JD
1242#endif]])
1243m4_ifdef([b4_initial_action],[
407d4a75
PE
1244m4_pushdef([b4_at_dollar], [m4_define([b4_at_dollar_used])yylloc])dnl
1245m4_pushdef([b4_dollar_dollar], [m4_define([b4_dollar_dollar_used])yylval])dnl
9ca7f077
JD
1246/* User initialization code. */
1247b4_user_initial_action
cd3684cf 1248m4_popdef([b4_dollar_dollar])dnl
8ec0a172 1249m4_popdef([b4_at_dollar])])dnl
407d4a75
PE
1250m4_ifdef([b4_dollar_dollar_used],[[ yyvsp[0] = yylval;
1251]])dnl
1252m4_ifdef([b4_at_dollar_used], [[ yylsp[0] = yylloc;
9ca7f077
JD
1253]])[
1254 goto yysetstate;
10fa2066 1255
71da9eea
AD
1256/*------------------------------------------------------------.
1257| yynewstate -- Push a new state, which is found in yystate. |
1258`------------------------------------------------------------*/
342b8b6e 1259 yynewstate:
71da9eea 1260 /* In all cases, when you get here, the value and location stacks
9d9b8b70 1261 have just been pushed. So pushing a state here evens the stacks. */
cbd89906
PE
1262 yyssp++;
1263
342b8b6e 1264 yysetstate:
cbd89906 1265 *yyssp = yystate;
10fa2066 1266
39912f52 1267 if (yyss + yystacksize - 1 <= yyssp)
10fa2066 1268 {
10fa2066 1269 /* Get the current used size of the three stacks, in elements. */
7093d0f5 1270 YYSIZE_T yysize = yyssp - yyss + 1;
10fa2066
RS
1271
1272#ifdef yyoverflow
3d76b07d 1273 {
9d9b8b70 1274 /* Give user a chance to reallocate the stack. Use copies of
3d76b07d
AD
1275 these so that the &'s don't force the real ones into
1276 memory. */
1277 YYSTYPE *yyvs1 = yyvs;
9ca7f077
JD
1278 yytype_int16 *yyss1 = yyss;]b4_locations_if([
1279 YYLTYPE *yyls1 = yyls;])[
3d76b07d
AD
1280
1281 /* Each stack pointer address is followed by the size of the
58612f1d
AD
1282 data in use in that stack, in bytes. This used to be a
1283 conditional around just the two extra args, but that might
1284 be undefined if yyoverflow is a macro. */
1a059451 1285 yyoverflow (YY_("memory exhausted"),
7093d0f5 1286 &yyss1, yysize * sizeof (*yyssp),
9ca7f077
JD
1287 &yyvs1, yysize * sizeof (*yyvsp),]b4_locations_if([
1288 &yyls1, yysize * sizeof (*yylsp),])[
3d76b07d 1289 &yystacksize);
9ca7f077
JD
1290]b4_locations_if([
1291 yyls = yyls1;])[
3d76b07d
AD
1292 yyss = yyss1;
1293 yyvs = yyvs1;
1294 }
10fa2066 1295#else /* no yyoverflow */
cf44a9ae 1296# ifndef YYSTACK_RELOCATE
1a059451 1297 goto yyexhaustedlab;
cf44a9ae 1298# else
10fa2066 1299 /* Extend the stack our own way. */
39912f52 1300 if (YYMAXDEPTH <= yystacksize)
1a059451 1301 goto yyexhaustedlab;
10fa2066 1302 yystacksize *= 2;
39912f52 1303 if (YYMAXDEPTH < yystacksize)
10fa2066 1304 yystacksize = YYMAXDEPTH;
e9e4c321 1305
600f9b0c 1306 {
d42cf844 1307 yytype_int16 *yyss1 = yyss;
2729e106
PE
1308 union yyalloc *yyptr =
1309 (union yyalloc *) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize));
600f9b0c 1310 if (! yyptr)
1a059451 1311 goto yyexhaustedlab;
9ca7f077
JD
1312 YYSTACK_RELOCATE (yyss_alloc, yyss);
1313 YYSTACK_RELOCATE (yyvs_alloc, yyvs);]b4_locations_if([
1314 YYSTACK_RELOCATE (yyls_alloc, yyls);])[
cf44a9ae 1315# undef YYSTACK_RELOCATE
600f9b0c
PE
1316 if (yyss1 != yyssa)
1317 YYSTACK_FREE (yyss1);
1318 }
cf44a9ae 1319# endif
10fa2066
RS
1320#endif /* no yyoverflow */
1321
7093d0f5 1322 yyssp = yyss + yysize - 1;
9ca7f077
JD
1323 yyvsp = yyvs + yysize - 1;]b4_locations_if([
1324 yylsp = yyls + yysize - 1;])[
10fa2066 1325
30757c8c 1326 YYDPRINTF ((stderr, "Stack size increased to %lu\n",
600f9b0c 1327 (unsigned long int) yystacksize));
10fa2066 1328
39912f52 1329 if (yyss + yystacksize - 1 <= yyssp)
10fa2066
RS
1330 YYABORT;
1331 }
1332
30757c8c 1333 YYDPRINTF ((stderr, "Entering state %d\n", yystate));
10fa2066 1334
868d2d96
JD
1335 if (yystate == YYFINAL)
1336 YYACCEPT;
1337
10fa2066 1338 goto yybackup;
71da9eea 1339
71da9eea
AD
1340/*-----------.
1341| yybackup. |
1342`-----------*/
1343yybackup:
10fa2066 1344
a85284cf 1345 /* Do appropriate processing given the current state. Read a
742e4900 1346 lookahead token if we need one and don't already have one. */
10fa2066 1347
742e4900 1348 /* First try to decide what to do without reference to lookahead token. */
10fa2066 1349 yyn = yypact[yystate];
12b0043a 1350 if (yyn == YYPACT_NINF)
10fa2066
RS
1351 goto yydefault;
1352
742e4900 1353 /* Not known => get a lookahead token if don't already have one. */
10fa2066 1354
742e4900 1355 /* YYCHAR is either YYEMPTY or YYEOF or a valid lookahead symbol. */
a20713a4 1356 if (yychar == YYEMPTY)
fa6aa7b3
JD
1357 {]b4_push_if([[
1358 if (!yyps->yynew)
1359 {]b4_use_push_for_pull_if([], [[
1360 YYDPRINTF ((stderr, "Return for a new token:\n"));]])[
1361 yyresult = YYPUSH_MORE;
9ca7f077
JD
1362 goto yypushreturn;
1363 }
fa6aa7b3 1364 yyps->yynew = 0;]b4_pure_if([], [[
9ca7f077
JD
1365 /* Restoring the pushed token is only necessary for the first
1366 yypush_parse invocation since subsequent invocations don't overwrite
1367 it before jumping to yyread_pushed_token. */
1368 yychar = yypushed_char;
fa6aa7b3
JD
1369 yylval = yypushed_val;]b4_locations_if([[
1370 yylloc = yypushed_loc;]])])[
1371yyread_pushed_token:]])[
1372 YYDPRINTF ((stderr, "Reading a token: "));]b4_push_if([b4_pure_if([[
1373 yychar = yypushed_char;
9ca7f077 1374 if (yypushed_val)
fa6aa7b3
JD
1375 yylval = *yypushed_val;]b4_locations_if([[
1376 if (yypushed_loc)
1377 yylloc = *yypushed_loc;]])])], [[
1378 yychar = YYLEX;]])[
1379 }
10fa2066 1380
a20713a4 1381 if (yychar <= YYEOF)
10fa2066 1382 {
a20713a4 1383 yychar = yytoken = YYEOF;
2f4f028d 1384 YYDPRINTF ((stderr, "Now at end of input.\n"));
10fa2066
RS
1385 }
1386 else
1387 {
a20713a4 1388 yytoken = YYTRANSLATE (yychar);
30757c8c 1389 YY_SYMBOL_PRINT ("Next token is", yytoken, &yylval, &yylloc);
10fa2066
RS
1390 }
1391
b0400cc6 1392 /* If the proper action on seeing token YYTOKEN is to reduce or to
e5cfd9d8 1393 detect an error, take that action. */
b0400cc6 1394 yyn += yytoken;
34ec3579 1395 if (yyn < 0 || YYLAST < yyn || yycheck[yyn] != yytoken)
e5cfd9d8
PE
1396 goto yydefault;
1397 yyn = yytable[yyn];
1398 if (yyn <= 0)
10fa2066 1399 {
e5cfd9d8
PE
1400 if (yyn == 0 || yyn == YYTABLE_NINF)
1401 goto yyerrlab;
10fa2066
RS
1402 yyn = -yyn;
1403 goto yyreduce;
1404 }
10fa2066 1405
a85284cf
AD
1406 /* Count tokens shifted since error; after three, turn off error
1407 status. */
1408 if (yyerrstatus)
1409 yyerrstatus--;
1410
742e4900 1411 /* Shift the lookahead token. */
30757c8c 1412 YY_SYMBOL_PRINT ("Shifting", yytoken, &yylval, &yylloc);
10fa2066 1413
868d2d96
JD
1414 /* Discard the shifted token. */
1415 yychar = YYEMPTY;
10fa2066 1416
a85284cf 1417 yystate = yyn;
17da6427 1418 *++yyvsp = yylval;
327afc7c 1419]b4_locations_if([ *++yylsp = yylloc;])[
10fa2066
RS
1420 goto yynewstate;
1421
10fa2066 1422
71da9eea
AD
1423/*-----------------------------------------------------------.
1424| yydefault -- do the default action for the current state. |
1425`-----------------------------------------------------------*/
1426yydefault:
10fa2066
RS
1427 yyn = yydefact[yystate];
1428 if (yyn == 0)
1429 goto yyerrlab;
71da9eea 1430 goto yyreduce;
10fa2066 1431
71da9eea
AD
1432
1433/*-----------------------------.
1434| yyreduce -- Do a reduction. |
1435`-----------------------------*/
10fa2066 1436yyreduce:
71da9eea 1437 /* yyn is the number of a rule to reduce with. */
10fa2066 1438 yylen = yyr2[yyn];
da9abf43
AD
1439
1440 /* If YYLEN is nonzero, implement the default value of the action:
573c1d9f 1441 `$$ = $1'.
da9abf43 1442
accea6db
PE
1443 Otherwise, the following line sets YYVAL to garbage.
1444 This behavior is undocumented and Bison
da9abf43
AD
1445 users should not rely upon it. Assigning to YYVAL
1446 unconditionally makes the parser a bit smaller, and it avoids a
1447 GCC warning that YYVAL may be used uninitialized. */
1448 yyval = yyvsp[1-yylen];
3abcd459 1449
327afc7c 1450]b4_locations_if(
9d9b8b70 1451[[ /* Default location. */
401aace6 1452 YYLLOC_DEFAULT (yyloc, (yylsp - yylen), yylen);]])[
d9963c85 1453 YY_REDUCE_PRINT (yyn);
a8289c62 1454 switch (yyn)
d1ff7a7c 1455 {
8ec0a172 1456 ]b4_user_actions[
95f22ad2 1457 default: break;
a8289c62 1458 }
d1ff7a7c 1459 YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc);
897668ee 1460
a85284cf
AD
1461 YYPOPSTACK (yylen);
1462 yylen = 0;
b0937b22 1463 YY_STACK_PRINT (yyss, yyssp);
10fa2066 1464
9ca7f077
JD
1465 *++yyvsp = yyval;]b4_locations_if([
1466 *++yylsp = yyloc;])[
10fa2066 1467
41aca2e0
AD
1468 /* Now `shift' the result of the reduction. Determine what state
1469 that goes to, based on the state we popped back to and the rule
1470 number reduced by. */
10fa2066
RS
1471
1472 yyn = yyr1[yyn];
1473
7742ddeb 1474 yystate = yypgoto[yyn - YYNTOKENS] + *yyssp;
34ec3579 1475 if (0 <= yystate && yystate <= YYLAST && yycheck[yystate] == *yyssp)
10fa2066
RS
1476 yystate = yytable[yystate];
1477 else
7742ddeb 1478 yystate = yydefgoto[yyn - YYNTOKENS];
10fa2066
RS
1479
1480 goto yynewstate;
1481
10fa2066 1482
71da9eea
AD
1483/*------------------------------------.
1484| yyerrlab -- here on detecting error |
1485`------------------------------------*/
1486yyerrlab:
1487 /* If not already recovering from an error, report this error. */
1488 if (!yyerrstatus)
10fa2066 1489 {
17da6427 1490 ++yynerrs;
b4c1f9d2
PE
1491#if ! YYERROR_VERBOSE
1492 yyerror (]b4_yyerror_args[YY_("syntax error"));
1493#else
1494 {
1495 YYSIZE_T yysize = yysyntax_error (0, yystate, yychar);
1496 if (yymsg_alloc < yysize && yymsg_alloc < YYSTACK_ALLOC_MAXIMUM)
1497 {
1498 YYSIZE_T yyalloc = 2 * yysize;
1499 if (! (yysize <= yyalloc && yyalloc <= YYSTACK_ALLOC_MAXIMUM))
1500 yyalloc = YYSTACK_ALLOC_MAXIMUM;
1501 if (yymsg != yymsgbuf)
1502 YYSTACK_FREE (yymsg);
1503 yymsg = (char *) YYSTACK_ALLOC (yyalloc);
1504 if (yymsg)
1505 yymsg_alloc = yyalloc;
1506 else
3aa2f55d 1507 {
b4c1f9d2
PE
1508 yymsg = yymsgbuf;
1509 yymsg_alloc = sizeof yymsgbuf;
3aa2f55d 1510 }
b4c1f9d2 1511 }
df5aed8c 1512
b4c1f9d2
PE
1513 if (0 < yysize && yysize <= yymsg_alloc)
1514 {
1515 (void) yysyntax_error (yymsg, yystate, yychar);
1516 yyerror (]b4_yyerror_args[yymsg);
1517 }
1518 else
1519 {
1520 yyerror (]b4_yyerror_args[YY_("syntax error"));
1521 if (yysize != 0)
1a059451 1522 goto yyexhaustedlab;
b4c1f9d2
PE
1523 }
1524 }
1525#endif
10fa2066 1526 }
71da9eea 1527
327afc7c 1528]b4_locations_if([[ yyerror_range[0] = yylloc;]])[
d42f69cd 1529
10fa2066
RS
1530 if (yyerrstatus == 3)
1531 {
742e4900 1532 /* If just tried and failed to reuse lookahead token after an
71da9eea 1533 error, discard it. */
10fa2066 1534
a6b89bb2 1535 if (yychar <= YYEOF)
02650b7f 1536 {
258b75ca 1537 /* Return failure if at end of input. */
a6b89bb2 1538 if (yychar == YYEOF)
80ce3401 1539 YYABORT;
02650b7f 1540 }
a6b89bb2
PE
1541 else
1542 {
4b367315 1543 yydestruct ("Error: discarding",
327afc7c 1544 yytoken, &yylval]b4_locations_if([, &yylloc])[]b4_user_args[);
a6b89bb2 1545 yychar = YYEMPTY;
a6b89bb2 1546 }
10fa2066
RS
1547 }
1548
742e4900 1549 /* Else will try to reuse lookahead token after shifting the error
71da9eea 1550 token. */
8a3eb3c8 1551 goto yyerrlab1;
300a7966 1552
10fa2066 1553
a6b89bb2
PE
1554/*---------------------------------------------------.
1555| yyerrorlab -- error raised explicitly by YYERROR. |
1556`---------------------------------------------------*/
1557yyerrorlab:
1558
c7a65b99
PE
1559 /* Pacify compilers like GCC when the user code never invokes
1560 YYERROR and the label yyerrorlab therefore never appears in user
1561 code. */
2a4647a3 1562 if (/*CONSTCOND*/ 0)
a6b89bb2 1563 goto yyerrorlab;
a6b89bb2 1564
327afc7c 1565]b4_locations_if([[ yyerror_range[0] = yylsp[1-yylen];
a85284cf 1566]])[ /* Do not reclaim the symbols of the rule which action triggered
9d9b8b70 1567 this YYERROR. */
a85284cf
AD
1568 YYPOPSTACK (yylen);
1569 yylen = 0;
1570 YY_STACK_PRINT (yyss, yyssp);
a6b89bb2 1571 yystate = *yyssp;
3fc16193 1572 goto yyerrlab1;
a6b89bb2
PE
1573
1574
1575/*-------------------------------------------------------------.
1576| yyerrlab1 -- common code for both syntax error and YYERROR. |
1577`-------------------------------------------------------------*/
300a7966 1578yyerrlab1:
cf44a9ae 1579 yyerrstatus = 3; /* Each real token shifted decrements this. */
10fa2066 1580
660bc8dd
PE
1581 for (;;)
1582 {
1583 yyn = yypact[yystate];
12b0043a 1584 if (yyn != YYPACT_NINF)
660bc8dd
PE
1585 {
1586 yyn += YYTERROR;
1587 if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR)
1588 {
1589 yyn = yytable[yyn];
1590 if (0 < yyn)
1591 break;
1592 }
1593 }
10fa2066 1594
660bc8dd
PE
1595 /* Pop the current state because it cannot handle the error token. */
1596 if (yyssp == yyss)
1597 YYABORT;
5504898e 1598
327afc7c 1599]b4_locations_if([[ yyerror_range[0] = *yylsp;]])[
4b367315 1600 yydestruct ("Error: popping",
327afc7c 1601 yystos[yystate], yyvsp]b4_locations_if([, yylsp])[]b4_user_args[);
a85284cf 1602 YYPOPSTACK (1);
a6b89bb2 1603 yystate = *yyssp;
b0937b22 1604 YY_STACK_PRINT (yyss, yyssp);
10fa2066 1605 }
10fa2066 1606
17da6427 1607 *++yyvsp = yylval;
327afc7c 1608]b4_locations_if([[
3fc16193
AD
1609 yyerror_range[1] = yylloc;
1610 /* Using YYLLOC is tempting, but would change the location of
742e4900 1611 the lookahead. YYLOC is available though. */
401aace6 1612 YYLLOC_DEFAULT (yyloc, (yyerror_range - 1), 2);
3fc16193 1613 *++yylsp = yyloc;]])[
10fa2066 1614
9d9b8b70 1615 /* Shift the error token. */
30757c8c 1616 YY_SYMBOL_PRINT ("Shifting", yystos[yyn], yyvsp, yylsp);
1576d44d 1617
10fa2066
RS
1618 yystate = yyn;
1619 goto yynewstate;
70ddf897 1620
71da9eea
AD
1621
1622/*-------------------------------------.
1623| yyacceptlab -- YYACCEPT comes here. |
1624`-------------------------------------*/
1625yyacceptlab:
600f9b0c
PE
1626 yyresult = 0;
1627 goto yyreturn;
71da9eea
AD
1628
1629/*-----------------------------------.
1630| yyabortlab -- YYABORT comes here. |
1631`-----------------------------------*/
1632yyabortlab:
600f9b0c
PE
1633 yyresult = 1;
1634 goto yyreturn;
1635
a2ea208d 1636#if !defined(yyoverflow) || YYERROR_VERBOSE
1a059451
PE
1637/*-------------------------------------------------.
1638| yyexhaustedlab -- memory exhaustion comes here. |
1639`-------------------------------------------------*/
1640yyexhaustedlab:
1641 yyerror (]b4_yyerror_args[YY_("memory exhausted"));
600f9b0c
PE
1642 yyresult = 2;
1643 /* Fall through. */
0bfb02ff 1644#endif
600f9b0c
PE
1645
1646yyreturn:
868d2d96 1647 if (yychar != YYEMPTY)
dd5f2af2 1648 yydestruct ("Cleanup: discarding lookahead",
327afc7c 1649 yytoken, &yylval]b4_locations_if([, &yylloc])[]b4_user_args[);
a85284cf 1650 /* Do not reclaim the symbols of the rule which action triggered
9d9b8b70 1651 this YYABORT or YYACCEPT. */
a85284cf
AD
1652 YYPOPSTACK (yylen);
1653 YY_STACK_PRINT (yyss, yyssp);
258b75ca
PE
1654 while (yyssp != yyss)
1655 {
dd5f2af2 1656 yydestruct ("Cleanup: popping",
327afc7c 1657 yystos[*yyssp], yyvsp]b4_locations_if([, yylsp])[]b4_user_args[);
a85284cf 1658 YYPOPSTACK (1);
258b75ca 1659 }
600f9b0c
PE
1660#ifndef yyoverflow
1661 if (yyss != yyssa)
1662 YYSTACK_FREE (yyss);
b4c1f9d2 1663#endif
9ca7f077
JD
1664]b4_push_if([[ yyps->yynew = 1;
1665
1666yypushreturn:
1667]])[#if YYERROR_VERBOSE
b4c1f9d2
PE
1668 if (yymsg != yymsgbuf)
1669 YYSTACK_FREE (yymsg);
70ddf897 1670#endif
7b5cdcbd
JD
1671 /* Make sure YYID is used. */
1672 return YYID (yyresult);
9ca7f077 1673}
be2a1a68 1674
24c0aad7 1675
9ca7f077 1676]b4_epilogue
327afc7c 1677b4_defines_if(
0d2b2ab0 1678[@output(b4_spec_defines_file@)@
327afc7c 1679b4_copyright([Skeleton interface for Bison's Yacc-like parsers in C],dnl '
620b5727
JD
1680 [1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008,
1681 2009])
6e93d810 1682
a4e25e1d 1683b4_percent_code_get([[requires]])[]dnl
9bc0dd67 1684
cf147260 1685b4_token_enums_defines(b4_tokens)
be2a1a68 1686
9bc0dd67
JD
1687[#if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED
1688]m4_ifdef([b4_stype],
ddc8ede1 1689[[typedef union ]b4_union_name[
7ecec4dd 1690{
ddc8ede1 1691]b4_user_stype[
7ecec4dd 1692} YYSTYPE;
ddc8ede1
PE
1693# define YYSTYPE_IS_TRIVIAL 1]],
1694[m4_if(b4_tag_seen_flag, 0,
1695[[typedef int YYSTYPE;
1696# define YYSTYPE_IS_TRIVIAL 1]])])[
050c471b
PE
1697# define yystype YYSTYPE /* obsolescent; will be withdrawn */
1698# define YYSTYPE_IS_DECLARED 1
be2a1a68
AD
1699#endif
1700
9ca7f077 1701]b4_pure_if([], [[extern YYSTYPE ]b4_prefix[lval;]])
be2a1a68 1702
327afc7c 1703b4_locations_if(
02650b7f 1704[#if ! defined YYLTYPE && ! defined YYLTYPE_IS_DECLARED
050c471b 1705typedef struct YYLTYPE
be2a1a68
AD
1706{
1707 int first_line;
1708 int first_column;
1709 int last_line;
1710 int last_column;
050c471b
PE
1711} YYLTYPE;
1712# define yyltype YYLTYPE /* obsolescent; will be withdrawn */
1713# define YYLTYPE_IS_DECLARED 1
1714# define YYLTYPE_IS_TRIVIAL 1
be2a1a68 1715#endif
ff48177d 1716
9ca7f077 1717]b4_pure_if([], [[extern YYLTYPE ]b4_prefix[lloc;]])
9bc0dd67 1718)dnl b4_locations_if
9ca7f077
JD
1719b4_push_if([[
1720#ifndef YYPUSH_DECLS
1721# define YYPUSH_DECLS
1722struct ]b4_prefix[pstate;
1723typedef struct ]b4_prefix[pstate ]b4_prefix[pstate;
1724enum { YYPUSH_MORE = 4 };
1725]b4_pull_if([b4_c_function_decl([b4_prefix[parse]], [[int]], b4_parse_param)
1726])b4_c_function_decl([b4_prefix[push_parse]], [[int]],
1727 [[b4_prefix[pstate *yyps]], [[yyps]]]b4_pure_if([,
1728 [[[int yypushed_char]], [[yypushed_char]]],
1729 [[[YYSTYPE const *yypushed_val]], [[yypushed_val]]]b4_locations_if([,
1730 [[[YYLTYPE const *yypushed_loc]], [[yypushed_loc]]]])])m4_ifset([b4_parse_param], [,
1731 b4_parse_param]))
1732b4_pull_if([b4_c_function_decl([b4_prefix[pull_parse]], [[int]],
1733 [[b4_prefix[pstate *yyps]], [[yyps]]]m4_ifset([b4_parse_param], [,
1734 b4_parse_param]))])
1735b4_c_function_decl([b4_prefix[pstate_new]], [b4_prefix[pstate *]],
1736 [[[void]], []])
1737b4_c_function_decl([b4_prefix[pstate_delete]], [[void]],
1738 [[b4_prefix[pstate *yyps]], [[yyps]]])[
1739#endif
1740]])
1741b4_percent_code_get([[provides]])[]dnl
327afc7c 1742])dnl b4_defines_if
08af01c2 1743m4_divert_pop(0)