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