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