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 60c8de5b0SBaptiste Daroussin #define YYMAJOR 1 70c8de5b0SBaptiste Daroussin #define YYMINOR 9 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 inherit1_parse 220c8de5b0SBaptiste Daroussin #endif /* yyparse */ 230c8de5b0SBaptiste Daroussin 240c8de5b0SBaptiste Daroussin #ifndef yylex 250c8de5b0SBaptiste Daroussin #define yylex inherit1_lex 260c8de5b0SBaptiste Daroussin #endif /* yylex */ 270c8de5b0SBaptiste Daroussin 280c8de5b0SBaptiste Daroussin #ifndef yyerror 290c8de5b0SBaptiste Daroussin #define yyerror inherit1_error 300c8de5b0SBaptiste Daroussin #endif /* yyerror */ 310c8de5b0SBaptiste Daroussin 320c8de5b0SBaptiste Daroussin #ifndef yychar 330c8de5b0SBaptiste Daroussin #define yychar inherit1_char 340c8de5b0SBaptiste Daroussin #endif /* yychar */ 350c8de5b0SBaptiste Daroussin 360c8de5b0SBaptiste Daroussin #ifndef yyval 370c8de5b0SBaptiste Daroussin #define yyval inherit1_val 380c8de5b0SBaptiste Daroussin #endif /* yyval */ 390c8de5b0SBaptiste Daroussin 400c8de5b0SBaptiste Daroussin #ifndef yylval 410c8de5b0SBaptiste Daroussin #define yylval inherit1_lval 420c8de5b0SBaptiste Daroussin #endif /* yylval */ 430c8de5b0SBaptiste Daroussin 440c8de5b0SBaptiste Daroussin #ifndef yydebug 450c8de5b0SBaptiste Daroussin #define yydebug inherit1_debug 460c8de5b0SBaptiste Daroussin #endif /* yydebug */ 470c8de5b0SBaptiste Daroussin 480c8de5b0SBaptiste Daroussin #ifndef yynerrs 490c8de5b0SBaptiste Daroussin #define yynerrs inherit1_nerrs 500c8de5b0SBaptiste Daroussin #endif /* yynerrs */ 510c8de5b0SBaptiste Daroussin 520c8de5b0SBaptiste Daroussin #ifndef yyerrflag 530c8de5b0SBaptiste Daroussin #define yyerrflag inherit1_errflag 540c8de5b0SBaptiste Daroussin #endif /* yyerrflag */ 550c8de5b0SBaptiste Daroussin 560c8de5b0SBaptiste Daroussin #ifndef yylhs 570c8de5b0SBaptiste Daroussin #define yylhs inherit1_lhs 580c8de5b0SBaptiste Daroussin #endif /* yylhs */ 590c8de5b0SBaptiste Daroussin 600c8de5b0SBaptiste Daroussin #ifndef yylen 610c8de5b0SBaptiste Daroussin #define yylen inherit1_len 620c8de5b0SBaptiste Daroussin #endif /* yylen */ 630c8de5b0SBaptiste Daroussin 640c8de5b0SBaptiste Daroussin #ifndef yydefred 650c8de5b0SBaptiste Daroussin #define yydefred inherit1_defred 660c8de5b0SBaptiste Daroussin #endif /* yydefred */ 670c8de5b0SBaptiste Daroussin 680c8de5b0SBaptiste Daroussin #ifndef yystos 690c8de5b0SBaptiste Daroussin #define yystos inherit1_stos 700c8de5b0SBaptiste Daroussin #endif /* yystos */ 710c8de5b0SBaptiste Daroussin 720c8de5b0SBaptiste Daroussin #ifndef yydgoto 730c8de5b0SBaptiste Daroussin #define yydgoto inherit1_dgoto 740c8de5b0SBaptiste Daroussin #endif /* yydgoto */ 750c8de5b0SBaptiste Daroussin 760c8de5b0SBaptiste Daroussin #ifndef yysindex 770c8de5b0SBaptiste Daroussin #define yysindex inherit1_sindex 780c8de5b0SBaptiste Daroussin #endif /* yysindex */ 790c8de5b0SBaptiste Daroussin 800c8de5b0SBaptiste Daroussin #ifndef yyrindex 810c8de5b0SBaptiste Daroussin #define yyrindex inherit1_rindex 820c8de5b0SBaptiste Daroussin #endif /* yyrindex */ 830c8de5b0SBaptiste Daroussin 840c8de5b0SBaptiste Daroussin #ifndef yygindex 850c8de5b0SBaptiste Daroussin #define yygindex inherit1_gindex 860c8de5b0SBaptiste Daroussin #endif /* yygindex */ 870c8de5b0SBaptiste Daroussin 880c8de5b0SBaptiste Daroussin #ifndef yytable 890c8de5b0SBaptiste Daroussin #define yytable inherit1_table 900c8de5b0SBaptiste Daroussin #endif /* yytable */ 910c8de5b0SBaptiste Daroussin 920c8de5b0SBaptiste Daroussin #ifndef yycheck 930c8de5b0SBaptiste Daroussin #define yycheck inherit1_check 940c8de5b0SBaptiste Daroussin #endif /* yycheck */ 950c8de5b0SBaptiste Daroussin 960c8de5b0SBaptiste Daroussin #ifndef yyname 970c8de5b0SBaptiste Daroussin #define yyname inherit1_name 980c8de5b0SBaptiste Daroussin #endif /* yyname */ 990c8de5b0SBaptiste Daroussin 1000c8de5b0SBaptiste Daroussin #ifndef yyrule 1010c8de5b0SBaptiste Daroussin #define yyrule inherit1_rule 1020c8de5b0SBaptiste Daroussin #endif /* yyrule */ 1030c8de5b0SBaptiste Daroussin 1040c8de5b0SBaptiste Daroussin #if YYBTYACC 1050c8de5b0SBaptiste Daroussin 1060c8de5b0SBaptiste Daroussin #ifndef yycindex 1070c8de5b0SBaptiste Daroussin #define yycindex inherit1_cindex 1080c8de5b0SBaptiste Daroussin #endif /* yycindex */ 1090c8de5b0SBaptiste Daroussin 1100c8de5b0SBaptiste Daroussin #ifndef yyctable 1110c8de5b0SBaptiste Daroussin #define yyctable inherit1_ctable 1120c8de5b0SBaptiste Daroussin #endif /* yyctable */ 1130c8de5b0SBaptiste Daroussin 1140c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 1150c8de5b0SBaptiste Daroussin 1160c8de5b0SBaptiste Daroussin #define YYPREFIX "inherit1_" 1170c8de5b0SBaptiste Daroussin 1180c8de5b0SBaptiste Daroussin #define YYPURE 0 1190c8de5b0SBaptiste Daroussin 1200c8de5b0SBaptiste Daroussin #line 2 "inherit1.y" 1210c8de5b0SBaptiste Daroussin #include <stdlib.h> 1220c8de5b0SBaptiste Daroussin 1230c8de5b0SBaptiste Daroussin typedef enum {cGLOBAL, cLOCAL} class; 1240c8de5b0SBaptiste Daroussin typedef enum {tREAL, tINTEGER} type; 1250c8de5b0SBaptiste Daroussin typedef char * name; 1260c8de5b0SBaptiste Daroussin 1270c8de5b0SBaptiste Daroussin struct symbol { class c; type t; name id; }; 1280c8de5b0SBaptiste Daroussin typedef struct symbol symbol; 1290c8de5b0SBaptiste Daroussin 1300c8de5b0SBaptiste Daroussin struct namelist { symbol *s; struct namelist *next; }; 1310c8de5b0SBaptiste Daroussin typedef struct namelist namelist; 1320c8de5b0SBaptiste Daroussin 1330c8de5b0SBaptiste Daroussin extern symbol *mksymbol(type t, class c, name id); 1340c8de5b0SBaptiste Daroussin 1350c8de5b0SBaptiste Daroussin #ifdef YYBISON 1360c8de5b0SBaptiste Daroussin #define YYLEX_DECL() yylex(void) 1370c8de5b0SBaptiste Daroussin #define YYERROR_DECL() yyerror(const char *s) 1380c8de5b0SBaptiste Daroussin extern int YYLEX_DECL(); 1390c8de5b0SBaptiste Daroussin extern void YYERROR_DECL(); 1400c8de5b0SBaptiste Daroussin #endif 1410c8de5b0SBaptiste Daroussin #ifdef YYSTYPE 1420c8de5b0SBaptiste Daroussin #undef YYSTYPE_IS_DECLARED 1430c8de5b0SBaptiste Daroussin #define YYSTYPE_IS_DECLARED 1 1440c8de5b0SBaptiste Daroussin #endif 1450c8de5b0SBaptiste Daroussin #ifndef YYSTYPE_IS_DECLARED 1460c8de5b0SBaptiste Daroussin #define YYSTYPE_IS_DECLARED 1 147c5b5d71aSJung-uk Kim #line 32 "inherit1.y" 1480c8de5b0SBaptiste Daroussin typedef union 1490c8de5b0SBaptiste Daroussin { 1500c8de5b0SBaptiste Daroussin class cval; 1510c8de5b0SBaptiste Daroussin type tval; 1520c8de5b0SBaptiste Daroussin namelist * nlist; 1530c8de5b0SBaptiste Daroussin name id; 1540c8de5b0SBaptiste Daroussin } YYSTYPE; 1550c8de5b0SBaptiste Daroussin #endif /* !YYSTYPE_IS_DECLARED */ 1560c8de5b0SBaptiste Daroussin #line 157 "inherit1.tab.c" 1570c8de5b0SBaptiste Daroussin 1580c8de5b0SBaptiste Daroussin /* compatibility with bison */ 1590c8de5b0SBaptiste Daroussin #ifdef YYPARSE_PARAM 1600c8de5b0SBaptiste Daroussin /* compatibility with FreeBSD */ 1610c8de5b0SBaptiste Daroussin # ifdef YYPARSE_PARAM_TYPE 1620c8de5b0SBaptiste Daroussin # define YYPARSE_DECL() yyparse(YYPARSE_PARAM_TYPE YYPARSE_PARAM) 1630c8de5b0SBaptiste Daroussin # else 1640c8de5b0SBaptiste Daroussin # define YYPARSE_DECL() yyparse(void *YYPARSE_PARAM) 1650c8de5b0SBaptiste Daroussin # endif 1660c8de5b0SBaptiste Daroussin #else 1670c8de5b0SBaptiste Daroussin # define YYPARSE_DECL() yyparse(void) 1680c8de5b0SBaptiste Daroussin #endif 1690c8de5b0SBaptiste Daroussin 1700c8de5b0SBaptiste Daroussin /* Parameters sent to lex. */ 1710c8de5b0SBaptiste Daroussin #ifdef YYLEX_PARAM 1720c8de5b0SBaptiste Daroussin # define YYLEX_DECL() yylex(void *YYLEX_PARAM) 1730c8de5b0SBaptiste Daroussin # define YYLEX yylex(YYLEX_PARAM) 1740c8de5b0SBaptiste Daroussin #else 1750c8de5b0SBaptiste Daroussin # define YYLEX_DECL() yylex(void) 1760c8de5b0SBaptiste Daroussin # define YYLEX yylex() 1770c8de5b0SBaptiste Daroussin #endif 1780c8de5b0SBaptiste Daroussin 1790c8de5b0SBaptiste Daroussin /* Parameters sent to yyerror. */ 1800c8de5b0SBaptiste Daroussin #ifndef YYERROR_DECL 1810c8de5b0SBaptiste Daroussin #define YYERROR_DECL() yyerror(const char *s) 1820c8de5b0SBaptiste Daroussin #endif 1830c8de5b0SBaptiste Daroussin #ifndef YYERROR_CALL 1840c8de5b0SBaptiste Daroussin #define YYERROR_CALL(msg) yyerror(msg) 1850c8de5b0SBaptiste Daroussin #endif 1860c8de5b0SBaptiste Daroussin 1870c8de5b0SBaptiste Daroussin extern int YYPARSE_DECL(); 1880c8de5b0SBaptiste Daroussin 1890c8de5b0SBaptiste Daroussin #define GLOBAL 257 1900c8de5b0SBaptiste Daroussin #define LOCAL 258 1910c8de5b0SBaptiste Daroussin #define REAL 259 1920c8de5b0SBaptiste Daroussin #define INTEGER 260 1930c8de5b0SBaptiste Daroussin #define NAME 261 1940c8de5b0SBaptiste Daroussin #define YYERRCODE 256 1950c8de5b0SBaptiste Daroussin typedef short YYINT; 1960c8de5b0SBaptiste Daroussin static const YYINT inherit1_lhs[] = { -1, 1970c8de5b0SBaptiste Daroussin 0, 0, 3, 3, 4, 4, 1, 1, 5, 6, 1980c8de5b0SBaptiste Daroussin 2, 1990c8de5b0SBaptiste Daroussin }; 2000c8de5b0SBaptiste Daroussin static const YYINT inherit1_len[] = { 2, 2010c8de5b0SBaptiste Daroussin 3, 2, 1, 1, 1, 1, 2, 1, 0, 0, 2020c8de5b0SBaptiste Daroussin 3, 2030c8de5b0SBaptiste Daroussin }; 2040c8de5b0SBaptiste Daroussin static const YYINT inherit1_defred[] = { 0, 2050c8de5b0SBaptiste Daroussin 3, 4, 5, 6, 0, 0, 9, 0, 2, 10, 2060c8de5b0SBaptiste Daroussin 8, 0, 0, 7, 0, 2070c8de5b0SBaptiste Daroussin }; 208*2aca18c7SJung-uk Kim #if defined(YYDESTRUCT_CALL) || defined(YYSTYPE_TOSTRING) 2090c8de5b0SBaptiste Daroussin static const YYINT inherit1_stos[] = { 0, 2100c8de5b0SBaptiste Daroussin 257, 258, 259, 260, 263, 266, 267, 267, 265, 268, 2110c8de5b0SBaptiste Daroussin 261, 264, 269, 261, 264, 2120c8de5b0SBaptiste Daroussin }; 213*2aca18c7SJung-uk Kim #endif /* YYDESTRUCT_CALL || YYSTYPE_TOSTRING */ 2140c8de5b0SBaptiste Daroussin static const YYINT inherit1_dgoto[] = { 5, 2150c8de5b0SBaptiste Daroussin 12, 9, 6, 7, 10, 13, 2160c8de5b0SBaptiste Daroussin }; 2170c8de5b0SBaptiste Daroussin static const YYINT inherit1_sindex[] = { -257, 2180c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, -255, 0, -254, 0, 0, 2190c8de5b0SBaptiste Daroussin 0, -253, -254, 0, -253, 2200c8de5b0SBaptiste Daroussin }; 2210c8de5b0SBaptiste Daroussin static const YYINT inherit1_rindex[] = { 0, 2220c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2230c8de5b0SBaptiste Daroussin 0, 6, 0, 0, 9, 2240c8de5b0SBaptiste Daroussin }; 2250c8de5b0SBaptiste Daroussin #if YYBTYACC 2260c8de5b0SBaptiste Daroussin static const YYINT inherit1_cindex[] = { 0, 2270c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2280c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 2290c8de5b0SBaptiste Daroussin }; 2300c8de5b0SBaptiste Daroussin #endif 2310c8de5b0SBaptiste Daroussin static const YYINT inherit1_gindex[] = { 0, 2320c8de5b0SBaptiste Daroussin -3, 0, 0, 5, 0, 0, 2330c8de5b0SBaptiste Daroussin }; 2340c8de5b0SBaptiste Daroussin #define YYTABLESIZE 11 2350c8de5b0SBaptiste Daroussin static const YYINT inherit1_table[] = { 1, 2360c8de5b0SBaptiste Daroussin 2, 3, 4, 3, 4, 1, 11, 14, 11, 15, 2370c8de5b0SBaptiste Daroussin 8, 2380c8de5b0SBaptiste Daroussin }; 2390c8de5b0SBaptiste Daroussin static const YYINT inherit1_check[] = { 257, 2400c8de5b0SBaptiste Daroussin 258, 259, 260, 259, 260, 0, 261, 261, 0, 13, 2410c8de5b0SBaptiste Daroussin 6, 2420c8de5b0SBaptiste Daroussin }; 24311fce282SBaptiste Daroussin #if YYBTYACC 24411fce282SBaptiste Daroussin static const YYINT inherit1_ctable[] = { -1, 24511fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 24611fce282SBaptiste Daroussin }; 24711fce282SBaptiste Daroussin #endif 2480c8de5b0SBaptiste Daroussin #define YYFINAL 5 2490c8de5b0SBaptiste Daroussin #ifndef YYDEBUG 2500c8de5b0SBaptiste Daroussin #define YYDEBUG 0 2510c8de5b0SBaptiste Daroussin #endif 2520c8de5b0SBaptiste Daroussin #define YYMAXTOKEN 261 2530c8de5b0SBaptiste Daroussin #define YYUNDFTOKEN 270 2540c8de5b0SBaptiste Daroussin #define YYTRANSLATE(a) ((a) > YYMAXTOKEN ? YYUNDFTOKEN : (a)) 2550c8de5b0SBaptiste Daroussin #if YYDEBUG 2560c8de5b0SBaptiste Daroussin static const char *const inherit1_name[] = { 2570c8de5b0SBaptiste Daroussin 2580c8de5b0SBaptiste Daroussin "$end",0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 2590c8de5b0SBaptiste Daroussin 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 2600c8de5b0SBaptiste Daroussin 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 2610c8de5b0SBaptiste Daroussin 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 2620c8de5b0SBaptiste Daroussin 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 2630c8de5b0SBaptiste Daroussin 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 2640c8de5b0SBaptiste Daroussin 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,"error","GLOBAL","LOCAL","REAL","INTEGER", 2650c8de5b0SBaptiste Daroussin "NAME","$accept","declaration","namelist","locnamelist","class","type","$$1", 2660c8de5b0SBaptiste Daroussin "$$2","illegal-symbol", 2670c8de5b0SBaptiste Daroussin }; 2680c8de5b0SBaptiste Daroussin static const char *const inherit1_rule[] = { 2690c8de5b0SBaptiste Daroussin "$accept : declaration", 2700c8de5b0SBaptiste Daroussin "declaration : class type namelist", 2710c8de5b0SBaptiste Daroussin "declaration : type locnamelist", 2720c8de5b0SBaptiste Daroussin "class : GLOBAL", 2730c8de5b0SBaptiste Daroussin "class : LOCAL", 2740c8de5b0SBaptiste Daroussin "type : REAL", 2750c8de5b0SBaptiste Daroussin "type : INTEGER", 2760c8de5b0SBaptiste Daroussin "namelist : namelist NAME", 2770c8de5b0SBaptiste Daroussin "namelist : NAME", 2780c8de5b0SBaptiste Daroussin "$$1 :", 2790c8de5b0SBaptiste Daroussin "$$2 :", 2800c8de5b0SBaptiste Daroussin "locnamelist : $$1 $$2 namelist", 2810c8de5b0SBaptiste Daroussin 2820c8de5b0SBaptiste Daroussin }; 2830c8de5b0SBaptiste Daroussin #endif 2840c8de5b0SBaptiste Daroussin 2850c8de5b0SBaptiste Daroussin int yydebug; 2860c8de5b0SBaptiste Daroussin int yynerrs; 2870c8de5b0SBaptiste Daroussin 2880c8de5b0SBaptiste Daroussin int yyerrflag; 2890c8de5b0SBaptiste Daroussin int yychar; 2900c8de5b0SBaptiste Daroussin YYSTYPE yyval; 2910c8de5b0SBaptiste Daroussin YYSTYPE yylval; 2920c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 2930c8de5b0SBaptiste Daroussin YYLTYPE yyloc; /* position returned by actions */ 2940c8de5b0SBaptiste Daroussin YYLTYPE yylloc; /* position from the lexer */ 2950c8de5b0SBaptiste Daroussin #endif 2960c8de5b0SBaptiste Daroussin 2970c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 2980c8de5b0SBaptiste Daroussin #ifndef YYLLOC_DEFAULT 2990c8de5b0SBaptiste Daroussin #define YYLLOC_DEFAULT(loc, rhs, n) \ 3000c8de5b0SBaptiste Daroussin do \ 3010c8de5b0SBaptiste Daroussin { \ 3020c8de5b0SBaptiste Daroussin if (n == 0) \ 3030c8de5b0SBaptiste Daroussin { \ 3040c8de5b0SBaptiste Daroussin (loc).first_line = ((rhs)[-1]).last_line; \ 3050c8de5b0SBaptiste Daroussin (loc).first_column = ((rhs)[-1]).last_column; \ 3060c8de5b0SBaptiste Daroussin (loc).last_line = ((rhs)[-1]).last_line; \ 3070c8de5b0SBaptiste Daroussin (loc).last_column = ((rhs)[-1]).last_column; \ 3080c8de5b0SBaptiste Daroussin } \ 3090c8de5b0SBaptiste Daroussin else \ 3100c8de5b0SBaptiste Daroussin { \ 3110c8de5b0SBaptiste Daroussin (loc).first_line = ((rhs)[ 0 ]).first_line; \ 3120c8de5b0SBaptiste Daroussin (loc).first_column = ((rhs)[ 0 ]).first_column; \ 3130c8de5b0SBaptiste Daroussin (loc).last_line = ((rhs)[n-1]).last_line; \ 3140c8de5b0SBaptiste Daroussin (loc).last_column = ((rhs)[n-1]).last_column; \ 3150c8de5b0SBaptiste Daroussin } \ 3160c8de5b0SBaptiste Daroussin } while (0) 3170c8de5b0SBaptiste Daroussin #endif /* YYLLOC_DEFAULT */ 3180c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 3190c8de5b0SBaptiste Daroussin #if YYBTYACC 3200c8de5b0SBaptiste Daroussin 3210c8de5b0SBaptiste Daroussin #ifndef YYLVQUEUEGROWTH 3220c8de5b0SBaptiste Daroussin #define YYLVQUEUEGROWTH 32 3230c8de5b0SBaptiste Daroussin #endif 3240c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 3250c8de5b0SBaptiste Daroussin 3260c8de5b0SBaptiste Daroussin /* define the initial stack-sizes */ 3270c8de5b0SBaptiste Daroussin #ifdef YYSTACKSIZE 3280c8de5b0SBaptiste Daroussin #undef YYMAXDEPTH 3290c8de5b0SBaptiste Daroussin #define YYMAXDEPTH YYSTACKSIZE 3300c8de5b0SBaptiste Daroussin #else 3310c8de5b0SBaptiste Daroussin #ifdef YYMAXDEPTH 3320c8de5b0SBaptiste Daroussin #define YYSTACKSIZE YYMAXDEPTH 3330c8de5b0SBaptiste Daroussin #else 3340c8de5b0SBaptiste Daroussin #define YYSTACKSIZE 10000 3350c8de5b0SBaptiste Daroussin #define YYMAXDEPTH 10000 3360c8de5b0SBaptiste Daroussin #endif 3370c8de5b0SBaptiste Daroussin #endif 3380c8de5b0SBaptiste Daroussin 3390c8de5b0SBaptiste Daroussin #ifndef YYINITSTACKSIZE 3400c8de5b0SBaptiste Daroussin #define YYINITSTACKSIZE 200 3410c8de5b0SBaptiste Daroussin #endif 3420c8de5b0SBaptiste Daroussin 3430c8de5b0SBaptiste Daroussin typedef struct { 3440c8de5b0SBaptiste Daroussin unsigned stacksize; 345c5b5d71aSJung-uk Kim YYINT *s_base; 346c5b5d71aSJung-uk Kim YYINT *s_mark; 347c5b5d71aSJung-uk Kim YYINT *s_last; 3480c8de5b0SBaptiste Daroussin YYSTYPE *l_base; 3490c8de5b0SBaptiste Daroussin YYSTYPE *l_mark; 3500c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 3510c8de5b0SBaptiste Daroussin YYLTYPE *p_base; 3520c8de5b0SBaptiste Daroussin YYLTYPE *p_mark; 3530c8de5b0SBaptiste Daroussin #endif 3540c8de5b0SBaptiste Daroussin } YYSTACKDATA; 3550c8de5b0SBaptiste Daroussin #if YYBTYACC 3560c8de5b0SBaptiste Daroussin 3570c8de5b0SBaptiste Daroussin struct YYParseState_s 3580c8de5b0SBaptiste Daroussin { 3590c8de5b0SBaptiste Daroussin struct YYParseState_s *save; /* Previously saved parser state */ 3600c8de5b0SBaptiste Daroussin YYSTACKDATA yystack; /* saved parser stack */ 3610c8de5b0SBaptiste Daroussin int state; /* saved parser state */ 3620c8de5b0SBaptiste Daroussin int errflag; /* saved error recovery status */ 3630c8de5b0SBaptiste Daroussin int lexeme; /* saved index of the conflict lexeme in the lexical queue */ 3640c8de5b0SBaptiste Daroussin YYINT ctry; /* saved index in yyctable[] for this conflict */ 3650c8de5b0SBaptiste Daroussin }; 3660c8de5b0SBaptiste Daroussin typedef struct YYParseState_s YYParseState; 3670c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 3680c8de5b0SBaptiste Daroussin /* variables for the parser stack */ 3690c8de5b0SBaptiste Daroussin static YYSTACKDATA yystack; 3700c8de5b0SBaptiste Daroussin #if YYBTYACC 3710c8de5b0SBaptiste Daroussin 3720c8de5b0SBaptiste Daroussin /* Current parser state */ 3730c8de5b0SBaptiste Daroussin static YYParseState *yyps = 0; 3740c8de5b0SBaptiste Daroussin 3750c8de5b0SBaptiste Daroussin /* yypath != NULL: do the full parse, starting at *yypath parser state. */ 3760c8de5b0SBaptiste Daroussin static YYParseState *yypath = 0; 3770c8de5b0SBaptiste Daroussin 3780c8de5b0SBaptiste Daroussin /* Base of the lexical value queue */ 3790c8de5b0SBaptiste Daroussin static YYSTYPE *yylvals = 0; 3800c8de5b0SBaptiste Daroussin 3810c8de5b0SBaptiste Daroussin /* Current position at lexical value queue */ 3820c8de5b0SBaptiste Daroussin static YYSTYPE *yylvp = 0; 3830c8de5b0SBaptiste Daroussin 3840c8de5b0SBaptiste Daroussin /* End position of lexical value queue */ 3850c8de5b0SBaptiste Daroussin static YYSTYPE *yylve = 0; 3860c8de5b0SBaptiste Daroussin 3870c8de5b0SBaptiste Daroussin /* The last allocated position at the lexical value queue */ 3880c8de5b0SBaptiste Daroussin static YYSTYPE *yylvlim = 0; 3890c8de5b0SBaptiste Daroussin 3900c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 3910c8de5b0SBaptiste Daroussin /* Base of the lexical position queue */ 3920c8de5b0SBaptiste Daroussin static YYLTYPE *yylpsns = 0; 3930c8de5b0SBaptiste Daroussin 3940c8de5b0SBaptiste Daroussin /* Current position at lexical position queue */ 3950c8de5b0SBaptiste Daroussin static YYLTYPE *yylpp = 0; 3960c8de5b0SBaptiste Daroussin 3970c8de5b0SBaptiste Daroussin /* End position of lexical position queue */ 3980c8de5b0SBaptiste Daroussin static YYLTYPE *yylpe = 0; 3990c8de5b0SBaptiste Daroussin 4000c8de5b0SBaptiste Daroussin /* The last allocated position at the lexical position queue */ 4010c8de5b0SBaptiste Daroussin static YYLTYPE *yylplim = 0; 4020c8de5b0SBaptiste Daroussin #endif 4030c8de5b0SBaptiste Daroussin 4040c8de5b0SBaptiste Daroussin /* Current position at lexical token queue */ 405*2aca18c7SJung-uk Kim static YYINT *yylexp = 0; 4060c8de5b0SBaptiste Daroussin 407*2aca18c7SJung-uk Kim static YYINT *yylexemes = 0; 4080c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 4090c8de5b0SBaptiste Daroussin #line 74 "inherit1.y" 4100c8de5b0SBaptiste Daroussin 4110c8de5b0SBaptiste Daroussin extern int YYLEX_DECL(); 4120c8de5b0SBaptiste Daroussin extern void YYERROR_DECL(); 413*2aca18c7SJung-uk Kim #line 414 "inherit1.tab.c" 4140c8de5b0SBaptiste Daroussin 4150c8de5b0SBaptiste Daroussin /* For use in generated program */ 4160c8de5b0SBaptiste Daroussin #define yydepth (int)(yystack.s_mark - yystack.s_base) 4170c8de5b0SBaptiste Daroussin #if YYBTYACC 4180c8de5b0SBaptiste Daroussin #define yytrial (yyps->save) 4190c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 4200c8de5b0SBaptiste Daroussin 4210c8de5b0SBaptiste Daroussin #if YYDEBUG 4220c8de5b0SBaptiste Daroussin #include <stdio.h> /* needed for printf */ 4230c8de5b0SBaptiste Daroussin #endif 4240c8de5b0SBaptiste Daroussin 4250c8de5b0SBaptiste Daroussin #include <stdlib.h> /* needed for malloc, etc */ 4260c8de5b0SBaptiste Daroussin #include <string.h> /* needed for memset */ 4270c8de5b0SBaptiste Daroussin 4280c8de5b0SBaptiste Daroussin /* allocate initial stack or double stack size, up to YYMAXDEPTH */ 4290c8de5b0SBaptiste Daroussin static int yygrowstack(YYSTACKDATA *data) 4300c8de5b0SBaptiste Daroussin { 4310c8de5b0SBaptiste Daroussin int i; 4320c8de5b0SBaptiste Daroussin unsigned newsize; 433c5b5d71aSJung-uk Kim YYINT *newss; 4340c8de5b0SBaptiste Daroussin YYSTYPE *newvs; 4350c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 4360c8de5b0SBaptiste Daroussin YYLTYPE *newps; 4370c8de5b0SBaptiste Daroussin #endif 4380c8de5b0SBaptiste Daroussin 4390c8de5b0SBaptiste Daroussin if ((newsize = data->stacksize) == 0) 4400c8de5b0SBaptiste Daroussin newsize = YYINITSTACKSIZE; 4410c8de5b0SBaptiste Daroussin else if (newsize >= YYMAXDEPTH) 4420c8de5b0SBaptiste Daroussin return YYENOMEM; 4430c8de5b0SBaptiste Daroussin else if ((newsize *= 2) > YYMAXDEPTH) 4440c8de5b0SBaptiste Daroussin newsize = YYMAXDEPTH; 4450c8de5b0SBaptiste Daroussin 4460c8de5b0SBaptiste Daroussin i = (int) (data->s_mark - data->s_base); 447c5b5d71aSJung-uk Kim newss = (YYINT *)realloc(data->s_base, newsize * sizeof(*newss)); 4480c8de5b0SBaptiste Daroussin if (newss == 0) 4490c8de5b0SBaptiste Daroussin return YYENOMEM; 4500c8de5b0SBaptiste Daroussin 4510c8de5b0SBaptiste Daroussin data->s_base = newss; 4520c8de5b0SBaptiste Daroussin data->s_mark = newss + i; 4530c8de5b0SBaptiste Daroussin 4540c8de5b0SBaptiste Daroussin newvs = (YYSTYPE *)realloc(data->l_base, newsize * sizeof(*newvs)); 4550c8de5b0SBaptiste Daroussin if (newvs == 0) 4560c8de5b0SBaptiste Daroussin return YYENOMEM; 4570c8de5b0SBaptiste Daroussin 4580c8de5b0SBaptiste Daroussin data->l_base = newvs; 4590c8de5b0SBaptiste Daroussin data->l_mark = newvs + i; 4600c8de5b0SBaptiste Daroussin 4610c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 4620c8de5b0SBaptiste Daroussin newps = (YYLTYPE *)realloc(data->p_base, newsize * sizeof(*newps)); 4630c8de5b0SBaptiste Daroussin if (newps == 0) 4640c8de5b0SBaptiste Daroussin return YYENOMEM; 4650c8de5b0SBaptiste Daroussin 4660c8de5b0SBaptiste Daroussin data->p_base = newps; 4670c8de5b0SBaptiste Daroussin data->p_mark = newps + i; 4680c8de5b0SBaptiste Daroussin #endif 4690c8de5b0SBaptiste Daroussin 4700c8de5b0SBaptiste Daroussin data->stacksize = newsize; 4710c8de5b0SBaptiste Daroussin data->s_last = data->s_base + newsize - 1; 4720c8de5b0SBaptiste Daroussin 4730c8de5b0SBaptiste Daroussin #if YYDEBUG 4740c8de5b0SBaptiste Daroussin if (yydebug) 4750c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug: stack size increased to %d\n", YYPREFIX, newsize); 4760c8de5b0SBaptiste Daroussin #endif 4770c8de5b0SBaptiste Daroussin return 0; 4780c8de5b0SBaptiste Daroussin } 4790c8de5b0SBaptiste Daroussin 4800c8de5b0SBaptiste Daroussin #if YYPURE || defined(YY_NO_LEAKS) 4810c8de5b0SBaptiste Daroussin static void yyfreestack(YYSTACKDATA *data) 4820c8de5b0SBaptiste Daroussin { 4830c8de5b0SBaptiste Daroussin free(data->s_base); 4840c8de5b0SBaptiste Daroussin free(data->l_base); 4850c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 4860c8de5b0SBaptiste Daroussin free(data->p_base); 4870c8de5b0SBaptiste Daroussin #endif 4880c8de5b0SBaptiste Daroussin memset(data, 0, sizeof(*data)); 4890c8de5b0SBaptiste Daroussin } 4900c8de5b0SBaptiste Daroussin #else 4910c8de5b0SBaptiste Daroussin #define yyfreestack(data) /* nothing */ 4920c8de5b0SBaptiste Daroussin #endif /* YYPURE || defined(YY_NO_LEAKS) */ 4930c8de5b0SBaptiste Daroussin #if YYBTYACC 4940c8de5b0SBaptiste Daroussin 4950c8de5b0SBaptiste Daroussin static YYParseState * 4960c8de5b0SBaptiste Daroussin yyNewState(unsigned size) 4970c8de5b0SBaptiste Daroussin { 4980c8de5b0SBaptiste Daroussin YYParseState *p = (YYParseState *) malloc(sizeof(YYParseState)); 4990c8de5b0SBaptiste Daroussin if (p == NULL) return NULL; 5000c8de5b0SBaptiste Daroussin 5010c8de5b0SBaptiste Daroussin p->yystack.stacksize = size; 5020c8de5b0SBaptiste Daroussin if (size == 0) 5030c8de5b0SBaptiste Daroussin { 5040c8de5b0SBaptiste Daroussin p->yystack.s_base = NULL; 5050c8de5b0SBaptiste Daroussin p->yystack.l_base = NULL; 5060c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 5070c8de5b0SBaptiste Daroussin p->yystack.p_base = NULL; 5080c8de5b0SBaptiste Daroussin #endif 5090c8de5b0SBaptiste Daroussin return p; 5100c8de5b0SBaptiste Daroussin } 511c5b5d71aSJung-uk Kim p->yystack.s_base = (YYINT *) malloc(size * sizeof(YYINT)); 5120c8de5b0SBaptiste Daroussin if (p->yystack.s_base == NULL) return NULL; 5130c8de5b0SBaptiste Daroussin p->yystack.l_base = (YYSTYPE *) malloc(size * sizeof(YYSTYPE)); 5140c8de5b0SBaptiste Daroussin if (p->yystack.l_base == NULL) return NULL; 5150c8de5b0SBaptiste Daroussin memset(p->yystack.l_base, 0, size * sizeof(YYSTYPE)); 5160c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 5170c8de5b0SBaptiste Daroussin p->yystack.p_base = (YYLTYPE *) malloc(size * sizeof(YYLTYPE)); 5180c8de5b0SBaptiste Daroussin if (p->yystack.p_base == NULL) return NULL; 5190c8de5b0SBaptiste Daroussin memset(p->yystack.p_base, 0, size * sizeof(YYLTYPE)); 5200c8de5b0SBaptiste Daroussin #endif 5210c8de5b0SBaptiste Daroussin 5220c8de5b0SBaptiste Daroussin return p; 5230c8de5b0SBaptiste Daroussin } 5240c8de5b0SBaptiste Daroussin 5250c8de5b0SBaptiste Daroussin static void 5260c8de5b0SBaptiste Daroussin yyFreeState(YYParseState *p) 5270c8de5b0SBaptiste Daroussin { 5280c8de5b0SBaptiste Daroussin yyfreestack(&p->yystack); 5290c8de5b0SBaptiste Daroussin free(p); 5300c8de5b0SBaptiste Daroussin } 5310c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 5320c8de5b0SBaptiste Daroussin 5330c8de5b0SBaptiste Daroussin #define YYABORT goto yyabort 5340c8de5b0SBaptiste Daroussin #define YYREJECT goto yyabort 5350c8de5b0SBaptiste Daroussin #define YYACCEPT goto yyaccept 5360c8de5b0SBaptiste Daroussin #define YYERROR goto yyerrlab 5370c8de5b0SBaptiste Daroussin #if YYBTYACC 5380c8de5b0SBaptiste Daroussin #define YYVALID do { if (yyps->save) goto yyvalid; } while(0) 5390c8de5b0SBaptiste Daroussin #define YYVALID_NESTED do { if (yyps->save && \ 5400c8de5b0SBaptiste Daroussin yyps->save->save == 0) goto yyvalid; } while(0) 5410c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 5420c8de5b0SBaptiste Daroussin 5430c8de5b0SBaptiste Daroussin int 5440c8de5b0SBaptiste Daroussin YYPARSE_DECL() 5450c8de5b0SBaptiste Daroussin { 5460c8de5b0SBaptiste Daroussin int yym, yyn, yystate, yyresult; 5470c8de5b0SBaptiste Daroussin #if YYBTYACC 5480c8de5b0SBaptiste Daroussin int yynewerrflag; 5490c8de5b0SBaptiste Daroussin YYParseState *yyerrctx = NULL; 5500c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 5510c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 5520c8de5b0SBaptiste Daroussin YYLTYPE yyerror_loc_range[2]; /* position of error start & end */ 5530c8de5b0SBaptiste Daroussin #endif 5540c8de5b0SBaptiste Daroussin #if YYDEBUG 5550c8de5b0SBaptiste Daroussin const char *yys; 5560c8de5b0SBaptiste Daroussin 5570c8de5b0SBaptiste Daroussin if ((yys = getenv("YYDEBUG")) != 0) 5580c8de5b0SBaptiste Daroussin { 5590c8de5b0SBaptiste Daroussin yyn = *yys; 5600c8de5b0SBaptiste Daroussin if (yyn >= '0' && yyn <= '9') 5610c8de5b0SBaptiste Daroussin yydebug = yyn - '0'; 5620c8de5b0SBaptiste Daroussin } 5630c8de5b0SBaptiste Daroussin if (yydebug) 5640c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug[<# of symbols on state stack>]\n", YYPREFIX); 5650c8de5b0SBaptiste Daroussin #endif 5660c8de5b0SBaptiste Daroussin 5670c8de5b0SBaptiste Daroussin #if YYBTYACC 5680c8de5b0SBaptiste Daroussin yyps = yyNewState(0); if (yyps == 0) goto yyenomem; 5690c8de5b0SBaptiste Daroussin yyps->save = 0; 5700c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 571c5b5d71aSJung-uk Kim yym = 0; 572c5b5d71aSJung-uk Kim yyn = 0; 5730c8de5b0SBaptiste Daroussin yynerrs = 0; 5740c8de5b0SBaptiste Daroussin yyerrflag = 0; 5750c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 5760c8de5b0SBaptiste Daroussin yystate = 0; 5770c8de5b0SBaptiste Daroussin 5780c8de5b0SBaptiste Daroussin #if YYPURE 5790c8de5b0SBaptiste Daroussin memset(&yystack, 0, sizeof(yystack)); 5800c8de5b0SBaptiste Daroussin #endif 5810c8de5b0SBaptiste Daroussin 5820c8de5b0SBaptiste Daroussin if (yystack.s_base == NULL && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 5830c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base; 5840c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base; 5850c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 5860c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base; 5870c8de5b0SBaptiste Daroussin #endif 5880c8de5b0SBaptiste Daroussin yystate = 0; 5890c8de5b0SBaptiste Daroussin *yystack.s_mark = 0; 5900c8de5b0SBaptiste Daroussin 5910c8de5b0SBaptiste Daroussin yyloop: 5920c8de5b0SBaptiste Daroussin if ((yyn = yydefred[yystate]) != 0) goto yyreduce; 5930c8de5b0SBaptiste Daroussin if (yychar < 0) 5940c8de5b0SBaptiste Daroussin { 5950c8de5b0SBaptiste Daroussin #if YYBTYACC 5960c8de5b0SBaptiste Daroussin do { 5970c8de5b0SBaptiste Daroussin if (yylvp < yylve) 5980c8de5b0SBaptiste Daroussin { 5990c8de5b0SBaptiste Daroussin /* we're currently re-reading tokens */ 6000c8de5b0SBaptiste Daroussin yylval = *yylvp++; 6010c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6020c8de5b0SBaptiste Daroussin yylloc = *yylpp++; 6030c8de5b0SBaptiste Daroussin #endif 6040c8de5b0SBaptiste Daroussin yychar = *yylexp++; 6050c8de5b0SBaptiste Daroussin break; 6060c8de5b0SBaptiste Daroussin } 6070c8de5b0SBaptiste Daroussin if (yyps->save) 6080c8de5b0SBaptiste Daroussin { 6090c8de5b0SBaptiste Daroussin /* in trial mode; save scanner results for future parse attempts */ 6100c8de5b0SBaptiste Daroussin if (yylvp == yylvlim) 6110c8de5b0SBaptiste Daroussin { /* Enlarge lexical value queue */ 61211fce282SBaptiste Daroussin size_t p = (size_t) (yylvp - yylvals); 61311fce282SBaptiste Daroussin size_t s = (size_t) (yylvlim - yylvals); 6140c8de5b0SBaptiste Daroussin 6150c8de5b0SBaptiste Daroussin s += YYLVQUEUEGROWTH; 616*2aca18c7SJung-uk Kim if ((yylexemes = realloc(yylexemes, s * sizeof(YYINT))) == NULL) goto yyenomem; 617*2aca18c7SJung-uk Kim if ((yylvals = realloc(yylvals, s * sizeof(YYSTYPE))) == NULL) goto yyenomem; 6180c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 619*2aca18c7SJung-uk Kim if ((yylpsns = realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL) goto yyenomem; 6200c8de5b0SBaptiste Daroussin #endif 6210c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals + p; 6220c8de5b0SBaptiste Daroussin yylvlim = yylvals + s; 6230c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6240c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns + p; 6250c8de5b0SBaptiste Daroussin yylplim = yylpsns + s; 6260c8de5b0SBaptiste Daroussin #endif 6270c8de5b0SBaptiste Daroussin yylexp = yylexemes + p; 6280c8de5b0SBaptiste Daroussin } 629*2aca18c7SJung-uk Kim *yylexp = (YYINT) YYLEX; 6300c8de5b0SBaptiste Daroussin *yylvp++ = yylval; 6310c8de5b0SBaptiste Daroussin yylve++; 6320c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6330c8de5b0SBaptiste Daroussin *yylpp++ = yylloc; 6340c8de5b0SBaptiste Daroussin yylpe++; 6350c8de5b0SBaptiste Daroussin #endif 6360c8de5b0SBaptiste Daroussin yychar = *yylexp++; 6370c8de5b0SBaptiste Daroussin break; 6380c8de5b0SBaptiste Daroussin } 6390c8de5b0SBaptiste Daroussin /* normal operation, no conflict encountered */ 6400c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 6410c8de5b0SBaptiste Daroussin yychar = YYLEX; 6420c8de5b0SBaptiste Daroussin #if YYBTYACC 6430c8de5b0SBaptiste Daroussin } while (0); 6440c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 6450c8de5b0SBaptiste Daroussin if (yychar < 0) yychar = YYEOF; 6460c8de5b0SBaptiste Daroussin #if YYDEBUG 6470c8de5b0SBaptiste Daroussin if (yydebug) 6480c8de5b0SBaptiste Daroussin { 649c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 6500c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)", 6510c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yychar, yys); 6520c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING 6530c8de5b0SBaptiste Daroussin #if YYBTYACC 6540c8de5b0SBaptiste Daroussin if (!yytrial) 6550c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 6560c8de5b0SBaptiste Daroussin fprintf(stderr, " <%s>", YYSTYPE_TOSTRING(yychar, yylval)); 6570c8de5b0SBaptiste Daroussin #endif 6580c8de5b0SBaptiste Daroussin fputc('\n', stderr); 6590c8de5b0SBaptiste Daroussin } 6600c8de5b0SBaptiste Daroussin #endif 6610c8de5b0SBaptiste Daroussin } 6620c8de5b0SBaptiste Daroussin #if YYBTYACC 6630c8de5b0SBaptiste Daroussin 6640c8de5b0SBaptiste Daroussin /* Do we have a conflict? */ 6650c8de5b0SBaptiste Daroussin if (((yyn = yycindex[yystate]) != 0) && (yyn += yychar) >= 0 && 6660c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 6670c8de5b0SBaptiste Daroussin { 6680c8de5b0SBaptiste Daroussin YYINT ctry; 6690c8de5b0SBaptiste Daroussin 6700c8de5b0SBaptiste Daroussin if (yypath) 6710c8de5b0SBaptiste Daroussin { 6720c8de5b0SBaptiste Daroussin YYParseState *save; 6730c8de5b0SBaptiste Daroussin #if YYDEBUG 6740c8de5b0SBaptiste Daroussin if (yydebug) 6750c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: CONFLICT in state %d: following successful trial parse\n", 6760c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate); 6770c8de5b0SBaptiste Daroussin #endif 6780c8de5b0SBaptiste Daroussin /* Switch to the next conflict context */ 6790c8de5b0SBaptiste Daroussin save = yypath; 6800c8de5b0SBaptiste Daroussin yypath = save->save; 6810c8de5b0SBaptiste Daroussin save->save = NULL; 6820c8de5b0SBaptiste Daroussin ctry = save->ctry; 6830c8de5b0SBaptiste Daroussin if (save->state != yystate) YYABORT; 6840c8de5b0SBaptiste Daroussin yyFreeState(save); 6850c8de5b0SBaptiste Daroussin 6860c8de5b0SBaptiste Daroussin } 6870c8de5b0SBaptiste Daroussin else 6880c8de5b0SBaptiste Daroussin { 6890c8de5b0SBaptiste Daroussin 6900c8de5b0SBaptiste Daroussin /* Unresolved conflict - start/continue trial parse */ 6910c8de5b0SBaptiste Daroussin YYParseState *save; 6920c8de5b0SBaptiste Daroussin #if YYDEBUG 6930c8de5b0SBaptiste Daroussin if (yydebug) 6940c8de5b0SBaptiste Daroussin { 6950c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: CONFLICT in state %d. ", YYDEBUGSTR, yydepth, yystate); 6960c8de5b0SBaptiste Daroussin if (yyps->save) 6970c8de5b0SBaptiste Daroussin fputs("ALREADY in conflict, continuing trial parse.\n", stderr); 6980c8de5b0SBaptiste Daroussin else 6990c8de5b0SBaptiste Daroussin fputs("Starting trial parse.\n", stderr); 7000c8de5b0SBaptiste Daroussin } 7010c8de5b0SBaptiste Daroussin #endif 7020c8de5b0SBaptiste Daroussin save = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1)); 7030c8de5b0SBaptiste Daroussin if (save == NULL) goto yyenomem; 7040c8de5b0SBaptiste Daroussin save->save = yyps->save; 7050c8de5b0SBaptiste Daroussin save->state = yystate; 7060c8de5b0SBaptiste Daroussin save->errflag = yyerrflag; 7070c8de5b0SBaptiste Daroussin save->yystack.s_mark = save->yystack.s_base + (yystack.s_mark - yystack.s_base); 708c5b5d71aSJung-uk Kim memcpy (save->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 7090c8de5b0SBaptiste Daroussin save->yystack.l_mark = save->yystack.l_base + (yystack.l_mark - yystack.l_base); 71011fce282SBaptiste Daroussin memcpy (save->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 7110c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7120c8de5b0SBaptiste Daroussin save->yystack.p_mark = save->yystack.p_base + (yystack.p_mark - yystack.p_base); 71311fce282SBaptiste Daroussin memcpy (save->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 7140c8de5b0SBaptiste Daroussin #endif 7150c8de5b0SBaptiste Daroussin ctry = yytable[yyn]; 7160c8de5b0SBaptiste Daroussin if (yyctable[ctry] == -1) 7170c8de5b0SBaptiste Daroussin { 7180c8de5b0SBaptiste Daroussin #if YYDEBUG 7190c8de5b0SBaptiste Daroussin if (yydebug && yychar >= YYEOF) 7200c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: backtracking 1 token\n", YYDEBUGSTR, yydepth); 7210c8de5b0SBaptiste Daroussin #endif 7220c8de5b0SBaptiste Daroussin ctry++; 7230c8de5b0SBaptiste Daroussin } 7240c8de5b0SBaptiste Daroussin save->ctry = ctry; 7250c8de5b0SBaptiste Daroussin if (yyps->save == NULL) 7260c8de5b0SBaptiste Daroussin { 7270c8de5b0SBaptiste Daroussin /* If this is a first conflict in the stack, start saving lexemes */ 7280c8de5b0SBaptiste Daroussin if (!yylexemes) 7290c8de5b0SBaptiste Daroussin { 730*2aca18c7SJung-uk Kim yylexemes = malloc((YYLVQUEUEGROWTH) * sizeof(YYINT)); 7310c8de5b0SBaptiste Daroussin if (yylexemes == NULL) goto yyenomem; 7320c8de5b0SBaptiste Daroussin yylvals = (YYSTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYSTYPE)); 7330c8de5b0SBaptiste Daroussin if (yylvals == NULL) goto yyenomem; 7340c8de5b0SBaptiste Daroussin yylvlim = yylvals + YYLVQUEUEGROWTH; 7350c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7360c8de5b0SBaptiste Daroussin yylpsns = (YYLTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYLTYPE)); 7370c8de5b0SBaptiste Daroussin if (yylpsns == NULL) goto yyenomem; 7380c8de5b0SBaptiste Daroussin yylplim = yylpsns + YYLVQUEUEGROWTH; 7390c8de5b0SBaptiste Daroussin #endif 7400c8de5b0SBaptiste Daroussin } 7410c8de5b0SBaptiste Daroussin if (yylvp == yylve) 7420c8de5b0SBaptiste Daroussin { 7430c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals; 7440c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7450c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns; 7460c8de5b0SBaptiste Daroussin #endif 7470c8de5b0SBaptiste Daroussin yylexp = yylexemes; 7480c8de5b0SBaptiste Daroussin if (yychar >= YYEOF) 7490c8de5b0SBaptiste Daroussin { 7500c8de5b0SBaptiste Daroussin *yylve++ = yylval; 7510c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7520c8de5b0SBaptiste Daroussin *yylpe++ = yylloc; 7530c8de5b0SBaptiste Daroussin #endif 754*2aca18c7SJung-uk Kim *yylexp = (YYINT) yychar; 7550c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 7560c8de5b0SBaptiste Daroussin } 7570c8de5b0SBaptiste Daroussin } 7580c8de5b0SBaptiste Daroussin } 7590c8de5b0SBaptiste Daroussin if (yychar >= YYEOF) 7600c8de5b0SBaptiste Daroussin { 7610c8de5b0SBaptiste Daroussin yylvp--; 7620c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7630c8de5b0SBaptiste Daroussin yylpp--; 7640c8de5b0SBaptiste Daroussin #endif 7650c8de5b0SBaptiste Daroussin yylexp--; 7660c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 7670c8de5b0SBaptiste Daroussin } 76811fce282SBaptiste Daroussin save->lexeme = (int) (yylvp - yylvals); 7690c8de5b0SBaptiste Daroussin yyps->save = save; 7700c8de5b0SBaptiste Daroussin } 7710c8de5b0SBaptiste Daroussin if (yytable[yyn] == ctry) 7720c8de5b0SBaptiste Daroussin { 7730c8de5b0SBaptiste Daroussin #if YYDEBUG 7740c8de5b0SBaptiste Daroussin if (yydebug) 7750c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n", 7760c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyctable[ctry]); 7770c8de5b0SBaptiste Daroussin #endif 7780c8de5b0SBaptiste Daroussin if (yychar < 0) 7790c8de5b0SBaptiste Daroussin { 7800c8de5b0SBaptiste Daroussin yylvp++; 7810c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7820c8de5b0SBaptiste Daroussin yylpp++; 7830c8de5b0SBaptiste Daroussin #endif 7840c8de5b0SBaptiste Daroussin yylexp++; 7850c8de5b0SBaptiste Daroussin } 7860c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) 7870c8de5b0SBaptiste Daroussin goto yyoverflow; 7880c8de5b0SBaptiste Daroussin yystate = yyctable[ctry]; 789c5b5d71aSJung-uk Kim *++yystack.s_mark = (YYINT) yystate; 7900c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval; 7910c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7920c8de5b0SBaptiste Daroussin *++yystack.p_mark = yylloc; 7930c8de5b0SBaptiste Daroussin #endif 7940c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 7950c8de5b0SBaptiste Daroussin if (yyerrflag > 0) --yyerrflag; 7960c8de5b0SBaptiste Daroussin goto yyloop; 7970c8de5b0SBaptiste Daroussin } 7980c8de5b0SBaptiste Daroussin else 7990c8de5b0SBaptiste Daroussin { 8000c8de5b0SBaptiste Daroussin yyn = yyctable[ctry]; 8010c8de5b0SBaptiste Daroussin goto yyreduce; 8020c8de5b0SBaptiste Daroussin } 8030c8de5b0SBaptiste Daroussin } /* End of code dealing with conflicts */ 8040c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 8050c8de5b0SBaptiste Daroussin if (((yyn = yysindex[yystate]) != 0) && (yyn += yychar) >= 0 && 8060c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 8070c8de5b0SBaptiste Daroussin { 8080c8de5b0SBaptiste Daroussin #if YYDEBUG 8090c8de5b0SBaptiste Daroussin if (yydebug) 8100c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n", 8110c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yytable[yyn]); 8120c8de5b0SBaptiste Daroussin #endif 8130c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 8140c8de5b0SBaptiste Daroussin yystate = yytable[yyn]; 8150c8de5b0SBaptiste Daroussin *++yystack.s_mark = yytable[yyn]; 8160c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval; 8170c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8180c8de5b0SBaptiste Daroussin *++yystack.p_mark = yylloc; 8190c8de5b0SBaptiste Daroussin #endif 8200c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 8210c8de5b0SBaptiste Daroussin if (yyerrflag > 0) --yyerrflag; 8220c8de5b0SBaptiste Daroussin goto yyloop; 8230c8de5b0SBaptiste Daroussin } 8240c8de5b0SBaptiste Daroussin if (((yyn = yyrindex[yystate]) != 0) && (yyn += yychar) >= 0 && 8250c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 8260c8de5b0SBaptiste Daroussin { 8270c8de5b0SBaptiste Daroussin yyn = yytable[yyn]; 8280c8de5b0SBaptiste Daroussin goto yyreduce; 8290c8de5b0SBaptiste Daroussin } 8300c8de5b0SBaptiste Daroussin if (yyerrflag != 0) goto yyinrecovery; 8310c8de5b0SBaptiste Daroussin #if YYBTYACC 8320c8de5b0SBaptiste Daroussin 8330c8de5b0SBaptiste Daroussin yynewerrflag = 1; 8340c8de5b0SBaptiste Daroussin goto yyerrhandler; 835c5b5d71aSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */ 8360c8de5b0SBaptiste Daroussin 8370c8de5b0SBaptiste Daroussin yyerrlab: 838c5b5d71aSJung-uk Kim /* explicit YYERROR from an action -- pop the rhs of the rule reduced 839c5b5d71aSJung-uk Kim * before looking for error recovery */ 840c5b5d71aSJung-uk Kim yystack.s_mark -= yym; 841c5b5d71aSJung-uk Kim yystate = *yystack.s_mark; 842c5b5d71aSJung-uk Kim yystack.l_mark -= yym; 843c5b5d71aSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 844c5b5d71aSJung-uk Kim yystack.p_mark -= yym; 845c5b5d71aSJung-uk Kim #endif 846c5b5d71aSJung-uk Kim 8470c8de5b0SBaptiste Daroussin yynewerrflag = 0; 8480c8de5b0SBaptiste Daroussin yyerrhandler: 8490c8de5b0SBaptiste Daroussin while (yyps->save) 8500c8de5b0SBaptiste Daroussin { 8510c8de5b0SBaptiste Daroussin int ctry; 8520c8de5b0SBaptiste Daroussin YYParseState *save = yyps->save; 8530c8de5b0SBaptiste Daroussin #if YYDEBUG 8540c8de5b0SBaptiste Daroussin if (yydebug) 8550c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: ERROR in state %d, CONFLICT BACKTRACKING to state %d, %d tokens\n", 8560c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyps->save->state, 8570c8de5b0SBaptiste Daroussin (int)(yylvp - yylvals - yyps->save->lexeme)); 8580c8de5b0SBaptiste Daroussin #endif 8590c8de5b0SBaptiste Daroussin /* Memorize most forward-looking error state in case it's really an error. */ 8600c8de5b0SBaptiste Daroussin if (yyerrctx == NULL || yyerrctx->lexeme < yylvp - yylvals) 8610c8de5b0SBaptiste Daroussin { 8620c8de5b0SBaptiste Daroussin /* Free old saved error context state */ 8630c8de5b0SBaptiste Daroussin if (yyerrctx) yyFreeState(yyerrctx); 8640c8de5b0SBaptiste Daroussin /* Create and fill out new saved error context state */ 8650c8de5b0SBaptiste Daroussin yyerrctx = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1)); 8660c8de5b0SBaptiste Daroussin if (yyerrctx == NULL) goto yyenomem; 8670c8de5b0SBaptiste Daroussin yyerrctx->save = yyps->save; 8680c8de5b0SBaptiste Daroussin yyerrctx->state = yystate; 8690c8de5b0SBaptiste Daroussin yyerrctx->errflag = yyerrflag; 8700c8de5b0SBaptiste Daroussin yyerrctx->yystack.s_mark = yyerrctx->yystack.s_base + (yystack.s_mark - yystack.s_base); 871c5b5d71aSJung-uk Kim memcpy (yyerrctx->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 8720c8de5b0SBaptiste Daroussin yyerrctx->yystack.l_mark = yyerrctx->yystack.l_base + (yystack.l_mark - yystack.l_base); 87311fce282SBaptiste Daroussin memcpy (yyerrctx->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 8740c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8750c8de5b0SBaptiste Daroussin yyerrctx->yystack.p_mark = yyerrctx->yystack.p_base + (yystack.p_mark - yystack.p_base); 87611fce282SBaptiste Daroussin memcpy (yyerrctx->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 8770c8de5b0SBaptiste Daroussin #endif 87811fce282SBaptiste Daroussin yyerrctx->lexeme = (int) (yylvp - yylvals); 8790c8de5b0SBaptiste Daroussin } 8800c8de5b0SBaptiste Daroussin yylvp = yylvals + save->lexeme; 8810c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8820c8de5b0SBaptiste Daroussin yylpp = yylpsns + save->lexeme; 8830c8de5b0SBaptiste Daroussin #endif 8840c8de5b0SBaptiste Daroussin yylexp = yylexemes + save->lexeme; 8850c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 8860c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (save->yystack.s_mark - save->yystack.s_base); 887c5b5d71aSJung-uk Kim memcpy (yystack.s_base, save->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 8880c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (save->yystack.l_mark - save->yystack.l_base); 88911fce282SBaptiste Daroussin memcpy (yystack.l_base, save->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 8900c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8910c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (save->yystack.p_mark - save->yystack.p_base); 89211fce282SBaptiste Daroussin memcpy (yystack.p_base, save->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 8930c8de5b0SBaptiste Daroussin #endif 8940c8de5b0SBaptiste Daroussin ctry = ++save->ctry; 8950c8de5b0SBaptiste Daroussin yystate = save->state; 8960c8de5b0SBaptiste Daroussin /* We tried shift, try reduce now */ 8970c8de5b0SBaptiste Daroussin if ((yyn = yyctable[ctry]) >= 0) goto yyreduce; 8980c8de5b0SBaptiste Daroussin yyps->save = save->save; 8990c8de5b0SBaptiste Daroussin save->save = NULL; 9000c8de5b0SBaptiste Daroussin yyFreeState(save); 9010c8de5b0SBaptiste Daroussin 9020c8de5b0SBaptiste Daroussin /* Nothing left on the stack -- error */ 9030c8de5b0SBaptiste Daroussin if (!yyps->save) 9040c8de5b0SBaptiste Daroussin { 9050c8de5b0SBaptiste Daroussin #if YYDEBUG 9060c8de5b0SBaptiste Daroussin if (yydebug) 9070c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug[%d,trial]: trial parse FAILED, entering ERROR mode\n", 9080c8de5b0SBaptiste Daroussin YYPREFIX, yydepth); 9090c8de5b0SBaptiste Daroussin #endif 9100c8de5b0SBaptiste Daroussin /* Restore state as it was in the most forward-advanced error */ 9110c8de5b0SBaptiste Daroussin yylvp = yylvals + yyerrctx->lexeme; 9120c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9130c8de5b0SBaptiste Daroussin yylpp = yylpsns + yyerrctx->lexeme; 9140c8de5b0SBaptiste Daroussin #endif 9150c8de5b0SBaptiste Daroussin yylexp = yylexemes + yyerrctx->lexeme; 9160c8de5b0SBaptiste Daroussin yychar = yylexp[-1]; 9170c8de5b0SBaptiste Daroussin yylval = yylvp[-1]; 9180c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9190c8de5b0SBaptiste Daroussin yylloc = yylpp[-1]; 9200c8de5b0SBaptiste Daroussin #endif 9210c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (yyerrctx->yystack.s_mark - yyerrctx->yystack.s_base); 922c5b5d71aSJung-uk Kim memcpy (yystack.s_base, yyerrctx->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 9230c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (yyerrctx->yystack.l_mark - yyerrctx->yystack.l_base); 92411fce282SBaptiste Daroussin memcpy (yystack.l_base, yyerrctx->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 9250c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9260c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (yyerrctx->yystack.p_mark - yyerrctx->yystack.p_base); 92711fce282SBaptiste Daroussin memcpy (yystack.p_base, yyerrctx->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 9280c8de5b0SBaptiste Daroussin #endif 9290c8de5b0SBaptiste Daroussin yystate = yyerrctx->state; 9300c8de5b0SBaptiste Daroussin yyFreeState(yyerrctx); 9310c8de5b0SBaptiste Daroussin yyerrctx = NULL; 9320c8de5b0SBaptiste Daroussin } 9330c8de5b0SBaptiste Daroussin yynewerrflag = 1; 9340c8de5b0SBaptiste Daroussin } 9350c8de5b0SBaptiste Daroussin if (yynewerrflag == 0) goto yyinrecovery; 9360c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 9370c8de5b0SBaptiste Daroussin 9380c8de5b0SBaptiste Daroussin YYERROR_CALL("syntax error"); 9390c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9400c8de5b0SBaptiste Daroussin yyerror_loc_range[0] = yylloc; /* lookahead position is error start position */ 9410c8de5b0SBaptiste Daroussin #endif 9420c8de5b0SBaptiste Daroussin 9430c8de5b0SBaptiste Daroussin #if !YYBTYACC 944c5b5d71aSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */ 9450c8de5b0SBaptiste Daroussin yyerrlab: 9460c8de5b0SBaptiste Daroussin #endif 9470c8de5b0SBaptiste Daroussin ++yynerrs; 9480c8de5b0SBaptiste Daroussin 9490c8de5b0SBaptiste Daroussin yyinrecovery: 9500c8de5b0SBaptiste Daroussin if (yyerrflag < 3) 9510c8de5b0SBaptiste Daroussin { 9520c8de5b0SBaptiste Daroussin yyerrflag = 3; 9530c8de5b0SBaptiste Daroussin for (;;) 9540c8de5b0SBaptiste Daroussin { 9550c8de5b0SBaptiste Daroussin if (((yyn = yysindex[*yystack.s_mark]) != 0) && (yyn += YYERRCODE) >= 0 && 9560c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) YYERRCODE) 9570c8de5b0SBaptiste Daroussin { 9580c8de5b0SBaptiste Daroussin #if YYDEBUG 9590c8de5b0SBaptiste Daroussin if (yydebug) 9600c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, error recovery shifting to state %d\n", 9610c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, *yystack.s_mark, yytable[yyn]); 9620c8de5b0SBaptiste Daroussin #endif 9630c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 9640c8de5b0SBaptiste Daroussin yystate = yytable[yyn]; 9650c8de5b0SBaptiste Daroussin *++yystack.s_mark = yytable[yyn]; 9660c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval; 9670c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9680c8de5b0SBaptiste Daroussin /* lookahead position is error end position */ 9690c8de5b0SBaptiste Daroussin yyerror_loc_range[1] = yylloc; 9700c8de5b0SBaptiste Daroussin YYLLOC_DEFAULT(yyloc, yyerror_loc_range, 2); /* position of error span */ 9710c8de5b0SBaptiste Daroussin *++yystack.p_mark = yyloc; 9720c8de5b0SBaptiste Daroussin #endif 9730c8de5b0SBaptiste Daroussin goto yyloop; 9740c8de5b0SBaptiste Daroussin } 9750c8de5b0SBaptiste Daroussin else 9760c8de5b0SBaptiste Daroussin { 9770c8de5b0SBaptiste Daroussin #if YYDEBUG 9780c8de5b0SBaptiste Daroussin if (yydebug) 9790c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: error recovery discarding state %d\n", 9800c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, *yystack.s_mark); 9810c8de5b0SBaptiste Daroussin #endif 9820c8de5b0SBaptiste Daroussin if (yystack.s_mark <= yystack.s_base) goto yyabort; 9830c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9840c8de5b0SBaptiste Daroussin /* the current TOS position is the error start position */ 9850c8de5b0SBaptiste Daroussin yyerror_loc_range[0] = *yystack.p_mark; 9860c8de5b0SBaptiste Daroussin #endif 9870c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL) 9880c8de5b0SBaptiste Daroussin #if YYBTYACC 9890c8de5b0SBaptiste Daroussin if (!yytrial) 9900c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 9910c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9920c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding state", 9930c8de5b0SBaptiste Daroussin yystos[*yystack.s_mark], yystack.l_mark, yystack.p_mark); 9940c8de5b0SBaptiste Daroussin #else 9950c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding state", 9960c8de5b0SBaptiste Daroussin yystos[*yystack.s_mark], yystack.l_mark); 9970c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 9980c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */ 9990c8de5b0SBaptiste Daroussin --yystack.s_mark; 10000c8de5b0SBaptiste Daroussin --yystack.l_mark; 10010c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 10020c8de5b0SBaptiste Daroussin --yystack.p_mark; 10030c8de5b0SBaptiste Daroussin #endif 10040c8de5b0SBaptiste Daroussin } 10050c8de5b0SBaptiste Daroussin } 10060c8de5b0SBaptiste Daroussin } 10070c8de5b0SBaptiste Daroussin else 10080c8de5b0SBaptiste Daroussin { 10090c8de5b0SBaptiste Daroussin if (yychar == YYEOF) goto yyabort; 10100c8de5b0SBaptiste Daroussin #if YYDEBUG 10110c8de5b0SBaptiste Daroussin if (yydebug) 10120c8de5b0SBaptiste Daroussin { 1013c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 10140c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, error recovery discarding token %d (%s)\n", 10150c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yychar, yys); 10160c8de5b0SBaptiste Daroussin } 10170c8de5b0SBaptiste Daroussin #endif 10180c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL) 10190c8de5b0SBaptiste Daroussin #if YYBTYACC 10200c8de5b0SBaptiste Daroussin if (!yytrial) 10210c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 10220c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 10230c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding token", yychar, &yylval, &yylloc); 10240c8de5b0SBaptiste Daroussin #else 10250c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding token", yychar, &yylval); 10260c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 10270c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */ 10280c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 10290c8de5b0SBaptiste Daroussin goto yyloop; 10300c8de5b0SBaptiste Daroussin } 10310c8de5b0SBaptiste Daroussin 10320c8de5b0SBaptiste Daroussin yyreduce: 10330c8de5b0SBaptiste Daroussin yym = yylen[yyn]; 10340c8de5b0SBaptiste Daroussin #if YYDEBUG 10350c8de5b0SBaptiste Daroussin if (yydebug) 10360c8de5b0SBaptiste Daroussin { 10370c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, reducing by rule %d (%s)", 10380c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyn, yyrule[yyn]); 10390c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING 10400c8de5b0SBaptiste Daroussin #if YYBTYACC 10410c8de5b0SBaptiste Daroussin if (!yytrial) 10420c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 10430c8de5b0SBaptiste Daroussin if (yym > 0) 10440c8de5b0SBaptiste Daroussin { 10450c8de5b0SBaptiste Daroussin int i; 10460c8de5b0SBaptiste Daroussin fputc('<', stderr); 10470c8de5b0SBaptiste Daroussin for (i = yym; i > 0; i--) 10480c8de5b0SBaptiste Daroussin { 10490c8de5b0SBaptiste Daroussin if (i != yym) fputs(", ", stderr); 10500c8de5b0SBaptiste Daroussin fputs(YYSTYPE_TOSTRING(yystos[yystack.s_mark[1-i]], 10510c8de5b0SBaptiste Daroussin yystack.l_mark[1-i]), stderr); 10520c8de5b0SBaptiste Daroussin } 10530c8de5b0SBaptiste Daroussin fputc('>', stderr); 10540c8de5b0SBaptiste Daroussin } 10550c8de5b0SBaptiste Daroussin #endif 10560c8de5b0SBaptiste Daroussin fputc('\n', stderr); 10570c8de5b0SBaptiste Daroussin } 10580c8de5b0SBaptiste Daroussin #endif 10590c8de5b0SBaptiste Daroussin if (yym > 0) 10600c8de5b0SBaptiste Daroussin yyval = yystack.l_mark[1-yym]; 10610c8de5b0SBaptiste Daroussin else 10620c8de5b0SBaptiste Daroussin memset(&yyval, 0, sizeof yyval); 10630c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 10640c8de5b0SBaptiste Daroussin 10650c8de5b0SBaptiste Daroussin /* Perform position reduction */ 10660c8de5b0SBaptiste Daroussin memset(&yyloc, 0, sizeof(yyloc)); 10670c8de5b0SBaptiste Daroussin #if YYBTYACC 10680c8de5b0SBaptiste Daroussin if (!yytrial) 10690c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 10700c8de5b0SBaptiste Daroussin { 10710c8de5b0SBaptiste Daroussin YYLLOC_DEFAULT(yyloc, &yystack.p_mark[1-yym], yym); 10720c8de5b0SBaptiste Daroussin /* just in case YYERROR is invoked within the action, save 10730c8de5b0SBaptiste Daroussin the start of the rhs as the error start position */ 10740c8de5b0SBaptiste Daroussin yyerror_loc_range[0] = yystack.p_mark[1-yym]; 10750c8de5b0SBaptiste Daroussin } 10760c8de5b0SBaptiste Daroussin #endif 10770c8de5b0SBaptiste Daroussin 10780c8de5b0SBaptiste Daroussin switch (yyn) 10790c8de5b0SBaptiste Daroussin { 10800c8de5b0SBaptiste Daroussin case 1: 10810c8de5b0SBaptiste Daroussin #line 44 "inherit1.y" 10820c8de5b0SBaptiste Daroussin { yyval.nlist = yystack.l_mark[0].nlist; } 10830c8de5b0SBaptiste Daroussin break; 10840c8de5b0SBaptiste Daroussin case 2: 10850c8de5b0SBaptiste Daroussin #line 46 "inherit1.y" 10860c8de5b0SBaptiste Daroussin { yyval.nlist = yystack.l_mark[0].nlist; } 10870c8de5b0SBaptiste Daroussin break; 10880c8de5b0SBaptiste Daroussin case 3: 10890c8de5b0SBaptiste Daroussin #line 49 "inherit1.y" 10900c8de5b0SBaptiste Daroussin { yyval.cval = cGLOBAL; } 10910c8de5b0SBaptiste Daroussin break; 10920c8de5b0SBaptiste Daroussin case 4: 10930c8de5b0SBaptiste Daroussin #line 50 "inherit1.y" 10940c8de5b0SBaptiste Daroussin { yyval.cval = cLOCAL; } 10950c8de5b0SBaptiste Daroussin break; 10960c8de5b0SBaptiste Daroussin case 5: 10970c8de5b0SBaptiste Daroussin #line 53 "inherit1.y" 10980c8de5b0SBaptiste Daroussin { yyval.tval = tREAL; } 10990c8de5b0SBaptiste Daroussin break; 11000c8de5b0SBaptiste Daroussin case 6: 11010c8de5b0SBaptiste Daroussin #line 54 "inherit1.y" 11020c8de5b0SBaptiste Daroussin { yyval.tval = tINTEGER; } 11030c8de5b0SBaptiste Daroussin break; 11040c8de5b0SBaptiste Daroussin case 7: 11050c8de5b0SBaptiste Daroussin #line 58 "inherit1.y" 11060c8de5b0SBaptiste Daroussin { yyval.nlist->s = mksymbol(yystack.l_mark[-2].tval, yystack.l_mark[-3].cval, yystack.l_mark[0].id); 11070c8de5b0SBaptiste Daroussin yyval.nlist->next = yystack.l_mark[-1].nlist; 11080c8de5b0SBaptiste Daroussin } 11090c8de5b0SBaptiste Daroussin break; 11100c8de5b0SBaptiste Daroussin case 8: 11110c8de5b0SBaptiste Daroussin #line 62 "inherit1.y" 11120c8de5b0SBaptiste Daroussin { yyval.nlist->s = mksymbol(yystack.l_mark[-1].tval, yystack.l_mark[-2].cval, yystack.l_mark[0].id); 11130c8de5b0SBaptiste Daroussin yyval.nlist->next = NULL; 11140c8de5b0SBaptiste Daroussin } 11150c8de5b0SBaptiste Daroussin break; 11160c8de5b0SBaptiste Daroussin case 9: 11170c8de5b0SBaptiste Daroussin #line 68 "inherit1.y" 11180c8de5b0SBaptiste Daroussin { yyval.cval = cLOCAL; } 11190c8de5b0SBaptiste Daroussin break; 11200c8de5b0SBaptiste Daroussin case 10: 11210c8de5b0SBaptiste Daroussin #line 69 "inherit1.y" 11220c8de5b0SBaptiste Daroussin { yyval.tval = yystack.l_mark[-2].tval; } 11230c8de5b0SBaptiste Daroussin break; 11240c8de5b0SBaptiste Daroussin case 11: 11250c8de5b0SBaptiste Daroussin #line 71 "inherit1.y" 11260c8de5b0SBaptiste Daroussin { yyval.nlist = yystack.l_mark[0].nlist; } 11270c8de5b0SBaptiste Daroussin break; 1128*2aca18c7SJung-uk Kim #line 1129 "inherit1.tab.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; 1183*2aca18c7SJung-uk Kim if ((yylexemes = realloc(yylexemes, s * sizeof(YYINT))) == NULL) 11840c8de5b0SBaptiste Daroussin goto yyenomem; 1185*2aca18c7SJung-uk Kim if ((yylvals = realloc(yylvals, s * sizeof(YYSTYPE))) == NULL) 11860c8de5b0SBaptiste Daroussin goto yyenomem; 11870c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1188*2aca18c7SJung-uk Kim if ((yylpsns = 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 } 1199*2aca18c7SJung-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