1*8e022d3cSDag-Erling Smørgrav/* $Id: btyaccpar.skel,v 1.13 2021/08/08 19:56:28 tom Exp $ */ 20c8de5b0SBaptiste Daroussin 30c8de5b0SBaptiste Daroussin#include "defs.h" 40c8de5b0SBaptiste Daroussin 50c8de5b0SBaptiste Daroussin/* If the skeleton is changed, the banner should be changed so that */ 60c8de5b0SBaptiste Daroussin/* the altered version can be easily distinguished from the original. */ 70c8de5b0SBaptiste Daroussin/* */ 80c8de5b0SBaptiste Daroussin/* The #defines included with the banner are there because they are */ 90c8de5b0SBaptiste Daroussin/* useful in subsequent code. The macros #defined in the header or */ 100c8de5b0SBaptiste Daroussin/* the body either are not useful outside of semantic actions or */ 110c8de5b0SBaptiste Daroussin/* are conditional. */ 120c8de5b0SBaptiste Daroussin 130c8de5b0SBaptiste Daroussin%% banner 140c8de5b0SBaptiste Daroussin/* original parser id follows */ 150c8de5b0SBaptiste Daroussin/* yysccsid[] = "@(#)yaccpar 1.9 (Berkeley) 02/21/93" */ 160c8de5b0SBaptiste Daroussin/* (use YYMAJOR/YYMINOR for ifdefs dependent on parser version) */ 170c8de5b0SBaptiste Daroussin 180c8de5b0SBaptiste Daroussin#define YYBYACC 1 190c8de5b0SBaptiste Daroussin%% insert VERSION here 200c8de5b0SBaptiste Daroussin 210c8de5b0SBaptiste Daroussin#define YYEMPTY (-1) 220c8de5b0SBaptiste Daroussin#define yyclearin (yychar = YYEMPTY) 230c8de5b0SBaptiste Daroussin#define yyerrok (yyerrflag = 0) 240c8de5b0SBaptiste Daroussin#define YYRECOVERING() (yyerrflag != 0) 250c8de5b0SBaptiste Daroussin#define YYENOMEM (-2) 260c8de5b0SBaptiste Daroussin#define YYEOF 0 270c8de5b0SBaptiste Daroussin%% xdecls 280c8de5b0SBaptiste Daroussin 290c8de5b0SBaptiste Daroussinextern int YYPARSE_DECL(); 300c8de5b0SBaptiste Daroussin%% tables 310c8de5b0SBaptiste Daroussinextern const YYINT yylhs[]; 320c8de5b0SBaptiste Daroussinextern const YYINT yylen[]; 330c8de5b0SBaptiste Daroussinextern const YYINT yydefred[]; 340c8de5b0SBaptiste Daroussinextern const YYINT yystos[]; 350c8de5b0SBaptiste Daroussinextern const YYINT yydgoto[]; 360c8de5b0SBaptiste Daroussinextern const YYINT yysindex[]; 370c8de5b0SBaptiste Daroussinextern const YYINT yyrindex[]; 380c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 390c8de5b0SBaptiste Daroussinextern const YYINT yycindex[]; 400c8de5b0SBaptiste Daroussin%%endif 410c8de5b0SBaptiste Daroussinextern const YYINT yygindex[]; 420c8de5b0SBaptiste Daroussinextern const YYINT yytable[]; 430c8de5b0SBaptiste Daroussinextern const YYINT yycheck[]; 440c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 450c8de5b0SBaptiste Daroussinextern const YYINT yyctable[]; 460c8de5b0SBaptiste Daroussin%%endif 470c8de5b0SBaptiste Daroussin 48c5b5d71aSJung-uk Kim#if YYDEBUG || defined(yytname) 490c8de5b0SBaptiste Daroussinextern const char *const yyname[]; 50c5b5d71aSJung-uk Kim#endif 51c5b5d71aSJung-uk Kim#if YYDEBUG 520c8de5b0SBaptiste Daroussinextern const char *const yyrule[]; 530c8de5b0SBaptiste Daroussin#endif 540c8de5b0SBaptiste Daroussin%% global_vars 550c8de5b0SBaptiste Daroussin 56b53bb29fSJung-uk Kim#if YYDEBUG 570c8de5b0SBaptiste Daroussinint yydebug; 58b53bb29fSJung-uk Kim#endif 590c8de5b0SBaptiste Daroussin%% impure_vars 600c8de5b0SBaptiste Daroussin 610c8de5b0SBaptiste Daroussinint yyerrflag; 620c8de5b0SBaptiste Daroussinint yychar; 630c8de5b0SBaptiste DaroussinYYSTYPE yyval; 640c8de5b0SBaptiste DaroussinYYSTYPE yylval; 65b53bb29fSJung-uk Kimint yynerrs; 66b53bb29fSJung-uk Kim 670c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 680c8de5b0SBaptiste DaroussinYYLTYPE yyloc; /* position returned by actions */ 690c8de5b0SBaptiste DaroussinYYLTYPE yylloc; /* position from the lexer */ 700c8de5b0SBaptiste Daroussin#endif 710c8de5b0SBaptiste Daroussin%% hdr_defs 720c8de5b0SBaptiste Daroussin 730c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 740c8de5b0SBaptiste Daroussin#ifndef YYLLOC_DEFAULT 750c8de5b0SBaptiste Daroussin#define YYLLOC_DEFAULT(loc, rhs, n) \ 760c8de5b0SBaptiste Daroussindo \ 770c8de5b0SBaptiste Daroussin{ \ 780c8de5b0SBaptiste Daroussin if (n == 0) \ 790c8de5b0SBaptiste Daroussin { \ 80b53bb29fSJung-uk Kim (loc).first_line = YYRHSLOC(rhs, 0).last_line; \ 81b53bb29fSJung-uk Kim (loc).first_column = YYRHSLOC(rhs, 0).last_column; \ 82b53bb29fSJung-uk Kim (loc).last_line = YYRHSLOC(rhs, 0).last_line; \ 83b53bb29fSJung-uk Kim (loc).last_column = YYRHSLOC(rhs, 0).last_column; \ 840c8de5b0SBaptiste Daroussin } \ 850c8de5b0SBaptiste Daroussin else \ 860c8de5b0SBaptiste Daroussin { \ 87b53bb29fSJung-uk Kim (loc).first_line = YYRHSLOC(rhs, 1).first_line; \ 88b53bb29fSJung-uk Kim (loc).first_column = YYRHSLOC(rhs, 1).first_column; \ 89b53bb29fSJung-uk Kim (loc).last_line = YYRHSLOC(rhs, n).last_line; \ 90b53bb29fSJung-uk Kim (loc).last_column = YYRHSLOC(rhs, n).last_column; \ 910c8de5b0SBaptiste Daroussin } \ 920c8de5b0SBaptiste Daroussin} while (0) 930c8de5b0SBaptiste Daroussin#endif /* YYLLOC_DEFAULT */ 940c8de5b0SBaptiste Daroussin#endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 950c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 960c8de5b0SBaptiste Daroussin 970c8de5b0SBaptiste Daroussin#ifndef YYLVQUEUEGROWTH 980c8de5b0SBaptiste Daroussin#define YYLVQUEUEGROWTH 32 990c8de5b0SBaptiste Daroussin#endif 1000c8de5b0SBaptiste Daroussin%%endif 1010c8de5b0SBaptiste Daroussin 1020c8de5b0SBaptiste Daroussin/* define the initial stack-sizes */ 1030c8de5b0SBaptiste Daroussin#ifdef YYSTACKSIZE 1040c8de5b0SBaptiste Daroussin#undef YYMAXDEPTH 1050c8de5b0SBaptiste Daroussin#define YYMAXDEPTH YYSTACKSIZE 1060c8de5b0SBaptiste Daroussin#else 1070c8de5b0SBaptiste Daroussin#ifdef YYMAXDEPTH 1080c8de5b0SBaptiste Daroussin#define YYSTACKSIZE YYMAXDEPTH 1090c8de5b0SBaptiste Daroussin#else 1100c8de5b0SBaptiste Daroussin#define YYSTACKSIZE 10000 1110c8de5b0SBaptiste Daroussin#define YYMAXDEPTH 10000 1120c8de5b0SBaptiste Daroussin#endif 1130c8de5b0SBaptiste Daroussin#endif 1140c8de5b0SBaptiste Daroussin 1150c8de5b0SBaptiste Daroussin#ifndef YYINITSTACKSIZE 1160c8de5b0SBaptiste Daroussin#define YYINITSTACKSIZE 200 1170c8de5b0SBaptiste Daroussin#endif 1180c8de5b0SBaptiste Daroussin 1190c8de5b0SBaptiste Daroussintypedef struct { 1200c8de5b0SBaptiste Daroussin unsigned stacksize; 121c5b5d71aSJung-uk Kim YYINT *s_base; 122c5b5d71aSJung-uk Kim YYINT *s_mark; 123c5b5d71aSJung-uk Kim YYINT *s_last; 1240c8de5b0SBaptiste Daroussin YYSTYPE *l_base; 1250c8de5b0SBaptiste Daroussin YYSTYPE *l_mark; 1260c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1270c8de5b0SBaptiste Daroussin YYLTYPE *p_base; 1280c8de5b0SBaptiste Daroussin YYLTYPE *p_mark; 1290c8de5b0SBaptiste Daroussin#endif 1300c8de5b0SBaptiste Daroussin} YYSTACKDATA; 1310c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 1320c8de5b0SBaptiste Daroussin 1330c8de5b0SBaptiste Daroussinstruct YYParseState_s 1340c8de5b0SBaptiste Daroussin{ 1350c8de5b0SBaptiste Daroussin struct YYParseState_s *save; /* Previously saved parser state */ 1360c8de5b0SBaptiste Daroussin YYSTACKDATA yystack; /* saved parser stack */ 1370c8de5b0SBaptiste Daroussin int state; /* saved parser state */ 1380c8de5b0SBaptiste Daroussin int errflag; /* saved error recovery status */ 1390c8de5b0SBaptiste Daroussin int lexeme; /* saved index of the conflict lexeme in the lexical queue */ 1400c8de5b0SBaptiste Daroussin YYINT ctry; /* saved index in yyctable[] for this conflict */ 1410c8de5b0SBaptiste Daroussin}; 1420c8de5b0SBaptiste Daroussintypedef struct YYParseState_s YYParseState; 1430c8de5b0SBaptiste Daroussin%%endif YYBTYACC 1440c8de5b0SBaptiste Daroussin%% hdr_vars 1450c8de5b0SBaptiste Daroussin/* variables for the parser stack */ 1460c8de5b0SBaptiste Daroussinstatic YYSTACKDATA yystack; 1470c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 1480c8de5b0SBaptiste Daroussin 1490c8de5b0SBaptiste Daroussin/* Current parser state */ 1500c8de5b0SBaptiste Daroussinstatic YYParseState *yyps = 0; 1510c8de5b0SBaptiste Daroussin 1520c8de5b0SBaptiste Daroussin/* yypath != NULL: do the full parse, starting at *yypath parser state. */ 1530c8de5b0SBaptiste Daroussinstatic YYParseState *yypath = 0; 1540c8de5b0SBaptiste Daroussin 1550c8de5b0SBaptiste Daroussin/* Base of the lexical value queue */ 1560c8de5b0SBaptiste Daroussinstatic YYSTYPE *yylvals = 0; 1570c8de5b0SBaptiste Daroussin 1580c8de5b0SBaptiste Daroussin/* Current position at lexical value queue */ 1590c8de5b0SBaptiste Daroussinstatic YYSTYPE *yylvp = 0; 1600c8de5b0SBaptiste Daroussin 1610c8de5b0SBaptiste Daroussin/* End position of lexical value queue */ 1620c8de5b0SBaptiste Daroussinstatic YYSTYPE *yylve = 0; 1630c8de5b0SBaptiste Daroussin 1640c8de5b0SBaptiste Daroussin/* The last allocated position at the lexical value queue */ 1650c8de5b0SBaptiste Daroussinstatic YYSTYPE *yylvlim = 0; 1660c8de5b0SBaptiste Daroussin 1670c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1680c8de5b0SBaptiste Daroussin/* Base of the lexical position queue */ 1690c8de5b0SBaptiste Daroussinstatic YYLTYPE *yylpsns = 0; 1700c8de5b0SBaptiste Daroussin 1710c8de5b0SBaptiste Daroussin/* Current position at lexical position queue */ 1720c8de5b0SBaptiste Daroussinstatic YYLTYPE *yylpp = 0; 1730c8de5b0SBaptiste Daroussin 1740c8de5b0SBaptiste Daroussin/* End position of lexical position queue */ 1750c8de5b0SBaptiste Daroussinstatic YYLTYPE *yylpe = 0; 1760c8de5b0SBaptiste Daroussin 1770c8de5b0SBaptiste Daroussin/* The last allocated position at the lexical position queue */ 1780c8de5b0SBaptiste Daroussinstatic YYLTYPE *yylplim = 0; 1790c8de5b0SBaptiste Daroussin#endif 1800c8de5b0SBaptiste Daroussin 1810c8de5b0SBaptiste Daroussin/* Current position at lexical token queue */ 1822aca18c7SJung-uk Kimstatic YYINT *yylexp = 0; 1830c8de5b0SBaptiste Daroussin 1842aca18c7SJung-uk Kimstatic YYINT *yylexemes = 0; 1850c8de5b0SBaptiste Daroussin%%endif YYBTYACC 1860c8de5b0SBaptiste Daroussin%% body_vars 1870c8de5b0SBaptiste Daroussin int yyerrflag; 1880c8de5b0SBaptiste Daroussin int yychar; 1890c8de5b0SBaptiste Daroussin YYSTYPE yyval; 1900c8de5b0SBaptiste Daroussin YYSTYPE yylval; 191b53bb29fSJung-uk Kim int yynerrs; 192b53bb29fSJung-uk Kim 1930c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1940c8de5b0SBaptiste Daroussin YYLTYPE yyloc; /* position returned by actions */ 1950c8de5b0SBaptiste Daroussin YYLTYPE yylloc; /* position from the lexer */ 1960c8de5b0SBaptiste Daroussin#endif 1970c8de5b0SBaptiste Daroussin 1980c8de5b0SBaptiste Daroussin /* variables for the parser stack */ 1990c8de5b0SBaptiste Daroussin YYSTACKDATA yystack; 2000c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 2010c8de5b0SBaptiste Daroussin 2020c8de5b0SBaptiste Daroussin /* Current parser state */ 2030c8de5b0SBaptiste Daroussin static YYParseState *yyps = 0; 2040c8de5b0SBaptiste Daroussin 2050c8de5b0SBaptiste Daroussin /* yypath != NULL: do the full parse, starting at *yypath parser state. */ 2060c8de5b0SBaptiste Daroussin static YYParseState *yypath = 0; 2070c8de5b0SBaptiste Daroussin 2080c8de5b0SBaptiste Daroussin /* Base of the lexical value queue */ 2090c8de5b0SBaptiste Daroussin static YYSTYPE *yylvals = 0; 2100c8de5b0SBaptiste Daroussin 2110c8de5b0SBaptiste Daroussin /* Current position at lexical value queue */ 2120c8de5b0SBaptiste Daroussin static YYSTYPE *yylvp = 0; 2130c8de5b0SBaptiste Daroussin 2140c8de5b0SBaptiste Daroussin /* End position of lexical value queue */ 2150c8de5b0SBaptiste Daroussin static YYSTYPE *yylve = 0; 2160c8de5b0SBaptiste Daroussin 2170c8de5b0SBaptiste Daroussin /* The last allocated position at the lexical value queue */ 2180c8de5b0SBaptiste Daroussin static YYSTYPE *yylvlim = 0; 2190c8de5b0SBaptiste Daroussin 2200c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 2210c8de5b0SBaptiste Daroussin /* Base of the lexical position queue */ 2220c8de5b0SBaptiste Daroussin static YYLTYPE *yylpsns = 0; 2230c8de5b0SBaptiste Daroussin 2240c8de5b0SBaptiste Daroussin /* Current position at lexical position queue */ 2250c8de5b0SBaptiste Daroussin static YYLTYPE *yylpp = 0; 2260c8de5b0SBaptiste Daroussin 2270c8de5b0SBaptiste Daroussin /* End position of lexical position queue */ 2280c8de5b0SBaptiste Daroussin static YYLTYPE *yylpe = 0; 2290c8de5b0SBaptiste Daroussin 2300c8de5b0SBaptiste Daroussin /* The last allocated position at the lexical position queue */ 2310c8de5b0SBaptiste Daroussin static YYLTYPE *yylplim = 0; 2320c8de5b0SBaptiste Daroussin#endif 2330c8de5b0SBaptiste Daroussin 2340c8de5b0SBaptiste Daroussin /* Current position at lexical token queue */ 2352aca18c7SJung-uk Kim static YYINT *yylexp = 0; 2360c8de5b0SBaptiste Daroussin 2372aca18c7SJung-uk Kim static YYINT *yylexemes = 0; 2380c8de5b0SBaptiste Daroussin%%endif YYBTYACC 2390c8de5b0SBaptiste Daroussin%% body_1 2400c8de5b0SBaptiste Daroussin 2410c8de5b0SBaptiste Daroussin/* For use in generated program */ 2420c8de5b0SBaptiste Daroussin#define yydepth (int)(yystack.s_mark - yystack.s_base) 2430c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 2440c8de5b0SBaptiste Daroussin#define yytrial (yyps->save) 2450c8de5b0SBaptiste Daroussin%%endif 2460c8de5b0SBaptiste Daroussin 2470c8de5b0SBaptiste Daroussin#if YYDEBUG 2480c8de5b0SBaptiste Daroussin#include <stdio.h> /* needed for printf */ 2490c8de5b0SBaptiste Daroussin#endif 2500c8de5b0SBaptiste Daroussin 2510c8de5b0SBaptiste Daroussin#include <stdlib.h> /* needed for malloc, etc */ 2520c8de5b0SBaptiste Daroussin#include <string.h> /* needed for memset */ 2530c8de5b0SBaptiste Daroussin 2540c8de5b0SBaptiste Daroussin/* allocate initial stack or double stack size, up to YYMAXDEPTH */ 2550c8de5b0SBaptiste Daroussinstatic int yygrowstack(YYSTACKDATA *data) 2560c8de5b0SBaptiste Daroussin{ 2570c8de5b0SBaptiste Daroussin int i; 2580c8de5b0SBaptiste Daroussin unsigned newsize; 259c5b5d71aSJung-uk Kim YYINT *newss; 2600c8de5b0SBaptiste Daroussin YYSTYPE *newvs; 2610c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 2620c8de5b0SBaptiste Daroussin YYLTYPE *newps; 2630c8de5b0SBaptiste Daroussin#endif 2640c8de5b0SBaptiste Daroussin 2650c8de5b0SBaptiste Daroussin if ((newsize = data->stacksize) == 0) 2660c8de5b0SBaptiste Daroussin newsize = YYINITSTACKSIZE; 2670c8de5b0SBaptiste Daroussin else if (newsize >= YYMAXDEPTH) 2680c8de5b0SBaptiste Daroussin return YYENOMEM; 2690c8de5b0SBaptiste Daroussin else if ((newsize *= 2) > YYMAXDEPTH) 2700c8de5b0SBaptiste Daroussin newsize = YYMAXDEPTH; 2710c8de5b0SBaptiste Daroussin 2720c8de5b0SBaptiste Daroussin i = (int) (data->s_mark - data->s_base); 273c5b5d71aSJung-uk Kim newss = (YYINT *)realloc(data->s_base, newsize * sizeof(*newss)); 27480f31432SJung-uk Kim if (newss == NULL) 2750c8de5b0SBaptiste Daroussin return YYENOMEM; 2760c8de5b0SBaptiste Daroussin 2770c8de5b0SBaptiste Daroussin data->s_base = newss; 2780c8de5b0SBaptiste Daroussin data->s_mark = newss + i; 2790c8de5b0SBaptiste Daroussin 2800c8de5b0SBaptiste Daroussin newvs = (YYSTYPE *)realloc(data->l_base, newsize * sizeof(*newvs)); 28180f31432SJung-uk Kim if (newvs == NULL) 2820c8de5b0SBaptiste Daroussin return YYENOMEM; 2830c8de5b0SBaptiste Daroussin 2840c8de5b0SBaptiste Daroussin data->l_base = newvs; 2850c8de5b0SBaptiste Daroussin data->l_mark = newvs + i; 2860c8de5b0SBaptiste Daroussin 2870c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 2880c8de5b0SBaptiste Daroussin newps = (YYLTYPE *)realloc(data->p_base, newsize * sizeof(*newps)); 28980f31432SJung-uk Kim if (newps == NULL) 2900c8de5b0SBaptiste Daroussin return YYENOMEM; 2910c8de5b0SBaptiste Daroussin 2920c8de5b0SBaptiste Daroussin data->p_base = newps; 2930c8de5b0SBaptiste Daroussin data->p_mark = newps + i; 2940c8de5b0SBaptiste Daroussin#endif 2950c8de5b0SBaptiste Daroussin 2960c8de5b0SBaptiste Daroussin data->stacksize = newsize; 2970c8de5b0SBaptiste Daroussin data->s_last = data->s_base + newsize - 1; 2980c8de5b0SBaptiste Daroussin 2990c8de5b0SBaptiste Daroussin#if YYDEBUG 3000c8de5b0SBaptiste Daroussin if (yydebug) 3010c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug: stack size increased to %d\n", YYPREFIX, newsize); 3020c8de5b0SBaptiste Daroussin#endif 3030c8de5b0SBaptiste Daroussin return 0; 3040c8de5b0SBaptiste Daroussin} 3050c8de5b0SBaptiste Daroussin 3060c8de5b0SBaptiste Daroussin#if YYPURE || defined(YY_NO_LEAKS) 3070c8de5b0SBaptiste Daroussinstatic void yyfreestack(YYSTACKDATA *data) 3080c8de5b0SBaptiste Daroussin{ 3090c8de5b0SBaptiste Daroussin free(data->s_base); 3100c8de5b0SBaptiste Daroussin free(data->l_base); 3110c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 3120c8de5b0SBaptiste Daroussin free(data->p_base); 3130c8de5b0SBaptiste Daroussin#endif 3140c8de5b0SBaptiste Daroussin memset(data, 0, sizeof(*data)); 3150c8de5b0SBaptiste Daroussin} 3160c8de5b0SBaptiste Daroussin#else 3170c8de5b0SBaptiste Daroussin#define yyfreestack(data) /* nothing */ 3180c8de5b0SBaptiste Daroussin#endif /* YYPURE || defined(YY_NO_LEAKS) */ 3190c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 3200c8de5b0SBaptiste Daroussin 3210c8de5b0SBaptiste Daroussinstatic YYParseState * 3220c8de5b0SBaptiste DaroussinyyNewState(unsigned size) 3230c8de5b0SBaptiste Daroussin{ 3240c8de5b0SBaptiste Daroussin YYParseState *p = (YYParseState *) malloc(sizeof(YYParseState)); 3250c8de5b0SBaptiste Daroussin if (p == NULL) return NULL; 3260c8de5b0SBaptiste Daroussin 3270c8de5b0SBaptiste Daroussin p->yystack.stacksize = size; 3280c8de5b0SBaptiste Daroussin if (size == 0) 3290c8de5b0SBaptiste Daroussin { 3300c8de5b0SBaptiste Daroussin p->yystack.s_base = NULL; 3310c8de5b0SBaptiste Daroussin p->yystack.l_base = NULL; 3320c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 3330c8de5b0SBaptiste Daroussin p->yystack.p_base = NULL; 3340c8de5b0SBaptiste Daroussin#endif 3350c8de5b0SBaptiste Daroussin return p; 3360c8de5b0SBaptiste Daroussin } 337c5b5d71aSJung-uk Kim p->yystack.s_base = (YYINT *) malloc(size * sizeof(YYINT)); 3380c8de5b0SBaptiste Daroussin if (p->yystack.s_base == NULL) return NULL; 3390c8de5b0SBaptiste Daroussin p->yystack.l_base = (YYSTYPE *) malloc(size * sizeof(YYSTYPE)); 3400c8de5b0SBaptiste Daroussin if (p->yystack.l_base == NULL) return NULL; 3410c8de5b0SBaptiste Daroussin memset(p->yystack.l_base, 0, size * sizeof(YYSTYPE)); 3420c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 3430c8de5b0SBaptiste Daroussin p->yystack.p_base = (YYLTYPE *) malloc(size * sizeof(YYLTYPE)); 3440c8de5b0SBaptiste Daroussin if (p->yystack.p_base == NULL) return NULL; 3450c8de5b0SBaptiste Daroussin memset(p->yystack.p_base, 0, size * sizeof(YYLTYPE)); 3460c8de5b0SBaptiste Daroussin#endif 3470c8de5b0SBaptiste Daroussin 3480c8de5b0SBaptiste Daroussin return p; 3490c8de5b0SBaptiste Daroussin} 3500c8de5b0SBaptiste Daroussin 3510c8de5b0SBaptiste Daroussinstatic void 3520c8de5b0SBaptiste DaroussinyyFreeState(YYParseState *p) 3530c8de5b0SBaptiste Daroussin{ 3540c8de5b0SBaptiste Daroussin yyfreestack(&p->yystack); 3550c8de5b0SBaptiste Daroussin free(p); 3560c8de5b0SBaptiste Daroussin} 3570c8de5b0SBaptiste Daroussin%%endif YYBTYACC 3580c8de5b0SBaptiste Daroussin 3590c8de5b0SBaptiste Daroussin#define YYABORT goto yyabort 3600c8de5b0SBaptiste Daroussin#define YYREJECT goto yyabort 3610c8de5b0SBaptiste Daroussin#define YYACCEPT goto yyaccept 3620c8de5b0SBaptiste Daroussin#define YYERROR goto yyerrlab 3630c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 3640c8de5b0SBaptiste Daroussin#define YYVALID do { if (yyps->save) goto yyvalid; } while(0) 3650c8de5b0SBaptiste Daroussin#define YYVALID_NESTED do { if (yyps->save && \ 3660c8de5b0SBaptiste Daroussin yyps->save->save == 0) goto yyvalid; } while(0) 3670c8de5b0SBaptiste Daroussin%%endif 3680c8de5b0SBaptiste Daroussin 3690c8de5b0SBaptiste Daroussinint 3700c8de5b0SBaptiste DaroussinYYPARSE_DECL() 3710c8de5b0SBaptiste Daroussin{ 3720c8de5b0SBaptiste Daroussin%% body_2 3730c8de5b0SBaptiste Daroussin int yym, yyn, yystate, yyresult; 3740c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 3750c8de5b0SBaptiste Daroussin int yynewerrflag; 3760c8de5b0SBaptiste Daroussin YYParseState *yyerrctx = NULL; 3770c8de5b0SBaptiste Daroussin%%endif 3780c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 379b53bb29fSJung-uk Kim YYLTYPE yyerror_loc_range[3]; /* position of error start/end (0 unused) */ 3800c8de5b0SBaptiste Daroussin#endif 3810c8de5b0SBaptiste Daroussin#if YYDEBUG 3820c8de5b0SBaptiste Daroussin const char *yys; 3830c8de5b0SBaptiste Daroussin 38480f31432SJung-uk Kim if ((yys = getenv("YYDEBUG")) != NULL) 3850c8de5b0SBaptiste Daroussin { 3860c8de5b0SBaptiste Daroussin yyn = *yys; 3870c8de5b0SBaptiste Daroussin if (yyn >= '0' && yyn <= '9') 3880c8de5b0SBaptiste Daroussin yydebug = yyn - '0'; 3890c8de5b0SBaptiste Daroussin } 3900c8de5b0SBaptiste Daroussin if (yydebug) 3910c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug[<# of symbols on state stack>]\n", YYPREFIX); 3920c8de5b0SBaptiste Daroussin#endif 3936166fdceSJung-uk Kim#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 3946166fdceSJung-uk Kim memset(yyerror_loc_range, 0, sizeof(yyerror_loc_range)); 3956166fdceSJung-uk Kim#endif 3966166fdceSJung-uk Kim 3976166fdceSJung-uk Kim%% init_vars 3986166fdceSJung-uk Kim yyerrflag = 0; 3996166fdceSJung-uk Kim yychar = 0; 4006166fdceSJung-uk Kim memset(&yyval, 0, sizeof(yyval)); 4016166fdceSJung-uk Kim memset(&yylval, 0, sizeof(yylval)); 4026166fdceSJung-uk Kim#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 4036166fdceSJung-uk Kim memset(&yyloc, 0, sizeof(yyloc)); 4046166fdceSJung-uk Kim memset(&yylloc, 0, sizeof(yylloc)); 4056166fdceSJung-uk Kim#endif 4060c8de5b0SBaptiste Daroussin 4072aca18c7SJung-uk Kim%% body_3 4080c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 4090c8de5b0SBaptiste Daroussin yyps = yyNewState(0); if (yyps == 0) goto yyenomem; 4100c8de5b0SBaptiste Daroussin yyps->save = 0; 4110c8de5b0SBaptiste Daroussin%%endif 412c5b5d71aSJung-uk Kim yym = 0; 413*8e022d3cSDag-Erling Smørgrav /* yyn is set below */ 4140c8de5b0SBaptiste Daroussin yynerrs = 0; 4150c8de5b0SBaptiste Daroussin yyerrflag = 0; 4160c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 4170c8de5b0SBaptiste Daroussin yystate = 0; 4180c8de5b0SBaptiste Daroussin 4190c8de5b0SBaptiste Daroussin#if YYPURE 4200c8de5b0SBaptiste Daroussin memset(&yystack, 0, sizeof(yystack)); 4210c8de5b0SBaptiste Daroussin#endif 4220c8de5b0SBaptiste Daroussin 4230c8de5b0SBaptiste Daroussin if (yystack.s_base == NULL && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 4240c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base; 4250c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base; 4260c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 4270c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base; 4280c8de5b0SBaptiste Daroussin#endif 4290c8de5b0SBaptiste Daroussin yystate = 0; 4300c8de5b0SBaptiste Daroussin *yystack.s_mark = 0; 4310c8de5b0SBaptiste Daroussin 4320c8de5b0SBaptiste Daroussinyyloop: 4330c8de5b0SBaptiste Daroussin if ((yyn = yydefred[yystate]) != 0) goto yyreduce; 4340c8de5b0SBaptiste Daroussin if (yychar < 0) 4350c8de5b0SBaptiste Daroussin { 4360c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 4370c8de5b0SBaptiste Daroussin do { 4380c8de5b0SBaptiste Daroussin if (yylvp < yylve) 4390c8de5b0SBaptiste Daroussin { 4400c8de5b0SBaptiste Daroussin /* we're currently re-reading tokens */ 4410c8de5b0SBaptiste Daroussin yylval = *yylvp++; 4420c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 4430c8de5b0SBaptiste Daroussin yylloc = *yylpp++; 4440c8de5b0SBaptiste Daroussin#endif 4450c8de5b0SBaptiste Daroussin yychar = *yylexp++; 4460c8de5b0SBaptiste Daroussin break; 4470c8de5b0SBaptiste Daroussin } 4480c8de5b0SBaptiste Daroussin if (yyps->save) 4490c8de5b0SBaptiste Daroussin { 4500c8de5b0SBaptiste Daroussin /* in trial mode; save scanner results for future parse attempts */ 4510c8de5b0SBaptiste Daroussin if (yylvp == yylvlim) 4520c8de5b0SBaptiste Daroussin { /* Enlarge lexical value queue */ 453c5b5d71aSJung-uk Kim size_t p = (size_t) (yylvp - yylvals); 454c5b5d71aSJung-uk Kim size_t s = (size_t) (yylvlim - yylvals); 4550c8de5b0SBaptiste Daroussin 4560c8de5b0SBaptiste Daroussin s += YYLVQUEUEGROWTH; 457b53bb29fSJung-uk Kim if ((yylexemes = (YYINT *)realloc(yylexemes, s * sizeof(YYINT))) == NULL) goto yyenomem; 458b53bb29fSJung-uk Kim if ((yylvals = (YYSTYPE *)realloc(yylvals, s * sizeof(YYSTYPE))) == NULL) goto yyenomem; 4590c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 460b53bb29fSJung-uk Kim if ((yylpsns = (YYLTYPE *)realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL) goto yyenomem; 4610c8de5b0SBaptiste Daroussin#endif 4620c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals + p; 4630c8de5b0SBaptiste Daroussin yylvlim = yylvals + s; 4640c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 4650c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns + p; 4660c8de5b0SBaptiste Daroussin yylplim = yylpsns + s; 4670c8de5b0SBaptiste Daroussin#endif 4680c8de5b0SBaptiste Daroussin yylexp = yylexemes + p; 4690c8de5b0SBaptiste Daroussin } 4702aca18c7SJung-uk Kim *yylexp = (YYINT) YYLEX; 4710c8de5b0SBaptiste Daroussin *yylvp++ = yylval; 4720c8de5b0SBaptiste Daroussin yylve++; 4730c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 4740c8de5b0SBaptiste Daroussin *yylpp++ = yylloc; 4750c8de5b0SBaptiste Daroussin yylpe++; 4760c8de5b0SBaptiste Daroussin#endif 4770c8de5b0SBaptiste Daroussin yychar = *yylexp++; 4780c8de5b0SBaptiste Daroussin break; 4790c8de5b0SBaptiste Daroussin } 4800c8de5b0SBaptiste Daroussin /* normal operation, no conflict encountered */ 4810c8de5b0SBaptiste Daroussin%%endif YYBTYACC 4820c8de5b0SBaptiste Daroussin yychar = YYLEX; 4830c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 4840c8de5b0SBaptiste Daroussin } while (0); 4850c8de5b0SBaptiste Daroussin%%endif 4860c8de5b0SBaptiste Daroussin if (yychar < 0) yychar = YYEOF; 4870c8de5b0SBaptiste Daroussin#if YYDEBUG 4880c8de5b0SBaptiste Daroussin if (yydebug) 4890c8de5b0SBaptiste Daroussin { 490c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 4910c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)", 4920c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yychar, yys); 4930c8de5b0SBaptiste Daroussin#ifdef YYSTYPE_TOSTRING 4940c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 4950c8de5b0SBaptiste Daroussin if (!yytrial) 4960c8de5b0SBaptiste Daroussin%%endif 4970c8de5b0SBaptiste Daroussin fprintf(stderr, " <%s>", YYSTYPE_TOSTRING(yychar, yylval)); 4980c8de5b0SBaptiste Daroussin#endif 4990c8de5b0SBaptiste Daroussin fputc('\n', stderr); 5000c8de5b0SBaptiste Daroussin } 5010c8de5b0SBaptiste Daroussin#endif 5020c8de5b0SBaptiste Daroussin } 5030c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 5040c8de5b0SBaptiste Daroussin 5050c8de5b0SBaptiste Daroussin /* Do we have a conflict? */ 5060c8de5b0SBaptiste Daroussin if (((yyn = yycindex[yystate]) != 0) && (yyn += yychar) >= 0 && 5070c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 5080c8de5b0SBaptiste Daroussin { 5090c8de5b0SBaptiste Daroussin YYINT ctry; 5100c8de5b0SBaptiste Daroussin 5110c8de5b0SBaptiste Daroussin if (yypath) 5120c8de5b0SBaptiste Daroussin { 5130c8de5b0SBaptiste Daroussin YYParseState *save; 5140c8de5b0SBaptiste Daroussin#if YYDEBUG 5150c8de5b0SBaptiste Daroussin if (yydebug) 5160c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: CONFLICT in state %d: following successful trial parse\n", 5170c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate); 5180c8de5b0SBaptiste Daroussin#endif 5190c8de5b0SBaptiste Daroussin /* Switch to the next conflict context */ 5200c8de5b0SBaptiste Daroussin save = yypath; 5210c8de5b0SBaptiste Daroussin yypath = save->save; 5220c8de5b0SBaptiste Daroussin save->save = NULL; 5230c8de5b0SBaptiste Daroussin ctry = save->ctry; 5240c8de5b0SBaptiste Daroussin if (save->state != yystate) YYABORT; 5250c8de5b0SBaptiste Daroussin yyFreeState(save); 5260c8de5b0SBaptiste Daroussin 5270c8de5b0SBaptiste Daroussin } 5280c8de5b0SBaptiste Daroussin else 5290c8de5b0SBaptiste Daroussin { 5300c8de5b0SBaptiste Daroussin 5310c8de5b0SBaptiste Daroussin /* Unresolved conflict - start/continue trial parse */ 5320c8de5b0SBaptiste Daroussin YYParseState *save; 5330c8de5b0SBaptiste Daroussin#if YYDEBUG 5340c8de5b0SBaptiste Daroussin if (yydebug) 5350c8de5b0SBaptiste Daroussin { 5360c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: CONFLICT in state %d. ", YYDEBUGSTR, yydepth, yystate); 5370c8de5b0SBaptiste Daroussin if (yyps->save) 5380c8de5b0SBaptiste Daroussin fputs("ALREADY in conflict, continuing trial parse.\n", stderr); 5390c8de5b0SBaptiste Daroussin else 5400c8de5b0SBaptiste Daroussin fputs("Starting trial parse.\n", stderr); 5410c8de5b0SBaptiste Daroussin } 5420c8de5b0SBaptiste Daroussin#endif 5430c8de5b0SBaptiste Daroussin save = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1)); 5440c8de5b0SBaptiste Daroussin if (save == NULL) goto yyenomem; 5450c8de5b0SBaptiste Daroussin save->save = yyps->save; 5460c8de5b0SBaptiste Daroussin save->state = yystate; 5470c8de5b0SBaptiste Daroussin save->errflag = yyerrflag; 5480c8de5b0SBaptiste Daroussin save->yystack.s_mark = save->yystack.s_base + (yystack.s_mark - yystack.s_base); 549c5b5d71aSJung-uk Kim memcpy (save->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 5500c8de5b0SBaptiste Daroussin save->yystack.l_mark = save->yystack.l_base + (yystack.l_mark - yystack.l_base); 551c5b5d71aSJung-uk Kim memcpy (save->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 5520c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 5530c8de5b0SBaptiste Daroussin save->yystack.p_mark = save->yystack.p_base + (yystack.p_mark - yystack.p_base); 554c5b5d71aSJung-uk Kim memcpy (save->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 5550c8de5b0SBaptiste Daroussin#endif 5560c8de5b0SBaptiste Daroussin ctry = yytable[yyn]; 5570c8de5b0SBaptiste Daroussin if (yyctable[ctry] == -1) 5580c8de5b0SBaptiste Daroussin { 5590c8de5b0SBaptiste Daroussin#if YYDEBUG 5600c8de5b0SBaptiste Daroussin if (yydebug && yychar >= YYEOF) 5610c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: backtracking 1 token\n", YYDEBUGSTR, yydepth); 5620c8de5b0SBaptiste Daroussin#endif 5630c8de5b0SBaptiste Daroussin ctry++; 5640c8de5b0SBaptiste Daroussin } 5650c8de5b0SBaptiste Daroussin save->ctry = ctry; 5660c8de5b0SBaptiste Daroussin if (yyps->save == NULL) 5670c8de5b0SBaptiste Daroussin { 5680c8de5b0SBaptiste Daroussin /* If this is a first conflict in the stack, start saving lexemes */ 5690c8de5b0SBaptiste Daroussin if (!yylexemes) 5700c8de5b0SBaptiste Daroussin { 571b53bb29fSJung-uk Kim yylexemes = (YYINT *) malloc((YYLVQUEUEGROWTH) * sizeof(YYINT)); 5720c8de5b0SBaptiste Daroussin if (yylexemes == NULL) goto yyenomem; 5730c8de5b0SBaptiste Daroussin yylvals = (YYSTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYSTYPE)); 5740c8de5b0SBaptiste Daroussin if (yylvals == NULL) goto yyenomem; 5750c8de5b0SBaptiste Daroussin yylvlim = yylvals + YYLVQUEUEGROWTH; 5760c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 5770c8de5b0SBaptiste Daroussin yylpsns = (YYLTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYLTYPE)); 5780c8de5b0SBaptiste Daroussin if (yylpsns == NULL) goto yyenomem; 5790c8de5b0SBaptiste Daroussin yylplim = yylpsns + YYLVQUEUEGROWTH; 5800c8de5b0SBaptiste Daroussin#endif 5810c8de5b0SBaptiste Daroussin } 5820c8de5b0SBaptiste Daroussin if (yylvp == yylve) 5830c8de5b0SBaptiste Daroussin { 5840c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals; 5850c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 5860c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns; 5870c8de5b0SBaptiste Daroussin#endif 5880c8de5b0SBaptiste Daroussin yylexp = yylexemes; 5890c8de5b0SBaptiste Daroussin if (yychar >= YYEOF) 5900c8de5b0SBaptiste Daroussin { 5910c8de5b0SBaptiste Daroussin *yylve++ = yylval; 5920c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 5930c8de5b0SBaptiste Daroussin *yylpe++ = yylloc; 5940c8de5b0SBaptiste Daroussin#endif 5952aca18c7SJung-uk Kim *yylexp = (YYINT) yychar; 5960c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 5970c8de5b0SBaptiste Daroussin } 5980c8de5b0SBaptiste Daroussin } 5990c8de5b0SBaptiste Daroussin } 6000c8de5b0SBaptiste Daroussin if (yychar >= YYEOF) 6010c8de5b0SBaptiste Daroussin { 6020c8de5b0SBaptiste Daroussin yylvp--; 6030c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6040c8de5b0SBaptiste Daroussin yylpp--; 6050c8de5b0SBaptiste Daroussin#endif 6060c8de5b0SBaptiste Daroussin yylexp--; 6070c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 6080c8de5b0SBaptiste Daroussin } 609c5b5d71aSJung-uk Kim save->lexeme = (int) (yylvp - yylvals); 6100c8de5b0SBaptiste Daroussin yyps->save = save; 6110c8de5b0SBaptiste Daroussin } 6120c8de5b0SBaptiste Daroussin if (yytable[yyn] == ctry) 6130c8de5b0SBaptiste Daroussin { 6140c8de5b0SBaptiste Daroussin#if YYDEBUG 6150c8de5b0SBaptiste Daroussin if (yydebug) 6160c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n", 6170c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyctable[ctry]); 6180c8de5b0SBaptiste Daroussin#endif 6190c8de5b0SBaptiste Daroussin if (yychar < 0) 6200c8de5b0SBaptiste Daroussin { 6210c8de5b0SBaptiste Daroussin yylvp++; 6220c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6230c8de5b0SBaptiste Daroussin yylpp++; 6240c8de5b0SBaptiste Daroussin#endif 6250c8de5b0SBaptiste Daroussin yylexp++; 6260c8de5b0SBaptiste Daroussin } 6270c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) 6280c8de5b0SBaptiste Daroussin goto yyoverflow; 6290c8de5b0SBaptiste Daroussin yystate = yyctable[ctry]; 630c5b5d71aSJung-uk Kim *++yystack.s_mark = (YYINT) yystate; 6310c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval; 6320c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6330c8de5b0SBaptiste Daroussin *++yystack.p_mark = yylloc; 6340c8de5b0SBaptiste Daroussin#endif 6350c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 6360c8de5b0SBaptiste Daroussin if (yyerrflag > 0) --yyerrflag; 6370c8de5b0SBaptiste Daroussin goto yyloop; 6380c8de5b0SBaptiste Daroussin } 6390c8de5b0SBaptiste Daroussin else 6400c8de5b0SBaptiste Daroussin { 6410c8de5b0SBaptiste Daroussin yyn = yyctable[ctry]; 6420c8de5b0SBaptiste Daroussin goto yyreduce; 6430c8de5b0SBaptiste Daroussin } 6440c8de5b0SBaptiste Daroussin } /* End of code dealing with conflicts */ 6450c8de5b0SBaptiste Daroussin%%endif YYBTYACC 6460c8de5b0SBaptiste Daroussin if (((yyn = yysindex[yystate]) != 0) && (yyn += yychar) >= 0 && 6470c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 6480c8de5b0SBaptiste Daroussin { 6490c8de5b0SBaptiste Daroussin#if YYDEBUG 6500c8de5b0SBaptiste Daroussin if (yydebug) 6510c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n", 6520c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yytable[yyn]); 6530c8de5b0SBaptiste Daroussin#endif 6540c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 6550c8de5b0SBaptiste Daroussin yystate = yytable[yyn]; 6560c8de5b0SBaptiste Daroussin *++yystack.s_mark = yytable[yyn]; 6570c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval; 6580c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6590c8de5b0SBaptiste Daroussin *++yystack.p_mark = yylloc; 6600c8de5b0SBaptiste Daroussin#endif 6610c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 6620c8de5b0SBaptiste Daroussin if (yyerrflag > 0) --yyerrflag; 6630c8de5b0SBaptiste Daroussin goto yyloop; 6640c8de5b0SBaptiste Daroussin } 6650c8de5b0SBaptiste Daroussin if (((yyn = yyrindex[yystate]) != 0) && (yyn += yychar) >= 0 && 6660c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 6670c8de5b0SBaptiste Daroussin { 6680c8de5b0SBaptiste Daroussin yyn = yytable[yyn]; 6690c8de5b0SBaptiste Daroussin goto yyreduce; 6700c8de5b0SBaptiste Daroussin } 6710c8de5b0SBaptiste Daroussin if (yyerrflag != 0) goto yyinrecovery; 6720c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 6730c8de5b0SBaptiste Daroussin 6740c8de5b0SBaptiste Daroussin yynewerrflag = 1; 6750c8de5b0SBaptiste Daroussin goto yyerrhandler; 676c5b5d71aSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */ 6770c8de5b0SBaptiste Daroussin 6780c8de5b0SBaptiste Daroussinyyerrlab: 679c5b5d71aSJung-uk Kim /* explicit YYERROR from an action -- pop the rhs of the rule reduced 680c5b5d71aSJung-uk Kim * before looking for error recovery */ 681c5b5d71aSJung-uk Kim yystack.s_mark -= yym; 682c5b5d71aSJung-uk Kim yystate = *yystack.s_mark; 683c5b5d71aSJung-uk Kim yystack.l_mark -= yym; 684c5b5d71aSJung-uk Kim#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 685c5b5d71aSJung-uk Kim yystack.p_mark -= yym; 686c5b5d71aSJung-uk Kim#endif 687c5b5d71aSJung-uk Kim 6880c8de5b0SBaptiste Daroussin yynewerrflag = 0; 6890c8de5b0SBaptiste Daroussinyyerrhandler: 6900c8de5b0SBaptiste Daroussin while (yyps->save) 6910c8de5b0SBaptiste Daroussin { 6920c8de5b0SBaptiste Daroussin int ctry; 6930c8de5b0SBaptiste Daroussin YYParseState *save = yyps->save; 6940c8de5b0SBaptiste Daroussin#if YYDEBUG 6950c8de5b0SBaptiste Daroussin if (yydebug) 6960c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: ERROR in state %d, CONFLICT BACKTRACKING to state %d, %d tokens\n", 6970c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyps->save->state, 6980c8de5b0SBaptiste Daroussin (int)(yylvp - yylvals - yyps->save->lexeme)); 6990c8de5b0SBaptiste Daroussin#endif 7000c8de5b0SBaptiste Daroussin /* Memorize most forward-looking error state in case it's really an error. */ 7010c8de5b0SBaptiste Daroussin if (yyerrctx == NULL || yyerrctx->lexeme < yylvp - yylvals) 7020c8de5b0SBaptiste Daroussin { 7030c8de5b0SBaptiste Daroussin /* Free old saved error context state */ 7040c8de5b0SBaptiste Daroussin if (yyerrctx) yyFreeState(yyerrctx); 7050c8de5b0SBaptiste Daroussin /* Create and fill out new saved error context state */ 7060c8de5b0SBaptiste Daroussin yyerrctx = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1)); 7070c8de5b0SBaptiste Daroussin if (yyerrctx == NULL) goto yyenomem; 7080c8de5b0SBaptiste Daroussin yyerrctx->save = yyps->save; 7090c8de5b0SBaptiste Daroussin yyerrctx->state = yystate; 7100c8de5b0SBaptiste Daroussin yyerrctx->errflag = yyerrflag; 7110c8de5b0SBaptiste Daroussin yyerrctx->yystack.s_mark = yyerrctx->yystack.s_base + (yystack.s_mark - yystack.s_base); 712c5b5d71aSJung-uk Kim memcpy (yyerrctx->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 7130c8de5b0SBaptiste Daroussin yyerrctx->yystack.l_mark = yyerrctx->yystack.l_base + (yystack.l_mark - yystack.l_base); 714c5b5d71aSJung-uk Kim memcpy (yyerrctx->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 7150c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7160c8de5b0SBaptiste Daroussin yyerrctx->yystack.p_mark = yyerrctx->yystack.p_base + (yystack.p_mark - yystack.p_base); 717c5b5d71aSJung-uk Kim memcpy (yyerrctx->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 7180c8de5b0SBaptiste Daroussin#endif 719c5b5d71aSJung-uk Kim yyerrctx->lexeme = (int) (yylvp - yylvals); 7200c8de5b0SBaptiste Daroussin } 7210c8de5b0SBaptiste Daroussin yylvp = yylvals + save->lexeme; 7220c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7230c8de5b0SBaptiste Daroussin yylpp = yylpsns + save->lexeme; 7240c8de5b0SBaptiste Daroussin#endif 7250c8de5b0SBaptiste Daroussin yylexp = yylexemes + save->lexeme; 7260c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 7270c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (save->yystack.s_mark - save->yystack.s_base); 728c5b5d71aSJung-uk Kim memcpy (yystack.s_base, save->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 7290c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (save->yystack.l_mark - save->yystack.l_base); 730c5b5d71aSJung-uk Kim memcpy (yystack.l_base, save->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 7310c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7320c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (save->yystack.p_mark - save->yystack.p_base); 733c5b5d71aSJung-uk Kim memcpy (yystack.p_base, save->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 7340c8de5b0SBaptiste Daroussin#endif 7350c8de5b0SBaptiste Daroussin ctry = ++save->ctry; 7360c8de5b0SBaptiste Daroussin yystate = save->state; 7370c8de5b0SBaptiste Daroussin /* We tried shift, try reduce now */ 7380c8de5b0SBaptiste Daroussin if ((yyn = yyctable[ctry]) >= 0) goto yyreduce; 7390c8de5b0SBaptiste Daroussin yyps->save = save->save; 7400c8de5b0SBaptiste Daroussin save->save = NULL; 7410c8de5b0SBaptiste Daroussin yyFreeState(save); 7420c8de5b0SBaptiste Daroussin 7430c8de5b0SBaptiste Daroussin /* Nothing left on the stack -- error */ 7440c8de5b0SBaptiste Daroussin if (!yyps->save) 7450c8de5b0SBaptiste Daroussin { 7460c8de5b0SBaptiste Daroussin#if YYDEBUG 7470c8de5b0SBaptiste Daroussin if (yydebug) 7480c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug[%d,trial]: trial parse FAILED, entering ERROR mode\n", 7490c8de5b0SBaptiste Daroussin YYPREFIX, yydepth); 7500c8de5b0SBaptiste Daroussin#endif 7510c8de5b0SBaptiste Daroussin /* Restore state as it was in the most forward-advanced error */ 7520c8de5b0SBaptiste Daroussin yylvp = yylvals + yyerrctx->lexeme; 7530c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7540c8de5b0SBaptiste Daroussin yylpp = yylpsns + yyerrctx->lexeme; 7550c8de5b0SBaptiste Daroussin#endif 7560c8de5b0SBaptiste Daroussin yylexp = yylexemes + yyerrctx->lexeme; 7570c8de5b0SBaptiste Daroussin yychar = yylexp[-1]; 7580c8de5b0SBaptiste Daroussin yylval = yylvp[-1]; 7590c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7600c8de5b0SBaptiste Daroussin yylloc = yylpp[-1]; 7610c8de5b0SBaptiste Daroussin#endif 7620c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (yyerrctx->yystack.s_mark - yyerrctx->yystack.s_base); 763c5b5d71aSJung-uk Kim memcpy (yystack.s_base, yyerrctx->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 7640c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (yyerrctx->yystack.l_mark - yyerrctx->yystack.l_base); 765c5b5d71aSJung-uk Kim memcpy (yystack.l_base, yyerrctx->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 7660c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7670c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (yyerrctx->yystack.p_mark - yyerrctx->yystack.p_base); 768c5b5d71aSJung-uk Kim memcpy (yystack.p_base, yyerrctx->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 7690c8de5b0SBaptiste Daroussin#endif 7700c8de5b0SBaptiste Daroussin yystate = yyerrctx->state; 7710c8de5b0SBaptiste Daroussin yyFreeState(yyerrctx); 7720c8de5b0SBaptiste Daroussin yyerrctx = NULL; 7730c8de5b0SBaptiste Daroussin } 7740c8de5b0SBaptiste Daroussin yynewerrflag = 1; 7750c8de5b0SBaptiste Daroussin } 7760c8de5b0SBaptiste Daroussin if (yynewerrflag == 0) goto yyinrecovery; 7770c8de5b0SBaptiste Daroussin%%endif YYBTYACC 7780c8de5b0SBaptiste Daroussin 7790c8de5b0SBaptiste Daroussin YYERROR_CALL("syntax error"); 7800c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 781b53bb29fSJung-uk Kim yyerror_loc_range[1] = yylloc; /* lookahead position is error start position */ 7820c8de5b0SBaptiste Daroussin#endif 7830c8de5b0SBaptiste Daroussin 7840c8de5b0SBaptiste Daroussin#if !YYBTYACC 785c5b5d71aSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */ 7860c8de5b0SBaptiste Daroussinyyerrlab: 7870c8de5b0SBaptiste Daroussin#endif 7880c8de5b0SBaptiste Daroussin ++yynerrs; 7890c8de5b0SBaptiste Daroussin 7900c8de5b0SBaptiste Daroussinyyinrecovery: 7910c8de5b0SBaptiste Daroussin if (yyerrflag < 3) 7920c8de5b0SBaptiste Daroussin { 7930c8de5b0SBaptiste Daroussin yyerrflag = 3; 7940c8de5b0SBaptiste Daroussin for (;;) 7950c8de5b0SBaptiste Daroussin { 7960c8de5b0SBaptiste Daroussin if (((yyn = yysindex[*yystack.s_mark]) != 0) && (yyn += YYERRCODE) >= 0 && 7970c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) YYERRCODE) 7980c8de5b0SBaptiste Daroussin { 7990c8de5b0SBaptiste Daroussin#if YYDEBUG 8000c8de5b0SBaptiste Daroussin if (yydebug) 8010c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, error recovery shifting to state %d\n", 8020c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, *yystack.s_mark, yytable[yyn]); 8030c8de5b0SBaptiste Daroussin#endif 8040c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 8050c8de5b0SBaptiste Daroussin yystate = yytable[yyn]; 8060c8de5b0SBaptiste Daroussin *++yystack.s_mark = yytable[yyn]; 8070c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval; 8080c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8090c8de5b0SBaptiste Daroussin /* lookahead position is error end position */ 810b53bb29fSJung-uk Kim yyerror_loc_range[2] = yylloc; 8110c8de5b0SBaptiste Daroussin YYLLOC_DEFAULT(yyloc, yyerror_loc_range, 2); /* position of error span */ 8120c8de5b0SBaptiste Daroussin *++yystack.p_mark = yyloc; 8130c8de5b0SBaptiste Daroussin#endif 8140c8de5b0SBaptiste Daroussin goto yyloop; 8150c8de5b0SBaptiste Daroussin } 8160c8de5b0SBaptiste Daroussin else 8170c8de5b0SBaptiste Daroussin { 8180c8de5b0SBaptiste Daroussin#if YYDEBUG 8190c8de5b0SBaptiste Daroussin if (yydebug) 8200c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: error recovery discarding state %d\n", 8210c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, *yystack.s_mark); 8220c8de5b0SBaptiste Daroussin#endif 8230c8de5b0SBaptiste Daroussin if (yystack.s_mark <= yystack.s_base) goto yyabort; 8240c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8250c8de5b0SBaptiste Daroussin /* the current TOS position is the error start position */ 826b53bb29fSJung-uk Kim yyerror_loc_range[1] = *yystack.p_mark; 8270c8de5b0SBaptiste Daroussin#endif 8280c8de5b0SBaptiste Daroussin#if defined(YYDESTRUCT_CALL) 8290c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 8300c8de5b0SBaptiste Daroussin if (!yytrial) 8310c8de5b0SBaptiste Daroussin%%endif 8320c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8330c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding state", 8340c8de5b0SBaptiste Daroussin yystos[*yystack.s_mark], yystack.l_mark, yystack.p_mark); 8350c8de5b0SBaptiste Daroussin#else 8360c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding state", 8370c8de5b0SBaptiste Daroussin yystos[*yystack.s_mark], yystack.l_mark); 8380c8de5b0SBaptiste Daroussin#endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 8390c8de5b0SBaptiste Daroussin#endif /* defined(YYDESTRUCT_CALL) */ 8400c8de5b0SBaptiste Daroussin --yystack.s_mark; 8410c8de5b0SBaptiste Daroussin --yystack.l_mark; 8420c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8430c8de5b0SBaptiste Daroussin --yystack.p_mark; 8440c8de5b0SBaptiste Daroussin#endif 8450c8de5b0SBaptiste Daroussin } 8460c8de5b0SBaptiste Daroussin } 8470c8de5b0SBaptiste Daroussin } 8480c8de5b0SBaptiste Daroussin else 8490c8de5b0SBaptiste Daroussin { 8500c8de5b0SBaptiste Daroussin if (yychar == YYEOF) goto yyabort; 8510c8de5b0SBaptiste Daroussin#if YYDEBUG 8520c8de5b0SBaptiste Daroussin if (yydebug) 8530c8de5b0SBaptiste Daroussin { 854c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 8550c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, error recovery discarding token %d (%s)\n", 8560c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yychar, yys); 8570c8de5b0SBaptiste Daroussin } 8580c8de5b0SBaptiste Daroussin#endif 8590c8de5b0SBaptiste Daroussin#if defined(YYDESTRUCT_CALL) 8600c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 8610c8de5b0SBaptiste Daroussin if (!yytrial) 8620c8de5b0SBaptiste Daroussin%%endif 8630c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8640c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding token", yychar, &yylval, &yylloc); 8650c8de5b0SBaptiste Daroussin#else 8660c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding token", yychar, &yylval); 8670c8de5b0SBaptiste Daroussin#endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 8680c8de5b0SBaptiste Daroussin#endif /* defined(YYDESTRUCT_CALL) */ 8690c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 8700c8de5b0SBaptiste Daroussin goto yyloop; 8710c8de5b0SBaptiste Daroussin } 8720c8de5b0SBaptiste Daroussin 8730c8de5b0SBaptiste Daroussinyyreduce: 8740c8de5b0SBaptiste Daroussin yym = yylen[yyn]; 8750c8de5b0SBaptiste Daroussin#if YYDEBUG 8760c8de5b0SBaptiste Daroussin if (yydebug) 8770c8de5b0SBaptiste Daroussin { 8780c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, reducing by rule %d (%s)", 8790c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyn, yyrule[yyn]); 8800c8de5b0SBaptiste Daroussin#ifdef YYSTYPE_TOSTRING 8810c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 8820c8de5b0SBaptiste Daroussin if (!yytrial) 8830c8de5b0SBaptiste Daroussin%%endif 8840c8de5b0SBaptiste Daroussin if (yym > 0) 8850c8de5b0SBaptiste Daroussin { 8860c8de5b0SBaptiste Daroussin int i; 8870c8de5b0SBaptiste Daroussin fputc('<', stderr); 8880c8de5b0SBaptiste Daroussin for (i = yym; i > 0; i--) 8890c8de5b0SBaptiste Daroussin { 8900c8de5b0SBaptiste Daroussin if (i != yym) fputs(", ", stderr); 8910c8de5b0SBaptiste Daroussin fputs(YYSTYPE_TOSTRING(yystos[yystack.s_mark[1-i]], 8920c8de5b0SBaptiste Daroussin yystack.l_mark[1-i]), stderr); 8930c8de5b0SBaptiste Daroussin } 8940c8de5b0SBaptiste Daroussin fputc('>', stderr); 8950c8de5b0SBaptiste Daroussin } 8960c8de5b0SBaptiste Daroussin#endif 8970c8de5b0SBaptiste Daroussin fputc('\n', stderr); 8980c8de5b0SBaptiste Daroussin } 8990c8de5b0SBaptiste Daroussin#endif 9000c8de5b0SBaptiste Daroussin if (yym > 0) 9010c8de5b0SBaptiste Daroussin yyval = yystack.l_mark[1-yym]; 9020c8de5b0SBaptiste Daroussin else 9030c8de5b0SBaptiste Daroussin memset(&yyval, 0, sizeof yyval); 9040c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9050c8de5b0SBaptiste Daroussin 9060c8de5b0SBaptiste Daroussin /* Perform position reduction */ 9070c8de5b0SBaptiste Daroussin memset(&yyloc, 0, sizeof(yyloc)); 9080c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 9090c8de5b0SBaptiste Daroussin if (!yytrial) 9100c8de5b0SBaptiste Daroussin%%endif 9110c8de5b0SBaptiste Daroussin { 912b53bb29fSJung-uk Kim YYLLOC_DEFAULT(yyloc, &yystack.p_mark[-yym], yym); 9130c8de5b0SBaptiste Daroussin /* just in case YYERROR is invoked within the action, save 9140c8de5b0SBaptiste Daroussin the start of the rhs as the error start position */ 915b53bb29fSJung-uk Kim yyerror_loc_range[1] = yystack.p_mark[1-yym]; 9160c8de5b0SBaptiste Daroussin } 9170c8de5b0SBaptiste Daroussin#endif 9180c8de5b0SBaptiste Daroussin 9190c8de5b0SBaptiste Daroussin switch (yyn) 9200c8de5b0SBaptiste Daroussin { 9210c8de5b0SBaptiste Daroussin%% trailer 9220c8de5b0SBaptiste Daroussin default: 9230c8de5b0SBaptiste Daroussin break; 9240c8de5b0SBaptiste Daroussin } 9250c8de5b0SBaptiste Daroussin yystack.s_mark -= yym; 9260c8de5b0SBaptiste Daroussin yystate = *yystack.s_mark; 9270c8de5b0SBaptiste Daroussin yystack.l_mark -= yym; 9280c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9290c8de5b0SBaptiste Daroussin yystack.p_mark -= yym; 9300c8de5b0SBaptiste Daroussin#endif 9310c8de5b0SBaptiste Daroussin yym = yylhs[yyn]; 9320c8de5b0SBaptiste Daroussin if (yystate == 0 && yym == 0) 9330c8de5b0SBaptiste Daroussin { 9340c8de5b0SBaptiste Daroussin#if YYDEBUG 9350c8de5b0SBaptiste Daroussin if (yydebug) 9360c8de5b0SBaptiste Daroussin { 9370c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: after reduction, ", YYDEBUGSTR, yydepth); 9380c8de5b0SBaptiste Daroussin#ifdef YYSTYPE_TOSTRING 9390c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 9400c8de5b0SBaptiste Daroussin if (!yytrial) 9410c8de5b0SBaptiste Daroussin%%endif 9420c8de5b0SBaptiste Daroussin fprintf(stderr, "result is <%s>, ", YYSTYPE_TOSTRING(yystos[YYFINAL], yyval)); 9430c8de5b0SBaptiste Daroussin#endif 9440c8de5b0SBaptiste Daroussin fprintf(stderr, "shifting from state 0 to final state %d\n", YYFINAL); 9450c8de5b0SBaptiste Daroussin } 9460c8de5b0SBaptiste Daroussin#endif 9470c8de5b0SBaptiste Daroussin yystate = YYFINAL; 9480c8de5b0SBaptiste Daroussin *++yystack.s_mark = YYFINAL; 9490c8de5b0SBaptiste Daroussin *++yystack.l_mark = yyval; 9500c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9510c8de5b0SBaptiste Daroussin *++yystack.p_mark = yyloc; 9520c8de5b0SBaptiste Daroussin#endif 9530c8de5b0SBaptiste Daroussin if (yychar < 0) 9540c8de5b0SBaptiste Daroussin { 9550c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 9560c8de5b0SBaptiste Daroussin do { 9570c8de5b0SBaptiste Daroussin if (yylvp < yylve) 9580c8de5b0SBaptiste Daroussin { 9590c8de5b0SBaptiste Daroussin /* we're currently re-reading tokens */ 9600c8de5b0SBaptiste Daroussin yylval = *yylvp++; 9610c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9620c8de5b0SBaptiste Daroussin yylloc = *yylpp++; 9630c8de5b0SBaptiste Daroussin#endif 9640c8de5b0SBaptiste Daroussin yychar = *yylexp++; 9650c8de5b0SBaptiste Daroussin break; 9660c8de5b0SBaptiste Daroussin } 9670c8de5b0SBaptiste Daroussin if (yyps->save) 9680c8de5b0SBaptiste Daroussin { 9690c8de5b0SBaptiste Daroussin /* in trial mode; save scanner results for future parse attempts */ 9700c8de5b0SBaptiste Daroussin if (yylvp == yylvlim) 9710c8de5b0SBaptiste Daroussin { /* Enlarge lexical value queue */ 972c5b5d71aSJung-uk Kim size_t p = (size_t) (yylvp - yylvals); 973c5b5d71aSJung-uk Kim size_t s = (size_t) (yylvlim - yylvals); 9740c8de5b0SBaptiste Daroussin 9750c8de5b0SBaptiste Daroussin s += YYLVQUEUEGROWTH; 976b53bb29fSJung-uk Kim if ((yylexemes = (YYINT *)realloc(yylexemes, s * sizeof(YYINT))) == NULL) 9770c8de5b0SBaptiste Daroussin goto yyenomem; 978b53bb29fSJung-uk Kim if ((yylvals = (YYSTYPE *)realloc(yylvals, s * sizeof(YYSTYPE))) == NULL) 9790c8de5b0SBaptiste Daroussin goto yyenomem; 9800c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 981b53bb29fSJung-uk Kim if ((yylpsns = (YYLTYPE *)realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL) 9820c8de5b0SBaptiste Daroussin goto yyenomem; 9830c8de5b0SBaptiste Daroussin#endif 9840c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals + p; 9850c8de5b0SBaptiste Daroussin yylvlim = yylvals + s; 9860c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9870c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns + p; 9880c8de5b0SBaptiste Daroussin yylplim = yylpsns + s; 9890c8de5b0SBaptiste Daroussin#endif 9900c8de5b0SBaptiste Daroussin yylexp = yylexemes + p; 9910c8de5b0SBaptiste Daroussin } 9922aca18c7SJung-uk Kim *yylexp = (YYINT) YYLEX; 9930c8de5b0SBaptiste Daroussin *yylvp++ = yylval; 9940c8de5b0SBaptiste Daroussin yylve++; 9950c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9960c8de5b0SBaptiste Daroussin *yylpp++ = yylloc; 9970c8de5b0SBaptiste Daroussin yylpe++; 9980c8de5b0SBaptiste Daroussin#endif 9990c8de5b0SBaptiste Daroussin yychar = *yylexp++; 10000c8de5b0SBaptiste Daroussin break; 10010c8de5b0SBaptiste Daroussin } 10020c8de5b0SBaptiste Daroussin /* normal operation, no conflict encountered */ 10030c8de5b0SBaptiste Daroussin%%endif YYBTYACC 10040c8de5b0SBaptiste Daroussin yychar = YYLEX; 10050c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 10060c8de5b0SBaptiste Daroussin } while (0); 10070c8de5b0SBaptiste Daroussin%%endif 10080c8de5b0SBaptiste Daroussin if (yychar < 0) yychar = YYEOF; 10090c8de5b0SBaptiste Daroussin#if YYDEBUG 10100c8de5b0SBaptiste Daroussin if (yydebug) 10110c8de5b0SBaptiste Daroussin { 1012c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 1013c5b5d71aSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)\n", 10140c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, YYFINAL, yychar, yys); 10150c8de5b0SBaptiste Daroussin } 10160c8de5b0SBaptiste Daroussin#endif 10170c8de5b0SBaptiste Daroussin } 10180c8de5b0SBaptiste Daroussin if (yychar == YYEOF) goto yyaccept; 10190c8de5b0SBaptiste Daroussin goto yyloop; 10200c8de5b0SBaptiste Daroussin } 10210c8de5b0SBaptiste Daroussin if (((yyn = yygindex[yym]) != 0) && (yyn += yystate) >= 0 && 10220c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yystate) 10230c8de5b0SBaptiste Daroussin yystate = yytable[yyn]; 10240c8de5b0SBaptiste Daroussin else 10250c8de5b0SBaptiste Daroussin yystate = yydgoto[yym]; 10260c8de5b0SBaptiste Daroussin#if YYDEBUG 10270c8de5b0SBaptiste Daroussin if (yydebug) 10280c8de5b0SBaptiste Daroussin { 10290c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: after reduction, ", YYDEBUGSTR, yydepth); 10300c8de5b0SBaptiste Daroussin#ifdef YYSTYPE_TOSTRING 10310c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 10320c8de5b0SBaptiste Daroussin if (!yytrial) 10330c8de5b0SBaptiste Daroussin%%endif 10340c8de5b0SBaptiste Daroussin fprintf(stderr, "result is <%s>, ", YYSTYPE_TOSTRING(yystos[yystate], yyval)); 10350c8de5b0SBaptiste Daroussin#endif 10360c8de5b0SBaptiste Daroussin fprintf(stderr, "shifting from state %d to state %d\n", *yystack.s_mark, yystate); 10370c8de5b0SBaptiste Daroussin } 10380c8de5b0SBaptiste Daroussin#endif 10390c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 1040c5b5d71aSJung-uk Kim *++yystack.s_mark = (YYINT) yystate; 10410c8de5b0SBaptiste Daroussin *++yystack.l_mark = yyval; 10420c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 10430c8de5b0SBaptiste Daroussin *++yystack.p_mark = yyloc; 10440c8de5b0SBaptiste Daroussin#endif 10450c8de5b0SBaptiste Daroussin goto yyloop; 10460c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 10470c8de5b0SBaptiste Daroussin 10480c8de5b0SBaptiste Daroussin /* Reduction declares that this path is valid. Set yypath and do a full parse */ 10490c8de5b0SBaptiste Daroussinyyvalid: 10500c8de5b0SBaptiste Daroussin if (yypath) YYABORT; 10510c8de5b0SBaptiste Daroussin while (yyps->save) 10520c8de5b0SBaptiste Daroussin { 10530c8de5b0SBaptiste Daroussin YYParseState *save = yyps->save; 10540c8de5b0SBaptiste Daroussin yyps->save = save->save; 10550c8de5b0SBaptiste Daroussin save->save = yypath; 10560c8de5b0SBaptiste Daroussin yypath = save; 10570c8de5b0SBaptiste Daroussin } 10580c8de5b0SBaptiste Daroussin#if YYDEBUG 10590c8de5b0SBaptiste Daroussin if (yydebug) 10600c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, CONFLICT trial successful, backtracking to state %d, %d tokens\n", 10610c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yypath->state, (int)(yylvp - yylvals - yypath->lexeme)); 10620c8de5b0SBaptiste Daroussin#endif 10630c8de5b0SBaptiste Daroussin if (yyerrctx) 10640c8de5b0SBaptiste Daroussin { 10650c8de5b0SBaptiste Daroussin yyFreeState(yyerrctx); 10660c8de5b0SBaptiste Daroussin yyerrctx = NULL; 10670c8de5b0SBaptiste Daroussin } 10680c8de5b0SBaptiste Daroussin yylvp = yylvals + yypath->lexeme; 10690c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 10700c8de5b0SBaptiste Daroussin yylpp = yylpsns + yypath->lexeme; 10710c8de5b0SBaptiste Daroussin#endif 10720c8de5b0SBaptiste Daroussin yylexp = yylexemes + yypath->lexeme; 10730c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 10740c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (yypath->yystack.s_mark - yypath->yystack.s_base); 1075c5b5d71aSJung-uk Kim memcpy (yystack.s_base, yypath->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 10760c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (yypath->yystack.l_mark - yypath->yystack.l_base); 1077c5b5d71aSJung-uk Kim memcpy (yystack.l_base, yypath->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 10780c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 10790c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (yypath->yystack.p_mark - yypath->yystack.p_base); 1080c5b5d71aSJung-uk Kim memcpy (yystack.p_base, yypath->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 10810c8de5b0SBaptiste Daroussin#endif 10820c8de5b0SBaptiste Daroussin yystate = yypath->state; 10830c8de5b0SBaptiste Daroussin goto yyloop; 10840c8de5b0SBaptiste Daroussin%%endif YYBTYACC 10850c8de5b0SBaptiste Daroussin 10860c8de5b0SBaptiste Daroussinyyoverflow: 10870c8de5b0SBaptiste Daroussin YYERROR_CALL("yacc stack overflow"); 10880c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 10890c8de5b0SBaptiste Daroussin goto yyabort_nomem; 10900c8de5b0SBaptiste Daroussinyyenomem: 10910c8de5b0SBaptiste Daroussin YYERROR_CALL("memory exhausted"); 10920c8de5b0SBaptiste Daroussinyyabort_nomem: 10930c8de5b0SBaptiste Daroussin%%endif 10940c8de5b0SBaptiste Daroussin yyresult = 2; 10950c8de5b0SBaptiste Daroussin goto yyreturn; 10960c8de5b0SBaptiste Daroussin 10970c8de5b0SBaptiste Daroussinyyabort: 10980c8de5b0SBaptiste Daroussin yyresult = 1; 10990c8de5b0SBaptiste Daroussin goto yyreturn; 11000c8de5b0SBaptiste Daroussin 11010c8de5b0SBaptiste Daroussinyyaccept: 11020c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 11030c8de5b0SBaptiste Daroussin if (yyps->save) goto yyvalid; 11040c8de5b0SBaptiste Daroussin%%endif 11050c8de5b0SBaptiste Daroussin yyresult = 0; 11060c8de5b0SBaptiste Daroussin 11070c8de5b0SBaptiste Daroussinyyreturn: 11080c8de5b0SBaptiste Daroussin#if defined(YYDESTRUCT_CALL) 11090c8de5b0SBaptiste Daroussin if (yychar != YYEOF && yychar != YYEMPTY) 11100c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 11110c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding token", yychar, &yylval, &yylloc); 11120c8de5b0SBaptiste Daroussin#else 11130c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding token", yychar, &yylval); 11140c8de5b0SBaptiste Daroussin#endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 11150c8de5b0SBaptiste Daroussin 11160c8de5b0SBaptiste Daroussin { 11170c8de5b0SBaptiste Daroussin YYSTYPE *pv; 11180c8de5b0SBaptiste Daroussin#if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 11190c8de5b0SBaptiste Daroussin YYLTYPE *pp; 11200c8de5b0SBaptiste Daroussin 11210c8de5b0SBaptiste Daroussin for (pv = yystack.l_base, pp = yystack.p_base; pv <= yystack.l_mark; ++pv, ++pp) 11220c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding state", 11230c8de5b0SBaptiste Daroussin yystos[*(yystack.s_base + (pv - yystack.l_base))], pv, pp); 11240c8de5b0SBaptiste Daroussin#else 11250c8de5b0SBaptiste Daroussin for (pv = yystack.l_base; pv <= yystack.l_mark; ++pv) 11260c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding state", 11270c8de5b0SBaptiste Daroussin yystos[*(yystack.s_base + (pv - yystack.l_base))], pv); 11280c8de5b0SBaptiste Daroussin#endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 11290c8de5b0SBaptiste Daroussin } 11300c8de5b0SBaptiste Daroussin#endif /* defined(YYDESTRUCT_CALL) */ 11310c8de5b0SBaptiste Daroussin 11320c8de5b0SBaptiste Daroussin%%ifdef YYBTYACC 11330c8de5b0SBaptiste Daroussin if (yyerrctx) 11340c8de5b0SBaptiste Daroussin { 11350c8de5b0SBaptiste Daroussin yyFreeState(yyerrctx); 11360c8de5b0SBaptiste Daroussin yyerrctx = NULL; 11370c8de5b0SBaptiste Daroussin } 11380c8de5b0SBaptiste Daroussin while (yyps) 11390c8de5b0SBaptiste Daroussin { 11400c8de5b0SBaptiste Daroussin YYParseState *save = yyps; 11410c8de5b0SBaptiste Daroussin yyps = save->save; 11420c8de5b0SBaptiste Daroussin save->save = NULL; 11430c8de5b0SBaptiste Daroussin yyFreeState(save); 11440c8de5b0SBaptiste Daroussin } 11450c8de5b0SBaptiste Daroussin while (yypath) 11460c8de5b0SBaptiste Daroussin { 11470c8de5b0SBaptiste Daroussin YYParseState *save = yypath; 11480c8de5b0SBaptiste Daroussin yypath = save->save; 11490c8de5b0SBaptiste Daroussin save->save = NULL; 11500c8de5b0SBaptiste Daroussin yyFreeState(save); 11510c8de5b0SBaptiste Daroussin } 11520c8de5b0SBaptiste Daroussin%%endif YYBTYACC 11530c8de5b0SBaptiste Daroussin yyfreestack(&yystack); 11540c8de5b0SBaptiste Daroussin return (yyresult); 11550c8de5b0SBaptiste Daroussin} 1156