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