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