xref: /freebsd-src/contrib/byacc/test/btyacc/code_calc.code.c (revision 8e022d3cdea10ee1039a632f670c27fd93f65625)
10c8de5b0SBaptiste Daroussin /* original parser id follows */
20c8de5b0SBaptiste Daroussin /* yysccsid[] = "@(#)yaccpar	1.9 (Berkeley) 02/21/93" */
3c5b5d71aSJung-uk Kim /* (use YYMAJOR/YYMINOR for ifdefs dependent on parser version) */
40c8de5b0SBaptiste Daroussin 
50c8de5b0SBaptiste Daroussin #define YYBYACC 1
6*8e022d3cSDag-Erling Smørgrav #define YYMAJOR 2
7*8e022d3cSDag-Erling Smørgrav #define YYMINOR 0
80c8de5b0SBaptiste Daroussin #define YYCHECK "yyyymmdd"
90c8de5b0SBaptiste Daroussin 
100c8de5b0SBaptiste Daroussin #define YYEMPTY        (-1)
110c8de5b0SBaptiste Daroussin #define yyclearin      (yychar = YYEMPTY)
120c8de5b0SBaptiste Daroussin #define yyerrok        (yyerrflag = 0)
130c8de5b0SBaptiste Daroussin #define YYRECOVERING() (yyerrflag != 0)
140c8de5b0SBaptiste Daroussin #define YYENOMEM       (-2)
150c8de5b0SBaptiste Daroussin #define YYEOF          0
160c8de5b0SBaptiste Daroussin #undef YYBTYACC
170c8de5b0SBaptiste Daroussin #define YYBTYACC 0
180c8de5b0SBaptiste Daroussin #define YYDEBUGSTR YYPREFIX "debug"
190c8de5b0SBaptiste Daroussin 
200c8de5b0SBaptiste Daroussin #ifndef yyparse
210c8de5b0SBaptiste Daroussin #define yyparse    calc_parse
220c8de5b0SBaptiste Daroussin #endif /* yyparse */
230c8de5b0SBaptiste Daroussin 
240c8de5b0SBaptiste Daroussin #ifndef yylex
250c8de5b0SBaptiste Daroussin #define yylex      calc_lex
260c8de5b0SBaptiste Daroussin #endif /* yylex */
270c8de5b0SBaptiste Daroussin 
280c8de5b0SBaptiste Daroussin #ifndef yyerror
290c8de5b0SBaptiste Daroussin #define yyerror    calc_error
300c8de5b0SBaptiste Daroussin #endif /* yyerror */
310c8de5b0SBaptiste Daroussin 
320c8de5b0SBaptiste Daroussin #ifndef yychar
330c8de5b0SBaptiste Daroussin #define yychar     calc_char
340c8de5b0SBaptiste Daroussin #endif /* yychar */
350c8de5b0SBaptiste Daroussin 
360c8de5b0SBaptiste Daroussin #ifndef yyval
370c8de5b0SBaptiste Daroussin #define yyval      calc_val
380c8de5b0SBaptiste Daroussin #endif /* yyval */
390c8de5b0SBaptiste Daroussin 
400c8de5b0SBaptiste Daroussin #ifndef yylval
410c8de5b0SBaptiste Daroussin #define yylval     calc_lval
420c8de5b0SBaptiste Daroussin #endif /* yylval */
430c8de5b0SBaptiste Daroussin 
440c8de5b0SBaptiste Daroussin #ifndef yydebug
450c8de5b0SBaptiste Daroussin #define yydebug    calc_debug
460c8de5b0SBaptiste Daroussin #endif /* yydebug */
470c8de5b0SBaptiste Daroussin 
480c8de5b0SBaptiste Daroussin #ifndef yynerrs
490c8de5b0SBaptiste Daroussin #define yynerrs    calc_nerrs
500c8de5b0SBaptiste Daroussin #endif /* yynerrs */
510c8de5b0SBaptiste Daroussin 
520c8de5b0SBaptiste Daroussin #ifndef yyerrflag
530c8de5b0SBaptiste Daroussin #define yyerrflag  calc_errflag
540c8de5b0SBaptiste Daroussin #endif /* yyerrflag */
550c8de5b0SBaptiste Daroussin 
560c8de5b0SBaptiste Daroussin #ifndef yylhs
570c8de5b0SBaptiste Daroussin #define yylhs      calc_lhs
580c8de5b0SBaptiste Daroussin #endif /* yylhs */
590c8de5b0SBaptiste Daroussin 
600c8de5b0SBaptiste Daroussin #ifndef yylen
610c8de5b0SBaptiste Daroussin #define yylen      calc_len
620c8de5b0SBaptiste Daroussin #endif /* yylen */
630c8de5b0SBaptiste Daroussin 
640c8de5b0SBaptiste Daroussin #ifndef yydefred
650c8de5b0SBaptiste Daroussin #define yydefred   calc_defred
660c8de5b0SBaptiste Daroussin #endif /* yydefred */
670c8de5b0SBaptiste Daroussin 
680c8de5b0SBaptiste Daroussin #ifndef yystos
690c8de5b0SBaptiste Daroussin #define yystos     calc_stos
700c8de5b0SBaptiste Daroussin #endif /* yystos */
710c8de5b0SBaptiste Daroussin 
720c8de5b0SBaptiste Daroussin #ifndef yydgoto
730c8de5b0SBaptiste Daroussin #define yydgoto    calc_dgoto
740c8de5b0SBaptiste Daroussin #endif /* yydgoto */
750c8de5b0SBaptiste Daroussin 
760c8de5b0SBaptiste Daroussin #ifndef yysindex
770c8de5b0SBaptiste Daroussin #define yysindex   calc_sindex
780c8de5b0SBaptiste Daroussin #endif /* yysindex */
790c8de5b0SBaptiste Daroussin 
800c8de5b0SBaptiste Daroussin #ifndef yyrindex
810c8de5b0SBaptiste Daroussin #define yyrindex   calc_rindex
820c8de5b0SBaptiste Daroussin #endif /* yyrindex */
830c8de5b0SBaptiste Daroussin 
840c8de5b0SBaptiste Daroussin #ifndef yygindex
850c8de5b0SBaptiste Daroussin #define yygindex   calc_gindex
860c8de5b0SBaptiste Daroussin #endif /* yygindex */
870c8de5b0SBaptiste Daroussin 
880c8de5b0SBaptiste Daroussin #ifndef yytable
890c8de5b0SBaptiste Daroussin #define yytable    calc_table
900c8de5b0SBaptiste Daroussin #endif /* yytable */
910c8de5b0SBaptiste Daroussin 
920c8de5b0SBaptiste Daroussin #ifndef yycheck
930c8de5b0SBaptiste Daroussin #define yycheck    calc_check
940c8de5b0SBaptiste Daroussin #endif /* yycheck */
950c8de5b0SBaptiste Daroussin 
960c8de5b0SBaptiste Daroussin #ifndef yyname
970c8de5b0SBaptiste Daroussin #define yyname     calc_name
980c8de5b0SBaptiste Daroussin #endif /* yyname */
990c8de5b0SBaptiste Daroussin 
1000c8de5b0SBaptiste Daroussin #ifndef yyrule
1010c8de5b0SBaptiste Daroussin #define yyrule     calc_rule
1020c8de5b0SBaptiste Daroussin #endif /* yyrule */
1030c8de5b0SBaptiste Daroussin 
1040c8de5b0SBaptiste Daroussin #if YYBTYACC
1050c8de5b0SBaptiste Daroussin 
1060c8de5b0SBaptiste Daroussin #ifndef yycindex
1070c8de5b0SBaptiste Daroussin #define yycindex   calc_cindex
1080c8de5b0SBaptiste Daroussin #endif /* yycindex */
1090c8de5b0SBaptiste Daroussin 
1100c8de5b0SBaptiste Daroussin #ifndef yyctable
1110c8de5b0SBaptiste Daroussin #define yyctable   calc_ctable
1120c8de5b0SBaptiste Daroussin #endif /* yyctable */
1130c8de5b0SBaptiste Daroussin 
1140c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
1150c8de5b0SBaptiste Daroussin 
1160c8de5b0SBaptiste Daroussin #define YYPREFIX "calc_"
1170c8de5b0SBaptiste Daroussin 
1180c8de5b0SBaptiste Daroussin #define YYPURE 0
1190c8de5b0SBaptiste Daroussin 
120c5b5d71aSJung-uk Kim #line 4 "code_calc.y"
1210c8de5b0SBaptiste Daroussin # include <stdio.h>
1220c8de5b0SBaptiste Daroussin # include <ctype.h>
1230c8de5b0SBaptiste Daroussin 
1240c8de5b0SBaptiste Daroussin int regs[26];
1250c8de5b0SBaptiste Daroussin int base;
1260c8de5b0SBaptiste Daroussin 
1270c8de5b0SBaptiste Daroussin #ifdef YYBISON
1280c8de5b0SBaptiste Daroussin int yylex(void);
1290c8de5b0SBaptiste Daroussin static void yyerror(const char *s);
1300c8de5b0SBaptiste Daroussin #endif
1310c8de5b0SBaptiste Daroussin 
1320c8de5b0SBaptiste Daroussin #line 133 "code_calc.code.c"
1330c8de5b0SBaptiste Daroussin 
1340c8de5b0SBaptiste Daroussin #if ! defined(YYSTYPE) && ! defined(YYSTYPE_IS_DECLARED)
1350c8de5b0SBaptiste Daroussin /* Default: YYSTYPE is the semantic value type. */
1360c8de5b0SBaptiste Daroussin typedef int YYSTYPE;
1370c8de5b0SBaptiste Daroussin # define YYSTYPE_IS_DECLARED 1
1380c8de5b0SBaptiste Daroussin #endif
1390c8de5b0SBaptiste Daroussin 
1400c8de5b0SBaptiste Daroussin /* compatibility with bison */
1410c8de5b0SBaptiste Daroussin #ifdef YYPARSE_PARAM
1420c8de5b0SBaptiste Daroussin /* compatibility with FreeBSD */
1430c8de5b0SBaptiste Daroussin # ifdef YYPARSE_PARAM_TYPE
1440c8de5b0SBaptiste Daroussin #  define YYPARSE_DECL() yyparse(YYPARSE_PARAM_TYPE YYPARSE_PARAM)
1450c8de5b0SBaptiste Daroussin # else
1460c8de5b0SBaptiste Daroussin #  define YYPARSE_DECL() yyparse(void *YYPARSE_PARAM)
1470c8de5b0SBaptiste Daroussin # endif
1480c8de5b0SBaptiste Daroussin #else
1490c8de5b0SBaptiste Daroussin # define YYPARSE_DECL() yyparse(void)
1500c8de5b0SBaptiste Daroussin #endif
1510c8de5b0SBaptiste Daroussin 
1520c8de5b0SBaptiste Daroussin /* Parameters sent to lex. */
1530c8de5b0SBaptiste Daroussin #ifdef YYLEX_PARAM
1540c8de5b0SBaptiste Daroussin # define YYLEX_DECL() yylex(void *YYLEX_PARAM)
1550c8de5b0SBaptiste Daroussin # define YYLEX yylex(YYLEX_PARAM)
1560c8de5b0SBaptiste Daroussin #else
1570c8de5b0SBaptiste Daroussin # define YYLEX_DECL() yylex(void)
1580c8de5b0SBaptiste Daroussin # define YYLEX yylex()
1590c8de5b0SBaptiste Daroussin #endif
1600c8de5b0SBaptiste Daroussin 
1610c8de5b0SBaptiste Daroussin /* Parameters sent to yyerror. */
1620c8de5b0SBaptiste Daroussin #ifndef YYERROR_DECL
1630c8de5b0SBaptiste Daroussin #define YYERROR_DECL() yyerror(const char *s)
1640c8de5b0SBaptiste Daroussin #endif
1650c8de5b0SBaptiste Daroussin #ifndef YYERROR_CALL
1660c8de5b0SBaptiste Daroussin #define YYERROR_CALL(msg) yyerror(msg)
1670c8de5b0SBaptiste Daroussin #endif
1680c8de5b0SBaptiste Daroussin 
1690c8de5b0SBaptiste Daroussin #define DIGIT 257
1700c8de5b0SBaptiste Daroussin #define LETTER 258
1710c8de5b0SBaptiste Daroussin #define UMINUS 259
1720c8de5b0SBaptiste Daroussin #define YYERRCODE 256
173c5b5d71aSJung-uk Kim #undef yytname
174c5b5d71aSJung-uk Kim #define yytname yyname
1750c8de5b0SBaptiste Daroussin #define YYTABLESIZE 220
1760c8de5b0SBaptiste Daroussin #define YYFINAL 1
1770c8de5b0SBaptiste Daroussin #ifndef YYDEBUG
1780c8de5b0SBaptiste Daroussin #define YYDEBUG 0
1790c8de5b0SBaptiste Daroussin #endif
1800c8de5b0SBaptiste Daroussin #define YYMAXTOKEN 259
1810c8de5b0SBaptiste Daroussin #define YYUNDFTOKEN 265
1820c8de5b0SBaptiste Daroussin #define YYTRANSLATE(a) ((a) > YYMAXTOKEN ? YYUNDFTOKEN : (a))
1830c8de5b0SBaptiste Daroussin 
1840c8de5b0SBaptiste Daroussin extern int YYPARSE_DECL();
185b53bb29fSJung-uk Kim typedef int YYINT;
1860c8de5b0SBaptiste Daroussin extern const YYINT yylhs[];
1870c8de5b0SBaptiste Daroussin extern const YYINT yylen[];
1880c8de5b0SBaptiste Daroussin extern const YYINT yydefred[];
1890c8de5b0SBaptiste Daroussin extern const YYINT yystos[];
1900c8de5b0SBaptiste Daroussin extern const YYINT yydgoto[];
1910c8de5b0SBaptiste Daroussin extern const YYINT yysindex[];
1920c8de5b0SBaptiste Daroussin extern const YYINT yyrindex[];
1930c8de5b0SBaptiste Daroussin #if YYBTYACC
1940c8de5b0SBaptiste Daroussin extern const YYINT yycindex[];
1950c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
1960c8de5b0SBaptiste Daroussin extern const YYINT yygindex[];
1970c8de5b0SBaptiste Daroussin extern const YYINT yytable[];
1980c8de5b0SBaptiste Daroussin extern const YYINT yycheck[];
1990c8de5b0SBaptiste Daroussin #if YYBTYACC
2000c8de5b0SBaptiste Daroussin extern const YYINT yyctable[];
2010c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
2020c8de5b0SBaptiste Daroussin 
203c5b5d71aSJung-uk Kim #if YYDEBUG || defined(yytname)
2040c8de5b0SBaptiste Daroussin extern const char *const yyname[];
205c5b5d71aSJung-uk Kim #endif
206c5b5d71aSJung-uk Kim #if YYDEBUG
2070c8de5b0SBaptiste Daroussin extern const char *const yyrule[];
2080c8de5b0SBaptiste Daroussin #endif
2090c8de5b0SBaptiste Daroussin 
210b53bb29fSJung-uk Kim #if YYDEBUG
2110c8de5b0SBaptiste Daroussin int      yydebug;
212b53bb29fSJung-uk Kim #endif
2130c8de5b0SBaptiste Daroussin 
2140c8de5b0SBaptiste Daroussin int      yyerrflag;
2150c8de5b0SBaptiste Daroussin int      yychar;
2160c8de5b0SBaptiste Daroussin YYSTYPE  yyval;
2170c8de5b0SBaptiste Daroussin YYSTYPE  yylval;
218b53bb29fSJung-uk Kim int      yynerrs;
219b53bb29fSJung-uk Kim 
2200c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
2210c8de5b0SBaptiste Daroussin YYLTYPE  yyloc; /* position returned by actions */
2220c8de5b0SBaptiste Daroussin YYLTYPE  yylloc; /* position from the lexer */
2230c8de5b0SBaptiste Daroussin #endif
2240c8de5b0SBaptiste Daroussin 
2250c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
2260c8de5b0SBaptiste Daroussin #ifndef YYLLOC_DEFAULT
2270c8de5b0SBaptiste Daroussin #define YYLLOC_DEFAULT(loc, rhs, n) \
2280c8de5b0SBaptiste Daroussin do \
2290c8de5b0SBaptiste Daroussin { \
2300c8de5b0SBaptiste Daroussin     if (n == 0) \
2310c8de5b0SBaptiste Daroussin     { \
232b53bb29fSJung-uk Kim         (loc).first_line   = YYRHSLOC(rhs, 0).last_line; \
233b53bb29fSJung-uk Kim         (loc).first_column = YYRHSLOC(rhs, 0).last_column; \
234b53bb29fSJung-uk Kim         (loc).last_line    = YYRHSLOC(rhs, 0).last_line; \
235b53bb29fSJung-uk Kim         (loc).last_column  = YYRHSLOC(rhs, 0).last_column; \
2360c8de5b0SBaptiste Daroussin     } \
2370c8de5b0SBaptiste Daroussin     else \
2380c8de5b0SBaptiste Daroussin     { \
239b53bb29fSJung-uk Kim         (loc).first_line   = YYRHSLOC(rhs, 1).first_line; \
240b53bb29fSJung-uk Kim         (loc).first_column = YYRHSLOC(rhs, 1).first_column; \
241b53bb29fSJung-uk Kim         (loc).last_line    = YYRHSLOC(rhs, n).last_line; \
242b53bb29fSJung-uk Kim         (loc).last_column  = YYRHSLOC(rhs, n).last_column; \
2430c8de5b0SBaptiste Daroussin     } \
2440c8de5b0SBaptiste Daroussin } while (0)
2450c8de5b0SBaptiste Daroussin #endif /* YYLLOC_DEFAULT */
2460c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
2470c8de5b0SBaptiste Daroussin #if YYBTYACC
2480c8de5b0SBaptiste Daroussin 
2490c8de5b0SBaptiste Daroussin #ifndef YYLVQUEUEGROWTH
2500c8de5b0SBaptiste Daroussin #define YYLVQUEUEGROWTH 32
2510c8de5b0SBaptiste Daroussin #endif
2520c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
2530c8de5b0SBaptiste Daroussin 
2540c8de5b0SBaptiste Daroussin /* define the initial stack-sizes */
2550c8de5b0SBaptiste Daroussin #ifdef YYSTACKSIZE
2560c8de5b0SBaptiste Daroussin #undef YYMAXDEPTH
2570c8de5b0SBaptiste Daroussin #define YYMAXDEPTH  YYSTACKSIZE
2580c8de5b0SBaptiste Daroussin #else
2590c8de5b0SBaptiste Daroussin #ifdef YYMAXDEPTH
2600c8de5b0SBaptiste Daroussin #define YYSTACKSIZE YYMAXDEPTH
2610c8de5b0SBaptiste Daroussin #else
2620c8de5b0SBaptiste Daroussin #define YYSTACKSIZE 10000
2630c8de5b0SBaptiste Daroussin #define YYMAXDEPTH  10000
2640c8de5b0SBaptiste Daroussin #endif
2650c8de5b0SBaptiste Daroussin #endif
2660c8de5b0SBaptiste Daroussin 
2670c8de5b0SBaptiste Daroussin #ifndef YYINITSTACKSIZE
2680c8de5b0SBaptiste Daroussin #define YYINITSTACKSIZE 200
2690c8de5b0SBaptiste Daroussin #endif
2700c8de5b0SBaptiste Daroussin 
2710c8de5b0SBaptiste Daroussin typedef struct {
2720c8de5b0SBaptiste Daroussin     unsigned stacksize;
273c5b5d71aSJung-uk Kim     YYINT    *s_base;
274c5b5d71aSJung-uk Kim     YYINT    *s_mark;
275c5b5d71aSJung-uk Kim     YYINT    *s_last;
2760c8de5b0SBaptiste Daroussin     YYSTYPE  *l_base;
2770c8de5b0SBaptiste Daroussin     YYSTYPE  *l_mark;
2780c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
2790c8de5b0SBaptiste Daroussin     YYLTYPE  *p_base;
2800c8de5b0SBaptiste Daroussin     YYLTYPE  *p_mark;
2810c8de5b0SBaptiste Daroussin #endif
2820c8de5b0SBaptiste Daroussin } YYSTACKDATA;
2830c8de5b0SBaptiste Daroussin #if YYBTYACC
2840c8de5b0SBaptiste Daroussin 
2850c8de5b0SBaptiste Daroussin struct YYParseState_s
2860c8de5b0SBaptiste Daroussin {
2870c8de5b0SBaptiste Daroussin     struct YYParseState_s *save;    /* Previously saved parser state */
2880c8de5b0SBaptiste Daroussin     YYSTACKDATA            yystack; /* saved parser stack */
2890c8de5b0SBaptiste Daroussin     int                    state;   /* saved parser state */
2900c8de5b0SBaptiste Daroussin     int                    errflag; /* saved error recovery status */
2910c8de5b0SBaptiste Daroussin     int                    lexeme;  /* saved index of the conflict lexeme in the lexical queue */
2920c8de5b0SBaptiste Daroussin     YYINT                  ctry;    /* saved index in yyctable[] for this conflict */
2930c8de5b0SBaptiste Daroussin };
2940c8de5b0SBaptiste Daroussin typedef struct YYParseState_s YYParseState;
2950c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
2960c8de5b0SBaptiste Daroussin /* variables for the parser stack */
2970c8de5b0SBaptiste Daroussin static YYSTACKDATA yystack;
2980c8de5b0SBaptiste Daroussin #if YYBTYACC
2990c8de5b0SBaptiste Daroussin 
3000c8de5b0SBaptiste Daroussin /* Current parser state */
3010c8de5b0SBaptiste Daroussin static YYParseState *yyps = 0;
3020c8de5b0SBaptiste Daroussin 
3030c8de5b0SBaptiste Daroussin /* yypath != NULL: do the full parse, starting at *yypath parser state. */
3040c8de5b0SBaptiste Daroussin static YYParseState *yypath = 0;
3050c8de5b0SBaptiste Daroussin 
3060c8de5b0SBaptiste Daroussin /* Base of the lexical value queue */
3070c8de5b0SBaptiste Daroussin static YYSTYPE *yylvals = 0;
3080c8de5b0SBaptiste Daroussin 
3090c8de5b0SBaptiste Daroussin /* Current position at lexical value queue */
3100c8de5b0SBaptiste Daroussin static YYSTYPE *yylvp = 0;
3110c8de5b0SBaptiste Daroussin 
3120c8de5b0SBaptiste Daroussin /* End position of lexical value queue */
3130c8de5b0SBaptiste Daroussin static YYSTYPE *yylve = 0;
3140c8de5b0SBaptiste Daroussin 
3150c8de5b0SBaptiste Daroussin /* The last allocated position at the lexical value queue */
3160c8de5b0SBaptiste Daroussin static YYSTYPE *yylvlim = 0;
3170c8de5b0SBaptiste Daroussin 
3180c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
3190c8de5b0SBaptiste Daroussin /* Base of the lexical position queue */
3200c8de5b0SBaptiste Daroussin static YYLTYPE *yylpsns = 0;
3210c8de5b0SBaptiste Daroussin 
3220c8de5b0SBaptiste Daroussin /* Current position at lexical position queue */
3230c8de5b0SBaptiste Daroussin static YYLTYPE *yylpp = 0;
3240c8de5b0SBaptiste Daroussin 
3250c8de5b0SBaptiste Daroussin /* End position of lexical position queue */
3260c8de5b0SBaptiste Daroussin static YYLTYPE *yylpe = 0;
3270c8de5b0SBaptiste Daroussin 
3280c8de5b0SBaptiste Daroussin /* The last allocated position at the lexical position queue */
3290c8de5b0SBaptiste Daroussin static YYLTYPE *yylplim = 0;
3300c8de5b0SBaptiste Daroussin #endif
3310c8de5b0SBaptiste Daroussin 
3320c8de5b0SBaptiste Daroussin /* Current position at lexical token queue */
3332aca18c7SJung-uk Kim static YYINT  *yylexp = 0;
3340c8de5b0SBaptiste Daroussin 
3352aca18c7SJung-uk Kim static YYINT  *yylexemes = 0;
3360c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
337c5b5d71aSJung-uk Kim #line 70 "code_calc.y"
3380c8de5b0SBaptiste Daroussin  /* start of programs */
3390c8de5b0SBaptiste Daroussin 
3400c8de5b0SBaptiste Daroussin #ifdef YYBYACC
3410c8de5b0SBaptiste Daroussin extern int YYLEX_DECL();
3420c8de5b0SBaptiste Daroussin #endif
3430c8de5b0SBaptiste Daroussin 
3440c8de5b0SBaptiste Daroussin int
main(void)3450c8de5b0SBaptiste Daroussin main (void)
3460c8de5b0SBaptiste Daroussin {
3470c8de5b0SBaptiste Daroussin     while(!feof(stdin)) {
3480c8de5b0SBaptiste Daroussin 	yyparse();
3490c8de5b0SBaptiste Daroussin     }
3500c8de5b0SBaptiste Daroussin     return 0;
3510c8de5b0SBaptiste Daroussin }
3520c8de5b0SBaptiste Daroussin 
3530c8de5b0SBaptiste Daroussin static void
yyerror(const char * s)3540c8de5b0SBaptiste Daroussin yyerror(const char *s)
3550c8de5b0SBaptiste Daroussin {
3560c8de5b0SBaptiste Daroussin     fprintf(stderr, "%s\n", s);
3570c8de5b0SBaptiste Daroussin }
3580c8de5b0SBaptiste Daroussin 
3590c8de5b0SBaptiste Daroussin int
yylex(void)3600c8de5b0SBaptiste Daroussin yylex(void)
3610c8de5b0SBaptiste Daroussin {
3620c8de5b0SBaptiste Daroussin 	/* lexical analysis routine */
3630c8de5b0SBaptiste Daroussin 	/* returns LETTER for a lower case letter, yylval = 0 through 25 */
3640c8de5b0SBaptiste Daroussin 	/* return DIGIT for a digit, yylval = 0 through 9 */
3650c8de5b0SBaptiste Daroussin 	/* all other characters are returned immediately */
3660c8de5b0SBaptiste Daroussin 
3670c8de5b0SBaptiste Daroussin     int c;
3680c8de5b0SBaptiste Daroussin 
3690c8de5b0SBaptiste Daroussin     while( (c=getchar()) == ' ' )   { /* skip blanks */ }
3700c8de5b0SBaptiste Daroussin 
3710c8de5b0SBaptiste Daroussin     /* c is now nonblank */
3720c8de5b0SBaptiste Daroussin 
3730c8de5b0SBaptiste Daroussin     if( islower( c )) {
3740c8de5b0SBaptiste Daroussin 	yylval = c - 'a';
3750c8de5b0SBaptiste Daroussin 	return ( LETTER );
3760c8de5b0SBaptiste Daroussin     }
3770c8de5b0SBaptiste Daroussin     if( isdigit( c )) {
3780c8de5b0SBaptiste Daroussin 	yylval = c - '0';
3790c8de5b0SBaptiste Daroussin 	return ( DIGIT );
3800c8de5b0SBaptiste Daroussin     }
3810c8de5b0SBaptiste Daroussin     return( c );
3820c8de5b0SBaptiste Daroussin }
383b53bb29fSJung-uk Kim #line 384 "code_calc.code.c"
3840c8de5b0SBaptiste Daroussin 
3850c8de5b0SBaptiste Daroussin /* For use in generated program */
3860c8de5b0SBaptiste Daroussin #define yydepth (int)(yystack.s_mark - yystack.s_base)
3870c8de5b0SBaptiste Daroussin #if YYBTYACC
3880c8de5b0SBaptiste Daroussin #define yytrial (yyps->save)
3890c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
3900c8de5b0SBaptiste Daroussin 
3910c8de5b0SBaptiste Daroussin #if YYDEBUG
3920c8de5b0SBaptiste Daroussin #include <stdio.h>	/* needed for printf */
3930c8de5b0SBaptiste Daroussin #endif
3940c8de5b0SBaptiste Daroussin 
3950c8de5b0SBaptiste Daroussin #include <stdlib.h>	/* needed for malloc, etc */
3960c8de5b0SBaptiste Daroussin #include <string.h>	/* needed for memset */
3970c8de5b0SBaptiste Daroussin 
3980c8de5b0SBaptiste Daroussin /* allocate initial stack or double stack size, up to YYMAXDEPTH */
yygrowstack(YYSTACKDATA * data)3990c8de5b0SBaptiste Daroussin static int yygrowstack(YYSTACKDATA *data)
4000c8de5b0SBaptiste Daroussin {
4010c8de5b0SBaptiste Daroussin     int i;
4020c8de5b0SBaptiste Daroussin     unsigned newsize;
403c5b5d71aSJung-uk Kim     YYINT *newss;
4040c8de5b0SBaptiste Daroussin     YYSTYPE *newvs;
4050c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
4060c8de5b0SBaptiste Daroussin     YYLTYPE *newps;
4070c8de5b0SBaptiste Daroussin #endif
4080c8de5b0SBaptiste Daroussin 
4090c8de5b0SBaptiste Daroussin     if ((newsize = data->stacksize) == 0)
4100c8de5b0SBaptiste Daroussin         newsize = YYINITSTACKSIZE;
4110c8de5b0SBaptiste Daroussin     else if (newsize >= YYMAXDEPTH)
4120c8de5b0SBaptiste Daroussin         return YYENOMEM;
4130c8de5b0SBaptiste Daroussin     else if ((newsize *= 2) > YYMAXDEPTH)
4140c8de5b0SBaptiste Daroussin         newsize = YYMAXDEPTH;
4150c8de5b0SBaptiste Daroussin 
4160c8de5b0SBaptiste Daroussin     i = (int) (data->s_mark - data->s_base);
417c5b5d71aSJung-uk Kim     newss = (YYINT *)realloc(data->s_base, newsize * sizeof(*newss));
418bf80e08eSJung-uk Kim     if (newss == NULL)
4190c8de5b0SBaptiste Daroussin         return YYENOMEM;
4200c8de5b0SBaptiste Daroussin 
4210c8de5b0SBaptiste Daroussin     data->s_base = newss;
4220c8de5b0SBaptiste Daroussin     data->s_mark = newss + i;
4230c8de5b0SBaptiste Daroussin 
4240c8de5b0SBaptiste Daroussin     newvs = (YYSTYPE *)realloc(data->l_base, newsize * sizeof(*newvs));
425bf80e08eSJung-uk Kim     if (newvs == NULL)
4260c8de5b0SBaptiste Daroussin         return YYENOMEM;
4270c8de5b0SBaptiste Daroussin 
4280c8de5b0SBaptiste Daroussin     data->l_base = newvs;
4290c8de5b0SBaptiste Daroussin     data->l_mark = newvs + i;
4300c8de5b0SBaptiste Daroussin 
4310c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
4320c8de5b0SBaptiste Daroussin     newps = (YYLTYPE *)realloc(data->p_base, newsize * sizeof(*newps));
433bf80e08eSJung-uk Kim     if (newps == NULL)
4340c8de5b0SBaptiste Daroussin         return YYENOMEM;
4350c8de5b0SBaptiste Daroussin 
4360c8de5b0SBaptiste Daroussin     data->p_base = newps;
4370c8de5b0SBaptiste Daroussin     data->p_mark = newps + i;
4380c8de5b0SBaptiste Daroussin #endif
4390c8de5b0SBaptiste Daroussin 
4400c8de5b0SBaptiste Daroussin     data->stacksize = newsize;
4410c8de5b0SBaptiste Daroussin     data->s_last = data->s_base + newsize - 1;
4420c8de5b0SBaptiste Daroussin 
4430c8de5b0SBaptiste Daroussin #if YYDEBUG
4440c8de5b0SBaptiste Daroussin     if (yydebug)
4450c8de5b0SBaptiste Daroussin         fprintf(stderr, "%sdebug: stack size increased to %d\n", YYPREFIX, newsize);
4460c8de5b0SBaptiste Daroussin #endif
4470c8de5b0SBaptiste Daroussin     return 0;
4480c8de5b0SBaptiste Daroussin }
4490c8de5b0SBaptiste Daroussin 
4500c8de5b0SBaptiste Daroussin #if YYPURE || defined(YY_NO_LEAKS)
yyfreestack(YYSTACKDATA * data)4510c8de5b0SBaptiste Daroussin static void yyfreestack(YYSTACKDATA *data)
4520c8de5b0SBaptiste Daroussin {
4530c8de5b0SBaptiste Daroussin     free(data->s_base);
4540c8de5b0SBaptiste Daroussin     free(data->l_base);
4550c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
4560c8de5b0SBaptiste Daroussin     free(data->p_base);
4570c8de5b0SBaptiste Daroussin #endif
4580c8de5b0SBaptiste Daroussin     memset(data, 0, sizeof(*data));
4590c8de5b0SBaptiste Daroussin }
4600c8de5b0SBaptiste Daroussin #else
4610c8de5b0SBaptiste Daroussin #define yyfreestack(data) /* nothing */
4620c8de5b0SBaptiste Daroussin #endif /* YYPURE || defined(YY_NO_LEAKS) */
4630c8de5b0SBaptiste Daroussin #if YYBTYACC
4640c8de5b0SBaptiste Daroussin 
4650c8de5b0SBaptiste Daroussin static YYParseState *
yyNewState(unsigned size)4660c8de5b0SBaptiste Daroussin yyNewState(unsigned size)
4670c8de5b0SBaptiste Daroussin {
4680c8de5b0SBaptiste Daroussin     YYParseState *p = (YYParseState *) malloc(sizeof(YYParseState));
4690c8de5b0SBaptiste Daroussin     if (p == NULL) return NULL;
4700c8de5b0SBaptiste Daroussin 
4710c8de5b0SBaptiste Daroussin     p->yystack.stacksize = size;
4720c8de5b0SBaptiste Daroussin     if (size == 0)
4730c8de5b0SBaptiste Daroussin     {
4740c8de5b0SBaptiste Daroussin         p->yystack.s_base = NULL;
4750c8de5b0SBaptiste Daroussin         p->yystack.l_base = NULL;
4760c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
4770c8de5b0SBaptiste Daroussin         p->yystack.p_base = NULL;
4780c8de5b0SBaptiste Daroussin #endif
4790c8de5b0SBaptiste Daroussin         return p;
4800c8de5b0SBaptiste Daroussin     }
481c5b5d71aSJung-uk Kim     p->yystack.s_base    = (YYINT *) malloc(size * sizeof(YYINT));
4820c8de5b0SBaptiste Daroussin     if (p->yystack.s_base == NULL) return NULL;
4830c8de5b0SBaptiste Daroussin     p->yystack.l_base    = (YYSTYPE *) malloc(size * sizeof(YYSTYPE));
4840c8de5b0SBaptiste Daroussin     if (p->yystack.l_base == NULL) return NULL;
4850c8de5b0SBaptiste Daroussin     memset(p->yystack.l_base, 0, size * sizeof(YYSTYPE));
4860c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
4870c8de5b0SBaptiste Daroussin     p->yystack.p_base    = (YYLTYPE *) malloc(size * sizeof(YYLTYPE));
4880c8de5b0SBaptiste Daroussin     if (p->yystack.p_base == NULL) return NULL;
4890c8de5b0SBaptiste Daroussin     memset(p->yystack.p_base, 0, size * sizeof(YYLTYPE));
4900c8de5b0SBaptiste Daroussin #endif
4910c8de5b0SBaptiste Daroussin 
4920c8de5b0SBaptiste Daroussin     return p;
4930c8de5b0SBaptiste Daroussin }
4940c8de5b0SBaptiste Daroussin 
4950c8de5b0SBaptiste Daroussin static void
yyFreeState(YYParseState * p)4960c8de5b0SBaptiste Daroussin yyFreeState(YYParseState *p)
4970c8de5b0SBaptiste Daroussin {
4980c8de5b0SBaptiste Daroussin     yyfreestack(&p->yystack);
4990c8de5b0SBaptiste Daroussin     free(p);
5000c8de5b0SBaptiste Daroussin }
5010c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
5020c8de5b0SBaptiste Daroussin 
5030c8de5b0SBaptiste Daroussin #define YYABORT  goto yyabort
5040c8de5b0SBaptiste Daroussin #define YYREJECT goto yyabort
5050c8de5b0SBaptiste Daroussin #define YYACCEPT goto yyaccept
5060c8de5b0SBaptiste Daroussin #define YYERROR  goto yyerrlab
5070c8de5b0SBaptiste Daroussin #if YYBTYACC
5080c8de5b0SBaptiste Daroussin #define YYVALID        do { if (yyps->save)            goto yyvalid; } while(0)
5090c8de5b0SBaptiste Daroussin #define YYVALID_NESTED do { if (yyps->save && \
5100c8de5b0SBaptiste Daroussin                                 yyps->save->save == 0) goto yyvalid; } while(0)
5110c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
5120c8de5b0SBaptiste Daroussin 
5130c8de5b0SBaptiste Daroussin int
YYPARSE_DECL()5140c8de5b0SBaptiste Daroussin YYPARSE_DECL()
5150c8de5b0SBaptiste Daroussin {
5160c8de5b0SBaptiste Daroussin     int yym, yyn, yystate, yyresult;
5170c8de5b0SBaptiste Daroussin #if YYBTYACC
5180c8de5b0SBaptiste Daroussin     int yynewerrflag;
5190c8de5b0SBaptiste Daroussin     YYParseState *yyerrctx = NULL;
5200c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
5210c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
522b53bb29fSJung-uk Kim     YYLTYPE  yyerror_loc_range[3]; /* position of error start/end (0 unused) */
5230c8de5b0SBaptiste Daroussin #endif
5240c8de5b0SBaptiste Daroussin #if YYDEBUG
5250c8de5b0SBaptiste Daroussin     const char *yys;
5260c8de5b0SBaptiste Daroussin 
527bf80e08eSJung-uk Kim     if ((yys = getenv("YYDEBUG")) != NULL)
5280c8de5b0SBaptiste Daroussin     {
5290c8de5b0SBaptiste Daroussin         yyn = *yys;
5300c8de5b0SBaptiste Daroussin         if (yyn >= '0' && yyn <= '9')
5310c8de5b0SBaptiste Daroussin             yydebug = yyn - '0';
5320c8de5b0SBaptiste Daroussin     }
5330c8de5b0SBaptiste Daroussin     if (yydebug)
5340c8de5b0SBaptiste Daroussin         fprintf(stderr, "%sdebug[<# of symbols on state stack>]\n", YYPREFIX);
5350c8de5b0SBaptiste Daroussin #endif
5366166fdceSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
5376166fdceSJung-uk Kim     memset(yyerror_loc_range, 0, sizeof(yyerror_loc_range));
5386166fdceSJung-uk Kim #endif
5390c8de5b0SBaptiste Daroussin 
5400c8de5b0SBaptiste Daroussin #if YYBTYACC
5410c8de5b0SBaptiste Daroussin     yyps = yyNewState(0); if (yyps == 0) goto yyenomem;
5420c8de5b0SBaptiste Daroussin     yyps->save = 0;
5430c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
544c5b5d71aSJung-uk Kim     yym = 0;
545*8e022d3cSDag-Erling Smørgrav     /* yyn is set below */
5460c8de5b0SBaptiste Daroussin     yynerrs = 0;
5470c8de5b0SBaptiste Daroussin     yyerrflag = 0;
5480c8de5b0SBaptiste Daroussin     yychar = YYEMPTY;
5490c8de5b0SBaptiste Daroussin     yystate = 0;
5500c8de5b0SBaptiste Daroussin 
5510c8de5b0SBaptiste Daroussin #if YYPURE
5520c8de5b0SBaptiste Daroussin     memset(&yystack, 0, sizeof(yystack));
5530c8de5b0SBaptiste Daroussin #endif
5540c8de5b0SBaptiste Daroussin 
5550c8de5b0SBaptiste Daroussin     if (yystack.s_base == NULL && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
5560c8de5b0SBaptiste Daroussin     yystack.s_mark = yystack.s_base;
5570c8de5b0SBaptiste Daroussin     yystack.l_mark = yystack.l_base;
5580c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
5590c8de5b0SBaptiste Daroussin     yystack.p_mark = yystack.p_base;
5600c8de5b0SBaptiste Daroussin #endif
5610c8de5b0SBaptiste Daroussin     yystate = 0;
5620c8de5b0SBaptiste Daroussin     *yystack.s_mark = 0;
5630c8de5b0SBaptiste Daroussin 
5640c8de5b0SBaptiste Daroussin yyloop:
5650c8de5b0SBaptiste Daroussin     if ((yyn = yydefred[yystate]) != 0) goto yyreduce;
5660c8de5b0SBaptiste Daroussin     if (yychar < 0)
5670c8de5b0SBaptiste Daroussin     {
5680c8de5b0SBaptiste Daroussin #if YYBTYACC
5690c8de5b0SBaptiste Daroussin         do {
5700c8de5b0SBaptiste Daroussin         if (yylvp < yylve)
5710c8de5b0SBaptiste Daroussin         {
5720c8de5b0SBaptiste Daroussin             /* we're currently re-reading tokens */
5730c8de5b0SBaptiste Daroussin             yylval = *yylvp++;
5740c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
5750c8de5b0SBaptiste Daroussin             yylloc = *yylpp++;
5760c8de5b0SBaptiste Daroussin #endif
5770c8de5b0SBaptiste Daroussin             yychar = *yylexp++;
5780c8de5b0SBaptiste Daroussin             break;
5790c8de5b0SBaptiste Daroussin         }
5800c8de5b0SBaptiste Daroussin         if (yyps->save)
5810c8de5b0SBaptiste Daroussin         {
5820c8de5b0SBaptiste Daroussin             /* in trial mode; save scanner results for future parse attempts */
5830c8de5b0SBaptiste Daroussin             if (yylvp == yylvlim)
5840c8de5b0SBaptiste Daroussin             {   /* Enlarge lexical value queue */
58511fce282SBaptiste Daroussin                 size_t p = (size_t) (yylvp - yylvals);
58611fce282SBaptiste Daroussin                 size_t s = (size_t) (yylvlim - yylvals);
5870c8de5b0SBaptiste Daroussin 
5880c8de5b0SBaptiste Daroussin                 s += YYLVQUEUEGROWTH;
589b53bb29fSJung-uk Kim                 if ((yylexemes = (YYINT *)realloc(yylexemes, s * sizeof(YYINT))) == NULL) goto yyenomem;
590b53bb29fSJung-uk Kim                 if ((yylvals   = (YYSTYPE *)realloc(yylvals, s * sizeof(YYSTYPE))) == NULL) goto yyenomem;
5910c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
592b53bb29fSJung-uk Kim                 if ((yylpsns   = (YYLTYPE *)realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL) goto yyenomem;
5930c8de5b0SBaptiste Daroussin #endif
5940c8de5b0SBaptiste Daroussin                 yylvp   = yylve = yylvals + p;
5950c8de5b0SBaptiste Daroussin                 yylvlim = yylvals + s;
5960c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
5970c8de5b0SBaptiste Daroussin                 yylpp   = yylpe = yylpsns + p;
5980c8de5b0SBaptiste Daroussin                 yylplim = yylpsns + s;
5990c8de5b0SBaptiste Daroussin #endif
6000c8de5b0SBaptiste Daroussin                 yylexp  = yylexemes + p;
6010c8de5b0SBaptiste Daroussin             }
6022aca18c7SJung-uk Kim             *yylexp = (YYINT) YYLEX;
6030c8de5b0SBaptiste Daroussin             *yylvp++ = yylval;
6040c8de5b0SBaptiste Daroussin             yylve++;
6050c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
6060c8de5b0SBaptiste Daroussin             *yylpp++ = yylloc;
6070c8de5b0SBaptiste Daroussin             yylpe++;
6080c8de5b0SBaptiste Daroussin #endif
6090c8de5b0SBaptiste Daroussin             yychar = *yylexp++;
6100c8de5b0SBaptiste Daroussin             break;
6110c8de5b0SBaptiste Daroussin         }
6120c8de5b0SBaptiste Daroussin         /* normal operation, no conflict encountered */
6130c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
6140c8de5b0SBaptiste Daroussin         yychar = YYLEX;
6150c8de5b0SBaptiste Daroussin #if YYBTYACC
6160c8de5b0SBaptiste Daroussin         } while (0);
6170c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
6180c8de5b0SBaptiste Daroussin         if (yychar < 0) yychar = YYEOF;
6190c8de5b0SBaptiste Daroussin #if YYDEBUG
6200c8de5b0SBaptiste Daroussin         if (yydebug)
6210c8de5b0SBaptiste Daroussin         {
622c5b5d71aSJung-uk Kim             if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
6230c8de5b0SBaptiste Daroussin             fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)",
6240c8de5b0SBaptiste Daroussin                             YYDEBUGSTR, yydepth, yystate, yychar, yys);
6250c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING
6260c8de5b0SBaptiste Daroussin #if YYBTYACC
6270c8de5b0SBaptiste Daroussin             if (!yytrial)
6280c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
6290c8de5b0SBaptiste Daroussin                 fprintf(stderr, " <%s>", YYSTYPE_TOSTRING(yychar, yylval));
6300c8de5b0SBaptiste Daroussin #endif
6310c8de5b0SBaptiste Daroussin             fputc('\n', stderr);
6320c8de5b0SBaptiste Daroussin         }
6330c8de5b0SBaptiste Daroussin #endif
6340c8de5b0SBaptiste Daroussin     }
6350c8de5b0SBaptiste Daroussin #if YYBTYACC
6360c8de5b0SBaptiste Daroussin 
6370c8de5b0SBaptiste Daroussin     /* Do we have a conflict? */
6380c8de5b0SBaptiste Daroussin     if (((yyn = yycindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
6390c8de5b0SBaptiste Daroussin         yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
6400c8de5b0SBaptiste Daroussin     {
6410c8de5b0SBaptiste Daroussin         YYINT ctry;
6420c8de5b0SBaptiste Daroussin 
6430c8de5b0SBaptiste Daroussin         if (yypath)
6440c8de5b0SBaptiste Daroussin         {
6450c8de5b0SBaptiste Daroussin             YYParseState *save;
6460c8de5b0SBaptiste Daroussin #if YYDEBUG
6470c8de5b0SBaptiste Daroussin             if (yydebug)
6480c8de5b0SBaptiste Daroussin                 fprintf(stderr, "%s[%d]: CONFLICT in state %d: following successful trial parse\n",
6490c8de5b0SBaptiste Daroussin                                 YYDEBUGSTR, yydepth, yystate);
6500c8de5b0SBaptiste Daroussin #endif
6510c8de5b0SBaptiste Daroussin             /* Switch to the next conflict context */
6520c8de5b0SBaptiste Daroussin             save = yypath;
6530c8de5b0SBaptiste Daroussin             yypath = save->save;
6540c8de5b0SBaptiste Daroussin             save->save = NULL;
6550c8de5b0SBaptiste Daroussin             ctry = save->ctry;
6560c8de5b0SBaptiste Daroussin             if (save->state != yystate) YYABORT;
6570c8de5b0SBaptiste Daroussin             yyFreeState(save);
6580c8de5b0SBaptiste Daroussin 
6590c8de5b0SBaptiste Daroussin         }
6600c8de5b0SBaptiste Daroussin         else
6610c8de5b0SBaptiste Daroussin         {
6620c8de5b0SBaptiste Daroussin 
6630c8de5b0SBaptiste Daroussin             /* Unresolved conflict - start/continue trial parse */
6640c8de5b0SBaptiste Daroussin             YYParseState *save;
6650c8de5b0SBaptiste Daroussin #if YYDEBUG
6660c8de5b0SBaptiste Daroussin             if (yydebug)
6670c8de5b0SBaptiste Daroussin             {
6680c8de5b0SBaptiste Daroussin                 fprintf(stderr, "%s[%d]: CONFLICT in state %d. ", YYDEBUGSTR, yydepth, yystate);
6690c8de5b0SBaptiste Daroussin                 if (yyps->save)
6700c8de5b0SBaptiste Daroussin                     fputs("ALREADY in conflict, continuing trial parse.\n", stderr);
6710c8de5b0SBaptiste Daroussin                 else
6720c8de5b0SBaptiste Daroussin                     fputs("Starting trial parse.\n", stderr);
6730c8de5b0SBaptiste Daroussin             }
6740c8de5b0SBaptiste Daroussin #endif
6750c8de5b0SBaptiste Daroussin             save                  = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1));
6760c8de5b0SBaptiste Daroussin             if (save == NULL) goto yyenomem;
6770c8de5b0SBaptiste Daroussin             save->save            = yyps->save;
6780c8de5b0SBaptiste Daroussin             save->state           = yystate;
6790c8de5b0SBaptiste Daroussin             save->errflag         = yyerrflag;
6800c8de5b0SBaptiste Daroussin             save->yystack.s_mark  = save->yystack.s_base + (yystack.s_mark - yystack.s_base);
681c5b5d71aSJung-uk Kim             memcpy (save->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
6820c8de5b0SBaptiste Daroussin             save->yystack.l_mark  = save->yystack.l_base + (yystack.l_mark - yystack.l_base);
68311fce282SBaptiste Daroussin             memcpy (save->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
6840c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
6850c8de5b0SBaptiste Daroussin             save->yystack.p_mark  = save->yystack.p_base + (yystack.p_mark - yystack.p_base);
68611fce282SBaptiste Daroussin             memcpy (save->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
6870c8de5b0SBaptiste Daroussin #endif
6880c8de5b0SBaptiste Daroussin             ctry                  = yytable[yyn];
6890c8de5b0SBaptiste Daroussin             if (yyctable[ctry] == -1)
6900c8de5b0SBaptiste Daroussin             {
6910c8de5b0SBaptiste Daroussin #if YYDEBUG
6920c8de5b0SBaptiste Daroussin                 if (yydebug && yychar >= YYEOF)
6930c8de5b0SBaptiste Daroussin                     fprintf(stderr, "%s[%d]: backtracking 1 token\n", YYDEBUGSTR, yydepth);
6940c8de5b0SBaptiste Daroussin #endif
6950c8de5b0SBaptiste Daroussin                 ctry++;
6960c8de5b0SBaptiste Daroussin             }
6970c8de5b0SBaptiste Daroussin             save->ctry = ctry;
6980c8de5b0SBaptiste Daroussin             if (yyps->save == NULL)
6990c8de5b0SBaptiste Daroussin             {
7000c8de5b0SBaptiste Daroussin                 /* If this is a first conflict in the stack, start saving lexemes */
7010c8de5b0SBaptiste Daroussin                 if (!yylexemes)
7020c8de5b0SBaptiste Daroussin                 {
703b53bb29fSJung-uk Kim                     yylexemes = (YYINT *) malloc((YYLVQUEUEGROWTH) * sizeof(YYINT));
7040c8de5b0SBaptiste Daroussin                     if (yylexemes == NULL) goto yyenomem;
7050c8de5b0SBaptiste Daroussin                     yylvals   = (YYSTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYSTYPE));
7060c8de5b0SBaptiste Daroussin                     if (yylvals == NULL) goto yyenomem;
7070c8de5b0SBaptiste Daroussin                     yylvlim   = yylvals + YYLVQUEUEGROWTH;
7080c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
7090c8de5b0SBaptiste Daroussin                     yylpsns   = (YYLTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYLTYPE));
7100c8de5b0SBaptiste Daroussin                     if (yylpsns == NULL) goto yyenomem;
7110c8de5b0SBaptiste Daroussin                     yylplim   = yylpsns + YYLVQUEUEGROWTH;
7120c8de5b0SBaptiste Daroussin #endif
7130c8de5b0SBaptiste Daroussin                 }
7140c8de5b0SBaptiste Daroussin                 if (yylvp == yylve)
7150c8de5b0SBaptiste Daroussin                 {
7160c8de5b0SBaptiste Daroussin                     yylvp  = yylve = yylvals;
7170c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
7180c8de5b0SBaptiste Daroussin                     yylpp  = yylpe = yylpsns;
7190c8de5b0SBaptiste Daroussin #endif
7200c8de5b0SBaptiste Daroussin                     yylexp = yylexemes;
7210c8de5b0SBaptiste Daroussin                     if (yychar >= YYEOF)
7220c8de5b0SBaptiste Daroussin                     {
7230c8de5b0SBaptiste Daroussin                         *yylve++ = yylval;
7240c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
7250c8de5b0SBaptiste Daroussin                         *yylpe++ = yylloc;
7260c8de5b0SBaptiste Daroussin #endif
7272aca18c7SJung-uk Kim                         *yylexp  = (YYINT) yychar;
7280c8de5b0SBaptiste Daroussin                         yychar   = YYEMPTY;
7290c8de5b0SBaptiste Daroussin                     }
7300c8de5b0SBaptiste Daroussin                 }
7310c8de5b0SBaptiste Daroussin             }
7320c8de5b0SBaptiste Daroussin             if (yychar >= YYEOF)
7330c8de5b0SBaptiste Daroussin             {
7340c8de5b0SBaptiste Daroussin                 yylvp--;
7350c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
7360c8de5b0SBaptiste Daroussin                 yylpp--;
7370c8de5b0SBaptiste Daroussin #endif
7380c8de5b0SBaptiste Daroussin                 yylexp--;
7390c8de5b0SBaptiste Daroussin                 yychar = YYEMPTY;
7400c8de5b0SBaptiste Daroussin             }
74111fce282SBaptiste Daroussin             save->lexeme = (int) (yylvp - yylvals);
7420c8de5b0SBaptiste Daroussin             yyps->save   = save;
7430c8de5b0SBaptiste Daroussin         }
7440c8de5b0SBaptiste Daroussin         if (yytable[yyn] == ctry)
7450c8de5b0SBaptiste Daroussin         {
7460c8de5b0SBaptiste Daroussin #if YYDEBUG
7470c8de5b0SBaptiste Daroussin             if (yydebug)
7480c8de5b0SBaptiste Daroussin                 fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n",
7490c8de5b0SBaptiste Daroussin                                 YYDEBUGSTR, yydepth, yystate, yyctable[ctry]);
7500c8de5b0SBaptiste Daroussin #endif
7510c8de5b0SBaptiste Daroussin             if (yychar < 0)
7520c8de5b0SBaptiste Daroussin             {
7530c8de5b0SBaptiste Daroussin                 yylvp++;
7540c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
7550c8de5b0SBaptiste Daroussin                 yylpp++;
7560c8de5b0SBaptiste Daroussin #endif
7570c8de5b0SBaptiste Daroussin                 yylexp++;
7580c8de5b0SBaptiste Daroussin             }
7590c8de5b0SBaptiste Daroussin             if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM)
7600c8de5b0SBaptiste Daroussin                 goto yyoverflow;
7610c8de5b0SBaptiste Daroussin             yystate = yyctable[ctry];
762c5b5d71aSJung-uk Kim             *++yystack.s_mark = (YYINT) yystate;
7630c8de5b0SBaptiste Daroussin             *++yystack.l_mark = yylval;
7640c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
7650c8de5b0SBaptiste Daroussin             *++yystack.p_mark = yylloc;
7660c8de5b0SBaptiste Daroussin #endif
7670c8de5b0SBaptiste Daroussin             yychar  = YYEMPTY;
7680c8de5b0SBaptiste Daroussin             if (yyerrflag > 0) --yyerrflag;
7690c8de5b0SBaptiste Daroussin             goto yyloop;
7700c8de5b0SBaptiste Daroussin         }
7710c8de5b0SBaptiste Daroussin         else
7720c8de5b0SBaptiste Daroussin         {
7730c8de5b0SBaptiste Daroussin             yyn = yyctable[ctry];
7740c8de5b0SBaptiste Daroussin             goto yyreduce;
7750c8de5b0SBaptiste Daroussin         }
7760c8de5b0SBaptiste Daroussin     } /* End of code dealing with conflicts */
7770c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
7780c8de5b0SBaptiste Daroussin     if (((yyn = yysindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
7790c8de5b0SBaptiste Daroussin             yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
7800c8de5b0SBaptiste Daroussin     {
7810c8de5b0SBaptiste Daroussin #if YYDEBUG
7820c8de5b0SBaptiste Daroussin         if (yydebug)
7830c8de5b0SBaptiste Daroussin             fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n",
7840c8de5b0SBaptiste Daroussin                             YYDEBUGSTR, yydepth, yystate, yytable[yyn]);
7850c8de5b0SBaptiste Daroussin #endif
7860c8de5b0SBaptiste Daroussin         if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
7870c8de5b0SBaptiste Daroussin         yystate = yytable[yyn];
7880c8de5b0SBaptiste Daroussin         *++yystack.s_mark = yytable[yyn];
7890c8de5b0SBaptiste Daroussin         *++yystack.l_mark = yylval;
7900c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
7910c8de5b0SBaptiste Daroussin         *++yystack.p_mark = yylloc;
7920c8de5b0SBaptiste Daroussin #endif
7930c8de5b0SBaptiste Daroussin         yychar = YYEMPTY;
7940c8de5b0SBaptiste Daroussin         if (yyerrflag > 0)  --yyerrflag;
7950c8de5b0SBaptiste Daroussin         goto yyloop;
7960c8de5b0SBaptiste Daroussin     }
7970c8de5b0SBaptiste Daroussin     if (((yyn = yyrindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
7980c8de5b0SBaptiste Daroussin             yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
7990c8de5b0SBaptiste Daroussin     {
8000c8de5b0SBaptiste Daroussin         yyn = yytable[yyn];
8010c8de5b0SBaptiste Daroussin         goto yyreduce;
8020c8de5b0SBaptiste Daroussin     }
8030c8de5b0SBaptiste Daroussin     if (yyerrflag != 0) goto yyinrecovery;
8040c8de5b0SBaptiste Daroussin #if YYBTYACC
8050c8de5b0SBaptiste Daroussin 
8060c8de5b0SBaptiste Daroussin     yynewerrflag = 1;
8070c8de5b0SBaptiste Daroussin     goto yyerrhandler;
808c5b5d71aSJung-uk Kim     goto yyerrlab; /* redundant goto avoids 'unused label' warning */
8090c8de5b0SBaptiste Daroussin 
8100c8de5b0SBaptiste Daroussin yyerrlab:
811c5b5d71aSJung-uk Kim     /* explicit YYERROR from an action -- pop the rhs of the rule reduced
812c5b5d71aSJung-uk Kim      * before looking for error recovery */
813c5b5d71aSJung-uk Kim     yystack.s_mark -= yym;
814c5b5d71aSJung-uk Kim     yystate = *yystack.s_mark;
815c5b5d71aSJung-uk Kim     yystack.l_mark -= yym;
816c5b5d71aSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
817c5b5d71aSJung-uk Kim     yystack.p_mark -= yym;
818c5b5d71aSJung-uk Kim #endif
819c5b5d71aSJung-uk Kim 
8200c8de5b0SBaptiste Daroussin     yynewerrflag = 0;
8210c8de5b0SBaptiste Daroussin yyerrhandler:
8220c8de5b0SBaptiste Daroussin     while (yyps->save)
8230c8de5b0SBaptiste Daroussin     {
8240c8de5b0SBaptiste Daroussin         int ctry;
8250c8de5b0SBaptiste Daroussin         YYParseState *save = yyps->save;
8260c8de5b0SBaptiste Daroussin #if YYDEBUG
8270c8de5b0SBaptiste Daroussin         if (yydebug)
8280c8de5b0SBaptiste Daroussin             fprintf(stderr, "%s[%d]: ERROR in state %d, CONFLICT BACKTRACKING to state %d, %d tokens\n",
8290c8de5b0SBaptiste Daroussin                             YYDEBUGSTR, yydepth, yystate, yyps->save->state,
8300c8de5b0SBaptiste Daroussin                     (int)(yylvp - yylvals - yyps->save->lexeme));
8310c8de5b0SBaptiste Daroussin #endif
8320c8de5b0SBaptiste Daroussin         /* Memorize most forward-looking error state in case it's really an error. */
8330c8de5b0SBaptiste Daroussin         if (yyerrctx == NULL || yyerrctx->lexeme < yylvp - yylvals)
8340c8de5b0SBaptiste Daroussin         {
8350c8de5b0SBaptiste Daroussin             /* Free old saved error context state */
8360c8de5b0SBaptiste Daroussin             if (yyerrctx) yyFreeState(yyerrctx);
8370c8de5b0SBaptiste Daroussin             /* Create and fill out new saved error context state */
8380c8de5b0SBaptiste Daroussin             yyerrctx                 = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1));
8390c8de5b0SBaptiste Daroussin             if (yyerrctx == NULL) goto yyenomem;
8400c8de5b0SBaptiste Daroussin             yyerrctx->save           = yyps->save;
8410c8de5b0SBaptiste Daroussin             yyerrctx->state          = yystate;
8420c8de5b0SBaptiste Daroussin             yyerrctx->errflag        = yyerrflag;
8430c8de5b0SBaptiste Daroussin             yyerrctx->yystack.s_mark = yyerrctx->yystack.s_base + (yystack.s_mark - yystack.s_base);
844c5b5d71aSJung-uk Kim             memcpy (yyerrctx->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
8450c8de5b0SBaptiste Daroussin             yyerrctx->yystack.l_mark = yyerrctx->yystack.l_base + (yystack.l_mark - yystack.l_base);
84611fce282SBaptiste Daroussin             memcpy (yyerrctx->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
8470c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
8480c8de5b0SBaptiste Daroussin             yyerrctx->yystack.p_mark = yyerrctx->yystack.p_base + (yystack.p_mark - yystack.p_base);
84911fce282SBaptiste Daroussin             memcpy (yyerrctx->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
8500c8de5b0SBaptiste Daroussin #endif
85111fce282SBaptiste Daroussin             yyerrctx->lexeme         = (int) (yylvp - yylvals);
8520c8de5b0SBaptiste Daroussin         }
8530c8de5b0SBaptiste Daroussin         yylvp          = yylvals   + save->lexeme;
8540c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
8550c8de5b0SBaptiste Daroussin         yylpp          = yylpsns   + save->lexeme;
8560c8de5b0SBaptiste Daroussin #endif
8570c8de5b0SBaptiste Daroussin         yylexp         = yylexemes + save->lexeme;
8580c8de5b0SBaptiste Daroussin         yychar         = YYEMPTY;
8590c8de5b0SBaptiste Daroussin         yystack.s_mark = yystack.s_base + (save->yystack.s_mark - save->yystack.s_base);
860c5b5d71aSJung-uk Kim         memcpy (yystack.s_base, save->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
8610c8de5b0SBaptiste Daroussin         yystack.l_mark = yystack.l_base + (save->yystack.l_mark - save->yystack.l_base);
86211fce282SBaptiste Daroussin         memcpy (yystack.l_base, save->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
8630c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
8640c8de5b0SBaptiste Daroussin         yystack.p_mark = yystack.p_base + (save->yystack.p_mark - save->yystack.p_base);
86511fce282SBaptiste Daroussin         memcpy (yystack.p_base, save->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
8660c8de5b0SBaptiste Daroussin #endif
8670c8de5b0SBaptiste Daroussin         ctry           = ++save->ctry;
8680c8de5b0SBaptiste Daroussin         yystate        = save->state;
8690c8de5b0SBaptiste Daroussin         /* We tried shift, try reduce now */
8700c8de5b0SBaptiste Daroussin         if ((yyn = yyctable[ctry]) >= 0) goto yyreduce;
8710c8de5b0SBaptiste Daroussin         yyps->save     = save->save;
8720c8de5b0SBaptiste Daroussin         save->save     = NULL;
8730c8de5b0SBaptiste Daroussin         yyFreeState(save);
8740c8de5b0SBaptiste Daroussin 
8750c8de5b0SBaptiste Daroussin         /* Nothing left on the stack -- error */
8760c8de5b0SBaptiste Daroussin         if (!yyps->save)
8770c8de5b0SBaptiste Daroussin         {
8780c8de5b0SBaptiste Daroussin #if YYDEBUG
8790c8de5b0SBaptiste Daroussin             if (yydebug)
8800c8de5b0SBaptiste Daroussin                 fprintf(stderr, "%sdebug[%d,trial]: trial parse FAILED, entering ERROR mode\n",
8810c8de5b0SBaptiste Daroussin                                 YYPREFIX, yydepth);
8820c8de5b0SBaptiste Daroussin #endif
8830c8de5b0SBaptiste Daroussin             /* Restore state as it was in the most forward-advanced error */
8840c8de5b0SBaptiste Daroussin             yylvp          = yylvals   + yyerrctx->lexeme;
8850c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
8860c8de5b0SBaptiste Daroussin             yylpp          = yylpsns   + yyerrctx->lexeme;
8870c8de5b0SBaptiste Daroussin #endif
8880c8de5b0SBaptiste Daroussin             yylexp         = yylexemes + yyerrctx->lexeme;
8890c8de5b0SBaptiste Daroussin             yychar         = yylexp[-1];
8900c8de5b0SBaptiste Daroussin             yylval         = yylvp[-1];
8910c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
8920c8de5b0SBaptiste Daroussin             yylloc         = yylpp[-1];
8930c8de5b0SBaptiste Daroussin #endif
8940c8de5b0SBaptiste Daroussin             yystack.s_mark = yystack.s_base + (yyerrctx->yystack.s_mark - yyerrctx->yystack.s_base);
895c5b5d71aSJung-uk Kim             memcpy (yystack.s_base, yyerrctx->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
8960c8de5b0SBaptiste Daroussin             yystack.l_mark = yystack.l_base + (yyerrctx->yystack.l_mark - yyerrctx->yystack.l_base);
89711fce282SBaptiste Daroussin             memcpy (yystack.l_base, yyerrctx->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
8980c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
8990c8de5b0SBaptiste Daroussin             yystack.p_mark = yystack.p_base + (yyerrctx->yystack.p_mark - yyerrctx->yystack.p_base);
90011fce282SBaptiste Daroussin             memcpy (yystack.p_base, yyerrctx->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
9010c8de5b0SBaptiste Daroussin #endif
9020c8de5b0SBaptiste Daroussin             yystate        = yyerrctx->state;
9030c8de5b0SBaptiste Daroussin             yyFreeState(yyerrctx);
9040c8de5b0SBaptiste Daroussin             yyerrctx       = NULL;
9050c8de5b0SBaptiste Daroussin         }
9060c8de5b0SBaptiste Daroussin         yynewerrflag = 1;
9070c8de5b0SBaptiste Daroussin     }
9080c8de5b0SBaptiste Daroussin     if (yynewerrflag == 0) goto yyinrecovery;
9090c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
9100c8de5b0SBaptiste Daroussin 
9110c8de5b0SBaptiste Daroussin     YYERROR_CALL("syntax error");
9120c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
913b53bb29fSJung-uk Kim     yyerror_loc_range[1] = yylloc; /* lookahead position is error start position */
9140c8de5b0SBaptiste Daroussin #endif
9150c8de5b0SBaptiste Daroussin 
9160c8de5b0SBaptiste Daroussin #if !YYBTYACC
917c5b5d71aSJung-uk Kim     goto yyerrlab; /* redundant goto avoids 'unused label' warning */
9180c8de5b0SBaptiste Daroussin yyerrlab:
9190c8de5b0SBaptiste Daroussin #endif
9200c8de5b0SBaptiste Daroussin     ++yynerrs;
9210c8de5b0SBaptiste Daroussin 
9220c8de5b0SBaptiste Daroussin yyinrecovery:
9230c8de5b0SBaptiste Daroussin     if (yyerrflag < 3)
9240c8de5b0SBaptiste Daroussin     {
9250c8de5b0SBaptiste Daroussin         yyerrflag = 3;
9260c8de5b0SBaptiste Daroussin         for (;;)
9270c8de5b0SBaptiste Daroussin         {
9280c8de5b0SBaptiste Daroussin             if (((yyn = yysindex[*yystack.s_mark]) != 0) && (yyn += YYERRCODE) >= 0 &&
9290c8de5b0SBaptiste Daroussin                     yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) YYERRCODE)
9300c8de5b0SBaptiste Daroussin             {
9310c8de5b0SBaptiste Daroussin #if YYDEBUG
9320c8de5b0SBaptiste Daroussin                 if (yydebug)
9330c8de5b0SBaptiste Daroussin                     fprintf(stderr, "%s[%d]: state %d, error recovery shifting to state %d\n",
9340c8de5b0SBaptiste Daroussin                                     YYDEBUGSTR, yydepth, *yystack.s_mark, yytable[yyn]);
9350c8de5b0SBaptiste Daroussin #endif
9360c8de5b0SBaptiste Daroussin                 if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
9370c8de5b0SBaptiste Daroussin                 yystate = yytable[yyn];
9380c8de5b0SBaptiste Daroussin                 *++yystack.s_mark = yytable[yyn];
9390c8de5b0SBaptiste Daroussin                 *++yystack.l_mark = yylval;
9400c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
9410c8de5b0SBaptiste Daroussin                 /* lookahead position is error end position */
942b53bb29fSJung-uk Kim                 yyerror_loc_range[2] = yylloc;
9430c8de5b0SBaptiste Daroussin                 YYLLOC_DEFAULT(yyloc, yyerror_loc_range, 2); /* position of error span */
9440c8de5b0SBaptiste Daroussin                 *++yystack.p_mark = yyloc;
9450c8de5b0SBaptiste Daroussin #endif
9460c8de5b0SBaptiste Daroussin                 goto yyloop;
9470c8de5b0SBaptiste Daroussin             }
9480c8de5b0SBaptiste Daroussin             else
9490c8de5b0SBaptiste Daroussin             {
9500c8de5b0SBaptiste Daroussin #if YYDEBUG
9510c8de5b0SBaptiste Daroussin                 if (yydebug)
9520c8de5b0SBaptiste Daroussin                     fprintf(stderr, "%s[%d]: error recovery discarding state %d\n",
9530c8de5b0SBaptiste Daroussin                                     YYDEBUGSTR, yydepth, *yystack.s_mark);
9540c8de5b0SBaptiste Daroussin #endif
9550c8de5b0SBaptiste Daroussin                 if (yystack.s_mark <= yystack.s_base) goto yyabort;
9560c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
9570c8de5b0SBaptiste Daroussin                 /* the current TOS position is the error start position */
958b53bb29fSJung-uk Kim                 yyerror_loc_range[1] = *yystack.p_mark;
9590c8de5b0SBaptiste Daroussin #endif
9600c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL)
9610c8de5b0SBaptiste Daroussin #if YYBTYACC
9620c8de5b0SBaptiste Daroussin                 if (!yytrial)
9630c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
9640c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
9650c8de5b0SBaptiste Daroussin                     YYDESTRUCT_CALL("error: discarding state",
9660c8de5b0SBaptiste Daroussin                                     yystos[*yystack.s_mark], yystack.l_mark, yystack.p_mark);
9670c8de5b0SBaptiste Daroussin #else
9680c8de5b0SBaptiste Daroussin                     YYDESTRUCT_CALL("error: discarding state",
9690c8de5b0SBaptiste Daroussin                                     yystos[*yystack.s_mark], yystack.l_mark);
9700c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
9710c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */
9720c8de5b0SBaptiste Daroussin                 --yystack.s_mark;
9730c8de5b0SBaptiste Daroussin                 --yystack.l_mark;
9740c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
9750c8de5b0SBaptiste Daroussin                 --yystack.p_mark;
9760c8de5b0SBaptiste Daroussin #endif
9770c8de5b0SBaptiste Daroussin             }
9780c8de5b0SBaptiste Daroussin         }
9790c8de5b0SBaptiste Daroussin     }
9800c8de5b0SBaptiste Daroussin     else
9810c8de5b0SBaptiste Daroussin     {
9820c8de5b0SBaptiste Daroussin         if (yychar == YYEOF) goto yyabort;
9830c8de5b0SBaptiste Daroussin #if YYDEBUG
9840c8de5b0SBaptiste Daroussin         if (yydebug)
9850c8de5b0SBaptiste Daroussin         {
986c5b5d71aSJung-uk Kim             if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
9870c8de5b0SBaptiste Daroussin             fprintf(stderr, "%s[%d]: state %d, error recovery discarding token %d (%s)\n",
9880c8de5b0SBaptiste Daroussin                             YYDEBUGSTR, yydepth, yystate, yychar, yys);
9890c8de5b0SBaptiste Daroussin         }
9900c8de5b0SBaptiste Daroussin #endif
9910c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL)
9920c8de5b0SBaptiste Daroussin #if YYBTYACC
9930c8de5b0SBaptiste Daroussin         if (!yytrial)
9940c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
9950c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
9960c8de5b0SBaptiste Daroussin             YYDESTRUCT_CALL("error: discarding token", yychar, &yylval, &yylloc);
9970c8de5b0SBaptiste Daroussin #else
9980c8de5b0SBaptiste Daroussin             YYDESTRUCT_CALL("error: discarding token", yychar, &yylval);
9990c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
10000c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */
10010c8de5b0SBaptiste Daroussin         yychar = YYEMPTY;
10020c8de5b0SBaptiste Daroussin         goto yyloop;
10030c8de5b0SBaptiste Daroussin     }
10040c8de5b0SBaptiste Daroussin 
10050c8de5b0SBaptiste Daroussin yyreduce:
10060c8de5b0SBaptiste Daroussin     yym = yylen[yyn];
10070c8de5b0SBaptiste Daroussin #if YYDEBUG
10080c8de5b0SBaptiste Daroussin     if (yydebug)
10090c8de5b0SBaptiste Daroussin     {
10100c8de5b0SBaptiste Daroussin         fprintf(stderr, "%s[%d]: state %d, reducing by rule %d (%s)",
10110c8de5b0SBaptiste Daroussin                         YYDEBUGSTR, yydepth, yystate, yyn, yyrule[yyn]);
10120c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING
10130c8de5b0SBaptiste Daroussin #if YYBTYACC
10140c8de5b0SBaptiste Daroussin         if (!yytrial)
10150c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
10160c8de5b0SBaptiste Daroussin             if (yym > 0)
10170c8de5b0SBaptiste Daroussin             {
10180c8de5b0SBaptiste Daroussin                 int i;
10190c8de5b0SBaptiste Daroussin                 fputc('<', stderr);
10200c8de5b0SBaptiste Daroussin                 for (i = yym; i > 0; i--)
10210c8de5b0SBaptiste Daroussin                 {
10220c8de5b0SBaptiste Daroussin                     if (i != yym) fputs(", ", stderr);
10230c8de5b0SBaptiste Daroussin                     fputs(YYSTYPE_TOSTRING(yystos[yystack.s_mark[1-i]],
10240c8de5b0SBaptiste Daroussin                                            yystack.l_mark[1-i]), stderr);
10250c8de5b0SBaptiste Daroussin                 }
10260c8de5b0SBaptiste Daroussin                 fputc('>', stderr);
10270c8de5b0SBaptiste Daroussin             }
10280c8de5b0SBaptiste Daroussin #endif
10290c8de5b0SBaptiste Daroussin         fputc('\n', stderr);
10300c8de5b0SBaptiste Daroussin     }
10310c8de5b0SBaptiste Daroussin #endif
10320c8de5b0SBaptiste Daroussin     if (yym > 0)
10330c8de5b0SBaptiste Daroussin         yyval = yystack.l_mark[1-yym];
10340c8de5b0SBaptiste Daroussin     else
10350c8de5b0SBaptiste Daroussin         memset(&yyval, 0, sizeof yyval);
10360c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
10370c8de5b0SBaptiste Daroussin 
10380c8de5b0SBaptiste Daroussin     /* Perform position reduction */
10390c8de5b0SBaptiste Daroussin     memset(&yyloc, 0, sizeof(yyloc));
10400c8de5b0SBaptiste Daroussin #if YYBTYACC
10410c8de5b0SBaptiste Daroussin     if (!yytrial)
10420c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
10430c8de5b0SBaptiste Daroussin     {
1044b53bb29fSJung-uk Kim         YYLLOC_DEFAULT(yyloc, &yystack.p_mark[-yym], yym);
10450c8de5b0SBaptiste Daroussin         /* just in case YYERROR is invoked within the action, save
10460c8de5b0SBaptiste Daroussin            the start of the rhs as the error start position */
1047b53bb29fSJung-uk Kim         yyerror_loc_range[1] = yystack.p_mark[1-yym];
10480c8de5b0SBaptiste Daroussin     }
10490c8de5b0SBaptiste Daroussin #endif
10500c8de5b0SBaptiste Daroussin 
10510c8de5b0SBaptiste Daroussin     switch (yyn)
10520c8de5b0SBaptiste Daroussin     {
10530c8de5b0SBaptiste Daroussin case 3:
1054c5b5d71aSJung-uk Kim #line 32 "code_calc.y"
10550c8de5b0SBaptiste Daroussin 	{  yyerrok ; }
1056*8e022d3cSDag-Erling Smørgrav #line 1057 "code_calc.code.c"
10570c8de5b0SBaptiste Daroussin break;
10580c8de5b0SBaptiste Daroussin case 4:
1059c5b5d71aSJung-uk Kim #line 36 "code_calc.y"
10600c8de5b0SBaptiste Daroussin 	{  printf("%d\n",yystack.l_mark[0]);}
1061*8e022d3cSDag-Erling Smørgrav #line 1062 "code_calc.code.c"
10620c8de5b0SBaptiste Daroussin break;
10630c8de5b0SBaptiste Daroussin case 5:
1064c5b5d71aSJung-uk Kim #line 38 "code_calc.y"
10650c8de5b0SBaptiste Daroussin 	{  regs[yystack.l_mark[-2]] = yystack.l_mark[0]; }
1066*8e022d3cSDag-Erling Smørgrav #line 1067 "code_calc.code.c"
10670c8de5b0SBaptiste Daroussin break;
10680c8de5b0SBaptiste Daroussin case 6:
1069c5b5d71aSJung-uk Kim #line 42 "code_calc.y"
10700c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[-1]; }
1071*8e022d3cSDag-Erling Smørgrav #line 1072 "code_calc.code.c"
10720c8de5b0SBaptiste Daroussin break;
10730c8de5b0SBaptiste Daroussin case 7:
1074c5b5d71aSJung-uk Kim #line 44 "code_calc.y"
10750c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[-2] + yystack.l_mark[0]; }
1076*8e022d3cSDag-Erling Smørgrav #line 1077 "code_calc.code.c"
10770c8de5b0SBaptiste Daroussin break;
10780c8de5b0SBaptiste Daroussin case 8:
1079c5b5d71aSJung-uk Kim #line 46 "code_calc.y"
10800c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[-2] - yystack.l_mark[0]; }
1081*8e022d3cSDag-Erling Smørgrav #line 1082 "code_calc.code.c"
10820c8de5b0SBaptiste Daroussin break;
10830c8de5b0SBaptiste Daroussin case 9:
1084c5b5d71aSJung-uk Kim #line 48 "code_calc.y"
10850c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[-2] * yystack.l_mark[0]; }
1086*8e022d3cSDag-Erling Smørgrav #line 1087 "code_calc.code.c"
10870c8de5b0SBaptiste Daroussin break;
10880c8de5b0SBaptiste Daroussin case 10:
1089c5b5d71aSJung-uk Kim #line 50 "code_calc.y"
10900c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[-2] / yystack.l_mark[0]; }
1091*8e022d3cSDag-Erling Smørgrav #line 1092 "code_calc.code.c"
10920c8de5b0SBaptiste Daroussin break;
10930c8de5b0SBaptiste Daroussin case 11:
1094c5b5d71aSJung-uk Kim #line 52 "code_calc.y"
10950c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[-2] % yystack.l_mark[0]; }
1096*8e022d3cSDag-Erling Smørgrav #line 1097 "code_calc.code.c"
10970c8de5b0SBaptiste Daroussin break;
10980c8de5b0SBaptiste Daroussin case 12:
1099c5b5d71aSJung-uk Kim #line 54 "code_calc.y"
11000c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[-2] & yystack.l_mark[0]; }
1101*8e022d3cSDag-Erling Smørgrav #line 1102 "code_calc.code.c"
11020c8de5b0SBaptiste Daroussin break;
11030c8de5b0SBaptiste Daroussin case 13:
1104c5b5d71aSJung-uk Kim #line 56 "code_calc.y"
11050c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[-2] | yystack.l_mark[0]; }
1106*8e022d3cSDag-Erling Smørgrav #line 1107 "code_calc.code.c"
11070c8de5b0SBaptiste Daroussin break;
11080c8de5b0SBaptiste Daroussin case 14:
1109c5b5d71aSJung-uk Kim #line 58 "code_calc.y"
11100c8de5b0SBaptiste Daroussin 	{  yyval = - yystack.l_mark[0]; }
1111*8e022d3cSDag-Erling Smørgrav #line 1112 "code_calc.code.c"
11120c8de5b0SBaptiste Daroussin break;
11130c8de5b0SBaptiste Daroussin case 15:
1114c5b5d71aSJung-uk Kim #line 60 "code_calc.y"
11150c8de5b0SBaptiste Daroussin 	{  yyval = regs[yystack.l_mark[0]]; }
1116*8e022d3cSDag-Erling Smørgrav #line 1117 "code_calc.code.c"
11170c8de5b0SBaptiste Daroussin break;
11180c8de5b0SBaptiste Daroussin case 17:
1119c5b5d71aSJung-uk Kim #line 65 "code_calc.y"
11200c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[0]; base = (yystack.l_mark[0]==0) ? 8 : 10; }
1121*8e022d3cSDag-Erling Smørgrav #line 1122 "code_calc.code.c"
11220c8de5b0SBaptiste Daroussin break;
11230c8de5b0SBaptiste Daroussin case 18:
1124c5b5d71aSJung-uk Kim #line 67 "code_calc.y"
11250c8de5b0SBaptiste Daroussin 	{  yyval = base * yystack.l_mark[-1] + yystack.l_mark[0]; }
1126*8e022d3cSDag-Erling Smørgrav #line 1127 "code_calc.code.c"
11270c8de5b0SBaptiste Daroussin break;
1128*8e022d3cSDag-Erling Smørgrav #line 1129 "code_calc.code.c"
11290c8de5b0SBaptiste Daroussin     default:
11300c8de5b0SBaptiste Daroussin         break;
11310c8de5b0SBaptiste Daroussin     }
11320c8de5b0SBaptiste Daroussin     yystack.s_mark -= yym;
11330c8de5b0SBaptiste Daroussin     yystate = *yystack.s_mark;
11340c8de5b0SBaptiste Daroussin     yystack.l_mark -= yym;
11350c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
11360c8de5b0SBaptiste Daroussin     yystack.p_mark -= yym;
11370c8de5b0SBaptiste Daroussin #endif
11380c8de5b0SBaptiste Daroussin     yym = yylhs[yyn];
11390c8de5b0SBaptiste Daroussin     if (yystate == 0 && yym == 0)
11400c8de5b0SBaptiste Daroussin     {
11410c8de5b0SBaptiste Daroussin #if YYDEBUG
11420c8de5b0SBaptiste Daroussin         if (yydebug)
11430c8de5b0SBaptiste Daroussin         {
11440c8de5b0SBaptiste Daroussin             fprintf(stderr, "%s[%d]: after reduction, ", YYDEBUGSTR, yydepth);
11450c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING
11460c8de5b0SBaptiste Daroussin #if YYBTYACC
11470c8de5b0SBaptiste Daroussin             if (!yytrial)
11480c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
11490c8de5b0SBaptiste Daroussin                 fprintf(stderr, "result is <%s>, ", YYSTYPE_TOSTRING(yystos[YYFINAL], yyval));
11500c8de5b0SBaptiste Daroussin #endif
11510c8de5b0SBaptiste Daroussin             fprintf(stderr, "shifting from state 0 to final state %d\n", YYFINAL);
11520c8de5b0SBaptiste Daroussin         }
11530c8de5b0SBaptiste Daroussin #endif
11540c8de5b0SBaptiste Daroussin         yystate = YYFINAL;
11550c8de5b0SBaptiste Daroussin         *++yystack.s_mark = YYFINAL;
11560c8de5b0SBaptiste Daroussin         *++yystack.l_mark = yyval;
11570c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
11580c8de5b0SBaptiste Daroussin         *++yystack.p_mark = yyloc;
11590c8de5b0SBaptiste Daroussin #endif
11600c8de5b0SBaptiste Daroussin         if (yychar < 0)
11610c8de5b0SBaptiste Daroussin         {
11620c8de5b0SBaptiste Daroussin #if YYBTYACC
11630c8de5b0SBaptiste Daroussin             do {
11640c8de5b0SBaptiste Daroussin             if (yylvp < yylve)
11650c8de5b0SBaptiste Daroussin             {
11660c8de5b0SBaptiste Daroussin                 /* we're currently re-reading tokens */
11670c8de5b0SBaptiste Daroussin                 yylval = *yylvp++;
11680c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
11690c8de5b0SBaptiste Daroussin                 yylloc = *yylpp++;
11700c8de5b0SBaptiste Daroussin #endif
11710c8de5b0SBaptiste Daroussin                 yychar = *yylexp++;
11720c8de5b0SBaptiste Daroussin                 break;
11730c8de5b0SBaptiste Daroussin             }
11740c8de5b0SBaptiste Daroussin             if (yyps->save)
11750c8de5b0SBaptiste Daroussin             {
11760c8de5b0SBaptiste Daroussin                 /* in trial mode; save scanner results for future parse attempts */
11770c8de5b0SBaptiste Daroussin                 if (yylvp == yylvlim)
11780c8de5b0SBaptiste Daroussin                 {   /* Enlarge lexical value queue */
117911fce282SBaptiste Daroussin                     size_t p = (size_t) (yylvp - yylvals);
118011fce282SBaptiste Daroussin                     size_t s = (size_t) (yylvlim - yylvals);
11810c8de5b0SBaptiste Daroussin 
11820c8de5b0SBaptiste Daroussin                     s += YYLVQUEUEGROWTH;
1183b53bb29fSJung-uk Kim                     if ((yylexemes = (YYINT *)realloc(yylexemes, s * sizeof(YYINT))) == NULL)
11840c8de5b0SBaptiste Daroussin                         goto yyenomem;
1185b53bb29fSJung-uk Kim                     if ((yylvals   = (YYSTYPE *)realloc(yylvals, s * sizeof(YYSTYPE))) == NULL)
11860c8de5b0SBaptiste Daroussin                         goto yyenomem;
11870c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1188b53bb29fSJung-uk Kim                     if ((yylpsns   = (YYLTYPE *)realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL)
11890c8de5b0SBaptiste Daroussin                         goto yyenomem;
11900c8de5b0SBaptiste Daroussin #endif
11910c8de5b0SBaptiste Daroussin                     yylvp   = yylve = yylvals + p;
11920c8de5b0SBaptiste Daroussin                     yylvlim = yylvals + s;
11930c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
11940c8de5b0SBaptiste Daroussin                     yylpp   = yylpe = yylpsns + p;
11950c8de5b0SBaptiste Daroussin                     yylplim = yylpsns + s;
11960c8de5b0SBaptiste Daroussin #endif
11970c8de5b0SBaptiste Daroussin                     yylexp  = yylexemes + p;
11980c8de5b0SBaptiste Daroussin                 }
11992aca18c7SJung-uk Kim                 *yylexp = (YYINT) YYLEX;
12000c8de5b0SBaptiste Daroussin                 *yylvp++ = yylval;
12010c8de5b0SBaptiste Daroussin                 yylve++;
12020c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
12030c8de5b0SBaptiste Daroussin                 *yylpp++ = yylloc;
12040c8de5b0SBaptiste Daroussin                 yylpe++;
12050c8de5b0SBaptiste Daroussin #endif
12060c8de5b0SBaptiste Daroussin                 yychar = *yylexp++;
12070c8de5b0SBaptiste Daroussin                 break;
12080c8de5b0SBaptiste Daroussin             }
12090c8de5b0SBaptiste Daroussin             /* normal operation, no conflict encountered */
12100c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
12110c8de5b0SBaptiste Daroussin             yychar = YYLEX;
12120c8de5b0SBaptiste Daroussin #if YYBTYACC
12130c8de5b0SBaptiste Daroussin             } while (0);
12140c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
12150c8de5b0SBaptiste Daroussin             if (yychar < 0) yychar = YYEOF;
12160c8de5b0SBaptiste Daroussin #if YYDEBUG
12170c8de5b0SBaptiste Daroussin             if (yydebug)
12180c8de5b0SBaptiste Daroussin             {
1219c5b5d71aSJung-uk Kim                 if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
1220c5b5d71aSJung-uk Kim                 fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)\n",
12210c8de5b0SBaptiste Daroussin                                 YYDEBUGSTR, yydepth, YYFINAL, yychar, yys);
12220c8de5b0SBaptiste Daroussin             }
12230c8de5b0SBaptiste Daroussin #endif
12240c8de5b0SBaptiste Daroussin         }
12250c8de5b0SBaptiste Daroussin         if (yychar == YYEOF) goto yyaccept;
12260c8de5b0SBaptiste Daroussin         goto yyloop;
12270c8de5b0SBaptiste Daroussin     }
12280c8de5b0SBaptiste Daroussin     if (((yyn = yygindex[yym]) != 0) && (yyn += yystate) >= 0 &&
12290c8de5b0SBaptiste Daroussin             yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yystate)
12300c8de5b0SBaptiste Daroussin         yystate = yytable[yyn];
12310c8de5b0SBaptiste Daroussin     else
12320c8de5b0SBaptiste Daroussin         yystate = yydgoto[yym];
12330c8de5b0SBaptiste Daroussin #if YYDEBUG
12340c8de5b0SBaptiste Daroussin     if (yydebug)
12350c8de5b0SBaptiste Daroussin     {
12360c8de5b0SBaptiste Daroussin         fprintf(stderr, "%s[%d]: after reduction, ", YYDEBUGSTR, yydepth);
12370c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING
12380c8de5b0SBaptiste Daroussin #if YYBTYACC
12390c8de5b0SBaptiste Daroussin         if (!yytrial)
12400c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
12410c8de5b0SBaptiste Daroussin             fprintf(stderr, "result is <%s>, ", YYSTYPE_TOSTRING(yystos[yystate], yyval));
12420c8de5b0SBaptiste Daroussin #endif
12430c8de5b0SBaptiste Daroussin         fprintf(stderr, "shifting from state %d to state %d\n", *yystack.s_mark, yystate);
12440c8de5b0SBaptiste Daroussin     }
12450c8de5b0SBaptiste Daroussin #endif
12460c8de5b0SBaptiste Daroussin     if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
1247c5b5d71aSJung-uk Kim     *++yystack.s_mark = (YYINT) yystate;
12480c8de5b0SBaptiste Daroussin     *++yystack.l_mark = yyval;
12490c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
12500c8de5b0SBaptiste Daroussin     *++yystack.p_mark = yyloc;
12510c8de5b0SBaptiste Daroussin #endif
12520c8de5b0SBaptiste Daroussin     goto yyloop;
12530c8de5b0SBaptiste Daroussin #if YYBTYACC
12540c8de5b0SBaptiste Daroussin 
12550c8de5b0SBaptiste Daroussin     /* Reduction declares that this path is valid. Set yypath and do a full parse */
12560c8de5b0SBaptiste Daroussin yyvalid:
12570c8de5b0SBaptiste Daroussin     if (yypath) YYABORT;
12580c8de5b0SBaptiste Daroussin     while (yyps->save)
12590c8de5b0SBaptiste Daroussin     {
12600c8de5b0SBaptiste Daroussin         YYParseState *save = yyps->save;
12610c8de5b0SBaptiste Daroussin         yyps->save = save->save;
12620c8de5b0SBaptiste Daroussin         save->save = yypath;
12630c8de5b0SBaptiste Daroussin         yypath = save;
12640c8de5b0SBaptiste Daroussin     }
12650c8de5b0SBaptiste Daroussin #if YYDEBUG
12660c8de5b0SBaptiste Daroussin     if (yydebug)
12670c8de5b0SBaptiste Daroussin         fprintf(stderr, "%s[%d]: state %d, CONFLICT trial successful, backtracking to state %d, %d tokens\n",
12680c8de5b0SBaptiste Daroussin                         YYDEBUGSTR, yydepth, yystate, yypath->state, (int)(yylvp - yylvals - yypath->lexeme));
12690c8de5b0SBaptiste Daroussin #endif
12700c8de5b0SBaptiste Daroussin     if (yyerrctx)
12710c8de5b0SBaptiste Daroussin     {
12720c8de5b0SBaptiste Daroussin         yyFreeState(yyerrctx);
12730c8de5b0SBaptiste Daroussin         yyerrctx = NULL;
12740c8de5b0SBaptiste Daroussin     }
12750c8de5b0SBaptiste Daroussin     yylvp          = yylvals + yypath->lexeme;
12760c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
12770c8de5b0SBaptiste Daroussin     yylpp          = yylpsns + yypath->lexeme;
12780c8de5b0SBaptiste Daroussin #endif
12790c8de5b0SBaptiste Daroussin     yylexp         = yylexemes + yypath->lexeme;
12800c8de5b0SBaptiste Daroussin     yychar         = YYEMPTY;
12810c8de5b0SBaptiste Daroussin     yystack.s_mark = yystack.s_base + (yypath->yystack.s_mark - yypath->yystack.s_base);
1282c5b5d71aSJung-uk Kim     memcpy (yystack.s_base, yypath->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
12830c8de5b0SBaptiste Daroussin     yystack.l_mark = yystack.l_base + (yypath->yystack.l_mark - yypath->yystack.l_base);
128411fce282SBaptiste Daroussin     memcpy (yystack.l_base, yypath->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
12850c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
12860c8de5b0SBaptiste Daroussin     yystack.p_mark = yystack.p_base + (yypath->yystack.p_mark - yypath->yystack.p_base);
128711fce282SBaptiste Daroussin     memcpy (yystack.p_base, yypath->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
12880c8de5b0SBaptiste Daroussin #endif
12890c8de5b0SBaptiste Daroussin     yystate        = yypath->state;
12900c8de5b0SBaptiste Daroussin     goto yyloop;
12910c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
12920c8de5b0SBaptiste Daroussin 
12930c8de5b0SBaptiste Daroussin yyoverflow:
12940c8de5b0SBaptiste Daroussin     YYERROR_CALL("yacc stack overflow");
12950c8de5b0SBaptiste Daroussin #if YYBTYACC
12960c8de5b0SBaptiste Daroussin     goto yyabort_nomem;
12970c8de5b0SBaptiste Daroussin yyenomem:
12980c8de5b0SBaptiste Daroussin     YYERROR_CALL("memory exhausted");
12990c8de5b0SBaptiste Daroussin yyabort_nomem:
13000c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
13010c8de5b0SBaptiste Daroussin     yyresult = 2;
13020c8de5b0SBaptiste Daroussin     goto yyreturn;
13030c8de5b0SBaptiste Daroussin 
13040c8de5b0SBaptiste Daroussin yyabort:
13050c8de5b0SBaptiste Daroussin     yyresult = 1;
13060c8de5b0SBaptiste Daroussin     goto yyreturn;
13070c8de5b0SBaptiste Daroussin 
13080c8de5b0SBaptiste Daroussin yyaccept:
13090c8de5b0SBaptiste Daroussin #if YYBTYACC
13100c8de5b0SBaptiste Daroussin     if (yyps->save) goto yyvalid;
13110c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
13120c8de5b0SBaptiste Daroussin     yyresult = 0;
13130c8de5b0SBaptiste Daroussin 
13140c8de5b0SBaptiste Daroussin yyreturn:
13150c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL)
13160c8de5b0SBaptiste Daroussin     if (yychar != YYEOF && yychar != YYEMPTY)
13170c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
13180c8de5b0SBaptiste Daroussin         YYDESTRUCT_CALL("cleanup: discarding token", yychar, &yylval, &yylloc);
13190c8de5b0SBaptiste Daroussin #else
13200c8de5b0SBaptiste Daroussin         YYDESTRUCT_CALL("cleanup: discarding token", yychar, &yylval);
13210c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
13220c8de5b0SBaptiste Daroussin 
13230c8de5b0SBaptiste Daroussin     {
13240c8de5b0SBaptiste Daroussin         YYSTYPE *pv;
13250c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
13260c8de5b0SBaptiste Daroussin         YYLTYPE *pp;
13270c8de5b0SBaptiste Daroussin 
13280c8de5b0SBaptiste Daroussin         for (pv = yystack.l_base, pp = yystack.p_base; pv <= yystack.l_mark; ++pv, ++pp)
13290c8de5b0SBaptiste Daroussin              YYDESTRUCT_CALL("cleanup: discarding state",
13300c8de5b0SBaptiste Daroussin                              yystos[*(yystack.s_base + (pv - yystack.l_base))], pv, pp);
13310c8de5b0SBaptiste Daroussin #else
13320c8de5b0SBaptiste Daroussin         for (pv = yystack.l_base; pv <= yystack.l_mark; ++pv)
13330c8de5b0SBaptiste Daroussin              YYDESTRUCT_CALL("cleanup: discarding state",
13340c8de5b0SBaptiste Daroussin                              yystos[*(yystack.s_base + (pv - yystack.l_base))], pv);
13350c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
13360c8de5b0SBaptiste Daroussin     }
13370c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */
13380c8de5b0SBaptiste Daroussin 
13390c8de5b0SBaptiste Daroussin #if YYBTYACC
13400c8de5b0SBaptiste Daroussin     if (yyerrctx)
13410c8de5b0SBaptiste Daroussin     {
13420c8de5b0SBaptiste Daroussin         yyFreeState(yyerrctx);
13430c8de5b0SBaptiste Daroussin         yyerrctx = NULL;
13440c8de5b0SBaptiste Daroussin     }
13450c8de5b0SBaptiste Daroussin     while (yyps)
13460c8de5b0SBaptiste Daroussin     {
13470c8de5b0SBaptiste Daroussin         YYParseState *save = yyps;
13480c8de5b0SBaptiste Daroussin         yyps = save->save;
13490c8de5b0SBaptiste Daroussin         save->save = NULL;
13500c8de5b0SBaptiste Daroussin         yyFreeState(save);
13510c8de5b0SBaptiste Daroussin     }
13520c8de5b0SBaptiste Daroussin     while (yypath)
13530c8de5b0SBaptiste Daroussin     {
13540c8de5b0SBaptiste Daroussin         YYParseState *save = yypath;
13550c8de5b0SBaptiste Daroussin         yypath = save->save;
13560c8de5b0SBaptiste Daroussin         save->save = NULL;
13570c8de5b0SBaptiste Daroussin         yyFreeState(save);
13580c8de5b0SBaptiste Daroussin     }
13590c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
13600c8de5b0SBaptiste Daroussin     yyfreestack(&yystack);
13610c8de5b0SBaptiste Daroussin     return (yyresult);
13620c8de5b0SBaptiste Daroussin }
1363