10c8de5b0SBaptiste Daroussin /* original parser id follows */ 20c8de5b0SBaptiste Daroussin /* yysccsid[] = "@(#)yaccpar 1.9 (Berkeley) 02/21/93" */ 3*c5b5d71aSJung-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 inherit2_parse 220c8de5b0SBaptiste Daroussin #endif /* yyparse */ 230c8de5b0SBaptiste Daroussin 240c8de5b0SBaptiste Daroussin #ifndef yylex 250c8de5b0SBaptiste Daroussin #define yylex inherit2_lex 260c8de5b0SBaptiste Daroussin #endif /* yylex */ 270c8de5b0SBaptiste Daroussin 280c8de5b0SBaptiste Daroussin #ifndef yyerror 290c8de5b0SBaptiste Daroussin #define yyerror inherit2_error 300c8de5b0SBaptiste Daroussin #endif /* yyerror */ 310c8de5b0SBaptiste Daroussin 320c8de5b0SBaptiste Daroussin #ifndef yychar 330c8de5b0SBaptiste Daroussin #define yychar inherit2_char 340c8de5b0SBaptiste Daroussin #endif /* yychar */ 350c8de5b0SBaptiste Daroussin 360c8de5b0SBaptiste Daroussin #ifndef yyval 370c8de5b0SBaptiste Daroussin #define yyval inherit2_val 380c8de5b0SBaptiste Daroussin #endif /* yyval */ 390c8de5b0SBaptiste Daroussin 400c8de5b0SBaptiste Daroussin #ifndef yylval 410c8de5b0SBaptiste Daroussin #define yylval inherit2_lval 420c8de5b0SBaptiste Daroussin #endif /* yylval */ 430c8de5b0SBaptiste Daroussin 440c8de5b0SBaptiste Daroussin #ifndef yydebug 450c8de5b0SBaptiste Daroussin #define yydebug inherit2_debug 460c8de5b0SBaptiste Daroussin #endif /* yydebug */ 470c8de5b0SBaptiste Daroussin 480c8de5b0SBaptiste Daroussin #ifndef yynerrs 490c8de5b0SBaptiste Daroussin #define yynerrs inherit2_nerrs 500c8de5b0SBaptiste Daroussin #endif /* yynerrs */ 510c8de5b0SBaptiste Daroussin 520c8de5b0SBaptiste Daroussin #ifndef yyerrflag 530c8de5b0SBaptiste Daroussin #define yyerrflag inherit2_errflag 540c8de5b0SBaptiste Daroussin #endif /* yyerrflag */ 550c8de5b0SBaptiste Daroussin 560c8de5b0SBaptiste Daroussin #ifndef yylhs 570c8de5b0SBaptiste Daroussin #define yylhs inherit2_lhs 580c8de5b0SBaptiste Daroussin #endif /* yylhs */ 590c8de5b0SBaptiste Daroussin 600c8de5b0SBaptiste Daroussin #ifndef yylen 610c8de5b0SBaptiste Daroussin #define yylen inherit2_len 620c8de5b0SBaptiste Daroussin #endif /* yylen */ 630c8de5b0SBaptiste Daroussin 640c8de5b0SBaptiste Daroussin #ifndef yydefred 650c8de5b0SBaptiste Daroussin #define yydefred inherit2_defred 660c8de5b0SBaptiste Daroussin #endif /* yydefred */ 670c8de5b0SBaptiste Daroussin 680c8de5b0SBaptiste Daroussin #ifndef yystos 690c8de5b0SBaptiste Daroussin #define yystos inherit2_stos 700c8de5b0SBaptiste Daroussin #endif /* yystos */ 710c8de5b0SBaptiste Daroussin 720c8de5b0SBaptiste Daroussin #ifndef yydgoto 730c8de5b0SBaptiste Daroussin #define yydgoto inherit2_dgoto 740c8de5b0SBaptiste Daroussin #endif /* yydgoto */ 750c8de5b0SBaptiste Daroussin 760c8de5b0SBaptiste Daroussin #ifndef yysindex 770c8de5b0SBaptiste Daroussin #define yysindex inherit2_sindex 780c8de5b0SBaptiste Daroussin #endif /* yysindex */ 790c8de5b0SBaptiste Daroussin 800c8de5b0SBaptiste Daroussin #ifndef yyrindex 810c8de5b0SBaptiste Daroussin #define yyrindex inherit2_rindex 820c8de5b0SBaptiste Daroussin #endif /* yyrindex */ 830c8de5b0SBaptiste Daroussin 840c8de5b0SBaptiste Daroussin #ifndef yygindex 850c8de5b0SBaptiste Daroussin #define yygindex inherit2_gindex 860c8de5b0SBaptiste Daroussin #endif /* yygindex */ 870c8de5b0SBaptiste Daroussin 880c8de5b0SBaptiste Daroussin #ifndef yytable 890c8de5b0SBaptiste Daroussin #define yytable inherit2_table 900c8de5b0SBaptiste Daroussin #endif /* yytable */ 910c8de5b0SBaptiste Daroussin 920c8de5b0SBaptiste Daroussin #ifndef yycheck 930c8de5b0SBaptiste Daroussin #define yycheck inherit2_check 940c8de5b0SBaptiste Daroussin #endif /* yycheck */ 950c8de5b0SBaptiste Daroussin 960c8de5b0SBaptiste Daroussin #ifndef yyname 970c8de5b0SBaptiste Daroussin #define yyname inherit2_name 980c8de5b0SBaptiste Daroussin #endif /* yyname */ 990c8de5b0SBaptiste Daroussin 1000c8de5b0SBaptiste Daroussin #ifndef yyrule 1010c8de5b0SBaptiste Daroussin #define yyrule inherit2_rule 1020c8de5b0SBaptiste Daroussin #endif /* yyrule */ 1030c8de5b0SBaptiste Daroussin 1040c8de5b0SBaptiste Daroussin #if YYBTYACC 1050c8de5b0SBaptiste Daroussin 1060c8de5b0SBaptiste Daroussin #ifndef yycindex 1070c8de5b0SBaptiste Daroussin #define yycindex inherit2_cindex 1080c8de5b0SBaptiste Daroussin #endif /* yycindex */ 1090c8de5b0SBaptiste Daroussin 1100c8de5b0SBaptiste Daroussin #ifndef yyctable 1110c8de5b0SBaptiste Daroussin #define yyctable inherit2_ctable 1120c8de5b0SBaptiste Daroussin #endif /* yyctable */ 1130c8de5b0SBaptiste Daroussin 1140c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 1150c8de5b0SBaptiste Daroussin 1160c8de5b0SBaptiste Daroussin #define YYPREFIX "inherit2_" 1170c8de5b0SBaptiste Daroussin 1180c8de5b0SBaptiste Daroussin #define YYPURE 0 1190c8de5b0SBaptiste Daroussin 1200c8de5b0SBaptiste Daroussin #line 2 "inherit2.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 #endif 1390c8de5b0SBaptiste Daroussin #ifdef YYSTYPE 1400c8de5b0SBaptiste Daroussin #undef YYSTYPE_IS_DECLARED 1410c8de5b0SBaptiste Daroussin #define YYSTYPE_IS_DECLARED 1 1420c8de5b0SBaptiste Daroussin #endif 1430c8de5b0SBaptiste Daroussin #ifndef YYSTYPE_IS_DECLARED 1440c8de5b0SBaptiste Daroussin #define YYSTYPE_IS_DECLARED 1 145*c5b5d71aSJung-uk Kim #line 39 "inherit2.y" 1460c8de5b0SBaptiste Daroussin typedef union 1470c8de5b0SBaptiste Daroussin { 1480c8de5b0SBaptiste Daroussin class cval; 1490c8de5b0SBaptiste Daroussin type tval; 1500c8de5b0SBaptiste Daroussin namelist * nlist; 1510c8de5b0SBaptiste Daroussin name id; 1520c8de5b0SBaptiste Daroussin } YYSTYPE; 1530c8de5b0SBaptiste Daroussin #endif /* !YYSTYPE_IS_DECLARED */ 1540c8de5b0SBaptiste Daroussin #line 155 "inherit2.tab.c" 1550c8de5b0SBaptiste Daroussin 1560c8de5b0SBaptiste Daroussin /* compatibility with bison */ 1570c8de5b0SBaptiste Daroussin #ifdef YYPARSE_PARAM 1580c8de5b0SBaptiste Daroussin /* compatibility with FreeBSD */ 1590c8de5b0SBaptiste Daroussin # ifdef YYPARSE_PARAM_TYPE 1600c8de5b0SBaptiste Daroussin # define YYPARSE_DECL() yyparse(YYPARSE_PARAM_TYPE YYPARSE_PARAM) 1610c8de5b0SBaptiste Daroussin # else 1620c8de5b0SBaptiste Daroussin # define YYPARSE_DECL() yyparse(void *YYPARSE_PARAM) 1630c8de5b0SBaptiste Daroussin # endif 1640c8de5b0SBaptiste Daroussin #else 1650c8de5b0SBaptiste Daroussin # define YYPARSE_DECL() yyparse(void) 1660c8de5b0SBaptiste Daroussin #endif 1670c8de5b0SBaptiste Daroussin 1680c8de5b0SBaptiste Daroussin /* Parameters sent to lex. */ 1690c8de5b0SBaptiste Daroussin #ifdef YYLEX_PARAM 1700c8de5b0SBaptiste Daroussin # define YYLEX_DECL() yylex(void *YYLEX_PARAM) 1710c8de5b0SBaptiste Daroussin # define YYLEX yylex(YYLEX_PARAM) 1720c8de5b0SBaptiste Daroussin #else 1730c8de5b0SBaptiste Daroussin # define YYLEX_DECL() yylex(void) 1740c8de5b0SBaptiste Daroussin # define YYLEX yylex() 1750c8de5b0SBaptiste Daroussin #endif 1760c8de5b0SBaptiste Daroussin 1770c8de5b0SBaptiste Daroussin /* Parameters sent to yyerror. */ 1780c8de5b0SBaptiste Daroussin #ifndef YYERROR_DECL 1790c8de5b0SBaptiste Daroussin #define YYERROR_DECL() yyerror(const char *s) 1800c8de5b0SBaptiste Daroussin #endif 1810c8de5b0SBaptiste Daroussin #ifndef YYERROR_CALL 1820c8de5b0SBaptiste Daroussin #define YYERROR_CALL(msg) yyerror(msg) 1830c8de5b0SBaptiste Daroussin #endif 1840c8de5b0SBaptiste Daroussin 1850c8de5b0SBaptiste Daroussin #ifndef YYDESTRUCT_DECL 1860c8de5b0SBaptiste Daroussin #define YYDESTRUCT_DECL() yydestruct(const char *msg, int psymb, YYSTYPE *val) 1870c8de5b0SBaptiste Daroussin #endif 1880c8de5b0SBaptiste Daroussin #ifndef YYDESTRUCT_CALL 1890c8de5b0SBaptiste Daroussin #define YYDESTRUCT_CALL(msg, psymb, val) yydestruct(msg, psymb, val) 1900c8de5b0SBaptiste Daroussin #endif 1910c8de5b0SBaptiste Daroussin 1920c8de5b0SBaptiste Daroussin extern int YYPARSE_DECL(); 1930c8de5b0SBaptiste Daroussin 1940c8de5b0SBaptiste Daroussin #define GLOBAL 257 1950c8de5b0SBaptiste Daroussin #define LOCAL 258 1960c8de5b0SBaptiste Daroussin #define REAL 259 1970c8de5b0SBaptiste Daroussin #define INTEGER 260 1980c8de5b0SBaptiste Daroussin #define NAME 261 1990c8de5b0SBaptiste Daroussin #define YYERRCODE 256 2000c8de5b0SBaptiste Daroussin typedef short YYINT; 2010c8de5b0SBaptiste Daroussin static const YYINT inherit2_lhs[] = { -1, 202*c5b5d71aSJung-uk Kim 5, 6, 0, 0, 3, 3, 4, 4, 1, 1, 203*c5b5d71aSJung-uk Kim 7, 2, 2040c8de5b0SBaptiste Daroussin }; 2050c8de5b0SBaptiste Daroussin static const YYINT inherit2_len[] = { 2, 206*c5b5d71aSJung-uk Kim 0, 0, 5, 2, 1, 1, 1, 1, 2, 1, 207*c5b5d71aSJung-uk Kim 0, 3, 2080c8de5b0SBaptiste Daroussin }; 2090c8de5b0SBaptiste Daroussin static const YYINT inherit2_defred[] = { 0, 210*c5b5d71aSJung-uk Kim 5, 6, 7, 8, 0, 0, 11, 1, 4, 2, 211*c5b5d71aSJung-uk Kim 2, 0, 0, 10, 0, 0, 9, 2120c8de5b0SBaptiste Daroussin }; 2130c8de5b0SBaptiste Daroussin static const YYINT inherit2_stos[] = { 0, 214*c5b5d71aSJung-uk Kim 257, 258, 259, 260, 263, 266, 267, 267, 265, 270, 215*c5b5d71aSJung-uk Kim 268, 269, 269, 261, 264, 264, 261, 2160c8de5b0SBaptiste Daroussin }; 2170c8de5b0SBaptiste Daroussin static const YYINT inherit2_dgoto[] = { 5, 218*c5b5d71aSJung-uk Kim 15, 9, 6, 7, 11, 12, 10, 2190c8de5b0SBaptiste Daroussin }; 2200c8de5b0SBaptiste Daroussin static const YYINT inherit2_sindex[] = { -257, 2210c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, -255, 0, 0, 0, 0, 222*c5b5d71aSJung-uk Kim 0, -254, -254, 0, -253, -253, 0, 2230c8de5b0SBaptiste Daroussin }; 2240c8de5b0SBaptiste Daroussin static const YYINT inherit2_rindex[] = { 0, 2250c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 226*c5b5d71aSJung-uk Kim 0, 0, 0, 0, 6, 9, 0, 2270c8de5b0SBaptiste Daroussin }; 2280c8de5b0SBaptiste Daroussin #if YYBTYACC 2290c8de5b0SBaptiste Daroussin static const YYINT inherit2_cindex[] = { 0, 2300c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 231*c5b5d71aSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 2320c8de5b0SBaptiste Daroussin }; 2330c8de5b0SBaptiste Daroussin #endif 2340c8de5b0SBaptiste Daroussin static const YYINT inherit2_gindex[] = { 0, 235*c5b5d71aSJung-uk Kim -3, 0, 0, 5, 0, 1, 0, 2360c8de5b0SBaptiste Daroussin }; 237*c5b5d71aSJung-uk Kim #define YYTABLESIZE 12 2380c8de5b0SBaptiste Daroussin static const YYINT inherit2_table[] = { 1, 239*c5b5d71aSJung-uk Kim 2, 3, 4, 3, 4, 12, 14, 17, 3, 16, 240*c5b5d71aSJung-uk Kim 8, 13, 2410c8de5b0SBaptiste Daroussin }; 2420c8de5b0SBaptiste Daroussin static const YYINT inherit2_check[] = { 257, 243*c5b5d71aSJung-uk Kim 258, 259, 260, 259, 260, 0, 261, 261, 0, 13, 244*c5b5d71aSJung-uk Kim 6, 11, 2450c8de5b0SBaptiste Daroussin }; 24611fce282SBaptiste Daroussin #if YYBTYACC 24711fce282SBaptiste Daroussin static const YYINT inherit2_ctable[] = { -1, 24811fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 249*c5b5d71aSJung-uk Kim -1, 25011fce282SBaptiste Daroussin }; 25111fce282SBaptiste Daroussin #endif 2520c8de5b0SBaptiste Daroussin #define YYFINAL 5 2530c8de5b0SBaptiste Daroussin #ifndef YYDEBUG 2540c8de5b0SBaptiste Daroussin #define YYDEBUG 0 2550c8de5b0SBaptiste Daroussin #endif 2560c8de5b0SBaptiste Daroussin #define YYMAXTOKEN 261 257*c5b5d71aSJung-uk Kim #define YYUNDFTOKEN 271 2580c8de5b0SBaptiste Daroussin #define YYTRANSLATE(a) ((a) > YYMAXTOKEN ? YYUNDFTOKEN : (a)) 2590c8de5b0SBaptiste Daroussin #if YYDEBUG 2600c8de5b0SBaptiste Daroussin static const char *const inherit2_name[] = { 2610c8de5b0SBaptiste Daroussin 2620c8de5b0SBaptiste 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, 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,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 2650c8de5b0SBaptiste 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, 2660c8de5b0SBaptiste 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, 2670c8de5b0SBaptiste 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, 2680c8de5b0SBaptiste 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", 2690c8de5b0SBaptiste Daroussin "NAME","$accept","declaration","namelist","locnamelist","class","type","$$1", 270*c5b5d71aSJung-uk Kim "$$2","$$3","illegal-symbol", 2710c8de5b0SBaptiste Daroussin }; 2720c8de5b0SBaptiste Daroussin static const char *const inherit2_rule[] = { 2730c8de5b0SBaptiste Daroussin "$accept : declaration", 2740c8de5b0SBaptiste Daroussin "$$1 :", 2750c8de5b0SBaptiste Daroussin "$$2 :", 2760c8de5b0SBaptiste Daroussin "declaration : class type $$1 $$2 namelist", 277*c5b5d71aSJung-uk Kim "declaration : type locnamelist", 2780c8de5b0SBaptiste Daroussin "class : GLOBAL", 2790c8de5b0SBaptiste Daroussin "class : LOCAL", 2800c8de5b0SBaptiste Daroussin "type : REAL", 2810c8de5b0SBaptiste Daroussin "type : INTEGER", 2820c8de5b0SBaptiste Daroussin "namelist : namelist NAME", 2830c8de5b0SBaptiste Daroussin "namelist : NAME", 284*c5b5d71aSJung-uk Kim "$$3 :", 285*c5b5d71aSJung-uk Kim "locnamelist : $$3 $$2 namelist", 2860c8de5b0SBaptiste Daroussin 2870c8de5b0SBaptiste Daroussin }; 2880c8de5b0SBaptiste Daroussin #endif 2890c8de5b0SBaptiste Daroussin 2900c8de5b0SBaptiste Daroussin int yydebug; 2910c8de5b0SBaptiste Daroussin int yynerrs; 2920c8de5b0SBaptiste Daroussin 2930c8de5b0SBaptiste Daroussin int yyerrflag; 2940c8de5b0SBaptiste Daroussin int yychar; 2950c8de5b0SBaptiste Daroussin YYSTYPE yyval; 2960c8de5b0SBaptiste Daroussin YYSTYPE yylval; 2970c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 2980c8de5b0SBaptiste Daroussin YYLTYPE yyloc; /* position returned by actions */ 2990c8de5b0SBaptiste Daroussin YYLTYPE yylloc; /* position from the lexer */ 3000c8de5b0SBaptiste Daroussin #endif 3010c8de5b0SBaptiste Daroussin 3020c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 3030c8de5b0SBaptiste Daroussin #ifndef YYLLOC_DEFAULT 3040c8de5b0SBaptiste Daroussin #define YYLLOC_DEFAULT(loc, rhs, n) \ 3050c8de5b0SBaptiste Daroussin do \ 3060c8de5b0SBaptiste Daroussin { \ 3070c8de5b0SBaptiste Daroussin if (n == 0) \ 3080c8de5b0SBaptiste Daroussin { \ 3090c8de5b0SBaptiste Daroussin (loc).first_line = ((rhs)[-1]).last_line; \ 3100c8de5b0SBaptiste Daroussin (loc).first_column = ((rhs)[-1]).last_column; \ 3110c8de5b0SBaptiste Daroussin (loc).last_line = ((rhs)[-1]).last_line; \ 3120c8de5b0SBaptiste Daroussin (loc).last_column = ((rhs)[-1]).last_column; \ 3130c8de5b0SBaptiste Daroussin } \ 3140c8de5b0SBaptiste Daroussin else \ 3150c8de5b0SBaptiste Daroussin { \ 3160c8de5b0SBaptiste Daroussin (loc).first_line = ((rhs)[ 0 ]).first_line; \ 3170c8de5b0SBaptiste Daroussin (loc).first_column = ((rhs)[ 0 ]).first_column; \ 3180c8de5b0SBaptiste Daroussin (loc).last_line = ((rhs)[n-1]).last_line; \ 3190c8de5b0SBaptiste Daroussin (loc).last_column = ((rhs)[n-1]).last_column; \ 3200c8de5b0SBaptiste Daroussin } \ 3210c8de5b0SBaptiste Daroussin } while (0) 3220c8de5b0SBaptiste Daroussin #endif /* YYLLOC_DEFAULT */ 3230c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 3240c8de5b0SBaptiste Daroussin #if YYBTYACC 3250c8de5b0SBaptiste Daroussin 3260c8de5b0SBaptiste Daroussin #ifndef YYLVQUEUEGROWTH 3270c8de5b0SBaptiste Daroussin #define YYLVQUEUEGROWTH 32 3280c8de5b0SBaptiste Daroussin #endif 3290c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 3300c8de5b0SBaptiste Daroussin 3310c8de5b0SBaptiste Daroussin /* define the initial stack-sizes */ 3320c8de5b0SBaptiste Daroussin #ifdef YYSTACKSIZE 3330c8de5b0SBaptiste Daroussin #undef YYMAXDEPTH 3340c8de5b0SBaptiste Daroussin #define YYMAXDEPTH YYSTACKSIZE 3350c8de5b0SBaptiste Daroussin #else 3360c8de5b0SBaptiste Daroussin #ifdef YYMAXDEPTH 3370c8de5b0SBaptiste Daroussin #define YYSTACKSIZE YYMAXDEPTH 3380c8de5b0SBaptiste Daroussin #else 3390c8de5b0SBaptiste Daroussin #define YYSTACKSIZE 10000 3400c8de5b0SBaptiste Daroussin #define YYMAXDEPTH 10000 3410c8de5b0SBaptiste Daroussin #endif 3420c8de5b0SBaptiste Daroussin #endif 3430c8de5b0SBaptiste Daroussin 3440c8de5b0SBaptiste Daroussin #ifndef YYINITSTACKSIZE 3450c8de5b0SBaptiste Daroussin #define YYINITSTACKSIZE 200 3460c8de5b0SBaptiste Daroussin #endif 3470c8de5b0SBaptiste Daroussin 3480c8de5b0SBaptiste Daroussin typedef struct { 3490c8de5b0SBaptiste Daroussin unsigned stacksize; 350*c5b5d71aSJung-uk Kim YYINT *s_base; 351*c5b5d71aSJung-uk Kim YYINT *s_mark; 352*c5b5d71aSJung-uk Kim YYINT *s_last; 3530c8de5b0SBaptiste Daroussin YYSTYPE *l_base; 3540c8de5b0SBaptiste Daroussin YYSTYPE *l_mark; 3550c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 3560c8de5b0SBaptiste Daroussin YYLTYPE *p_base; 3570c8de5b0SBaptiste Daroussin YYLTYPE *p_mark; 3580c8de5b0SBaptiste Daroussin #endif 3590c8de5b0SBaptiste Daroussin } YYSTACKDATA; 3600c8de5b0SBaptiste Daroussin #if YYBTYACC 3610c8de5b0SBaptiste Daroussin 3620c8de5b0SBaptiste Daroussin struct YYParseState_s 3630c8de5b0SBaptiste Daroussin { 3640c8de5b0SBaptiste Daroussin struct YYParseState_s *save; /* Previously saved parser state */ 3650c8de5b0SBaptiste Daroussin YYSTACKDATA yystack; /* saved parser stack */ 3660c8de5b0SBaptiste Daroussin int state; /* saved parser state */ 3670c8de5b0SBaptiste Daroussin int errflag; /* saved error recovery status */ 3680c8de5b0SBaptiste Daroussin int lexeme; /* saved index of the conflict lexeme in the lexical queue */ 3690c8de5b0SBaptiste Daroussin YYINT ctry; /* saved index in yyctable[] for this conflict */ 3700c8de5b0SBaptiste Daroussin }; 3710c8de5b0SBaptiste Daroussin typedef struct YYParseState_s YYParseState; 3720c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 3730c8de5b0SBaptiste Daroussin /* variables for the parser stack */ 3740c8de5b0SBaptiste Daroussin static YYSTACKDATA yystack; 3750c8de5b0SBaptiste Daroussin #if YYBTYACC 3760c8de5b0SBaptiste Daroussin 3770c8de5b0SBaptiste Daroussin /* Current parser state */ 3780c8de5b0SBaptiste Daroussin static YYParseState *yyps = 0; 3790c8de5b0SBaptiste Daroussin 3800c8de5b0SBaptiste Daroussin /* yypath != NULL: do the full parse, starting at *yypath parser state. */ 3810c8de5b0SBaptiste Daroussin static YYParseState *yypath = 0; 3820c8de5b0SBaptiste Daroussin 3830c8de5b0SBaptiste Daroussin /* Base of the lexical value queue */ 3840c8de5b0SBaptiste Daroussin static YYSTYPE *yylvals = 0; 3850c8de5b0SBaptiste Daroussin 3860c8de5b0SBaptiste Daroussin /* Current position at lexical value queue */ 3870c8de5b0SBaptiste Daroussin static YYSTYPE *yylvp = 0; 3880c8de5b0SBaptiste Daroussin 3890c8de5b0SBaptiste Daroussin /* End position of lexical value queue */ 3900c8de5b0SBaptiste Daroussin static YYSTYPE *yylve = 0; 3910c8de5b0SBaptiste Daroussin 3920c8de5b0SBaptiste Daroussin /* The last allocated position at the lexical value queue */ 3930c8de5b0SBaptiste Daroussin static YYSTYPE *yylvlim = 0; 3940c8de5b0SBaptiste Daroussin 3950c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 3960c8de5b0SBaptiste Daroussin /* Base of the lexical position queue */ 3970c8de5b0SBaptiste Daroussin static YYLTYPE *yylpsns = 0; 3980c8de5b0SBaptiste Daroussin 3990c8de5b0SBaptiste Daroussin /* Current position at lexical position queue */ 4000c8de5b0SBaptiste Daroussin static YYLTYPE *yylpp = 0; 4010c8de5b0SBaptiste Daroussin 4020c8de5b0SBaptiste Daroussin /* End position of lexical position queue */ 4030c8de5b0SBaptiste Daroussin static YYLTYPE *yylpe = 0; 4040c8de5b0SBaptiste Daroussin 4050c8de5b0SBaptiste Daroussin /* The last allocated position at the lexical position queue */ 4060c8de5b0SBaptiste Daroussin static YYLTYPE *yylplim = 0; 4070c8de5b0SBaptiste Daroussin #endif 4080c8de5b0SBaptiste Daroussin 4090c8de5b0SBaptiste Daroussin /* Current position at lexical token queue */ 4100c8de5b0SBaptiste Daroussin static short *yylexp = 0; 4110c8de5b0SBaptiste Daroussin 4120c8de5b0SBaptiste Daroussin static short *yylexemes = 0; 4130c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 4140c8de5b0SBaptiste Daroussin #line 78 "inherit2.y" 4150c8de5b0SBaptiste Daroussin 4160c8de5b0SBaptiste Daroussin extern int YYLEX_DECL(); 4170c8de5b0SBaptiste Daroussin extern void YYERROR_DECL(); 418*c5b5d71aSJung-uk Kim #line 419 "inherit2.tab.c" 4190c8de5b0SBaptiste Daroussin 4200c8de5b0SBaptiste Daroussin /* Release memory associated with symbol. */ 4210c8de5b0SBaptiste Daroussin #if ! defined YYDESTRUCT_IS_DECLARED 4220c8de5b0SBaptiste Daroussin static void 4230c8de5b0SBaptiste Daroussin YYDESTRUCT_DECL() 4240c8de5b0SBaptiste Daroussin { 4250c8de5b0SBaptiste Daroussin switch (psymb) 4260c8de5b0SBaptiste Daroussin { 4270c8de5b0SBaptiste Daroussin case 263: 4280c8de5b0SBaptiste Daroussin #line 30 "inherit2.y" 4290c8de5b0SBaptiste Daroussin { 4300c8de5b0SBaptiste Daroussin namelist *p = (*val).nlist; 4310c8de5b0SBaptiste Daroussin while (p != NULL) 4320c8de5b0SBaptiste Daroussin { namelist *pp = p; 4330c8de5b0SBaptiste Daroussin p = p->next; 4340c8de5b0SBaptiste Daroussin free(pp->s); free(pp); 4350c8de5b0SBaptiste Daroussin } 4360c8de5b0SBaptiste Daroussin } 4370c8de5b0SBaptiste Daroussin break; 438*c5b5d71aSJung-uk Kim #line 439 "inherit2.tab.c" 4390c8de5b0SBaptiste Daroussin case 264: 4400c8de5b0SBaptiste Daroussin #line 30 "inherit2.y" 4410c8de5b0SBaptiste Daroussin { 4420c8de5b0SBaptiste Daroussin namelist *p = (*val).nlist; 4430c8de5b0SBaptiste Daroussin while (p != NULL) 4440c8de5b0SBaptiste Daroussin { namelist *pp = p; 4450c8de5b0SBaptiste Daroussin p = p->next; 4460c8de5b0SBaptiste Daroussin free(pp->s); free(pp); 4470c8de5b0SBaptiste Daroussin } 4480c8de5b0SBaptiste Daroussin } 4490c8de5b0SBaptiste Daroussin break; 450*c5b5d71aSJung-uk Kim #line 451 "inherit2.tab.c" 4510c8de5b0SBaptiste Daroussin case 265: 4520c8de5b0SBaptiste Daroussin #line 30 "inherit2.y" 4530c8de5b0SBaptiste Daroussin { 4540c8de5b0SBaptiste Daroussin namelist *p = (*val).nlist; 4550c8de5b0SBaptiste Daroussin while (p != NULL) 4560c8de5b0SBaptiste Daroussin { namelist *pp = p; 4570c8de5b0SBaptiste Daroussin p = p->next; 4580c8de5b0SBaptiste Daroussin free(pp->s); free(pp); 4590c8de5b0SBaptiste Daroussin } 4600c8de5b0SBaptiste Daroussin } 4610c8de5b0SBaptiste Daroussin break; 462*c5b5d71aSJung-uk Kim #line 463 "inherit2.tab.c" 4630c8de5b0SBaptiste Daroussin } 4640c8de5b0SBaptiste Daroussin } 4650c8de5b0SBaptiste Daroussin #define YYDESTRUCT_IS_DECLARED 1 4660c8de5b0SBaptiste Daroussin #endif 4670c8de5b0SBaptiste Daroussin 4680c8de5b0SBaptiste Daroussin /* For use in generated program */ 4690c8de5b0SBaptiste Daroussin #define yydepth (int)(yystack.s_mark - yystack.s_base) 4700c8de5b0SBaptiste Daroussin #if YYBTYACC 4710c8de5b0SBaptiste Daroussin #define yytrial (yyps->save) 4720c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 4730c8de5b0SBaptiste Daroussin 4740c8de5b0SBaptiste Daroussin #if YYDEBUG 4750c8de5b0SBaptiste Daroussin #include <stdio.h> /* needed for printf */ 4760c8de5b0SBaptiste Daroussin #endif 4770c8de5b0SBaptiste Daroussin 4780c8de5b0SBaptiste Daroussin #include <stdlib.h> /* needed for malloc, etc */ 4790c8de5b0SBaptiste Daroussin #include <string.h> /* needed for memset */ 4800c8de5b0SBaptiste Daroussin 4810c8de5b0SBaptiste Daroussin /* allocate initial stack or double stack size, up to YYMAXDEPTH */ 4820c8de5b0SBaptiste Daroussin static int yygrowstack(YYSTACKDATA *data) 4830c8de5b0SBaptiste Daroussin { 4840c8de5b0SBaptiste Daroussin int i; 4850c8de5b0SBaptiste Daroussin unsigned newsize; 486*c5b5d71aSJung-uk Kim YYINT *newss; 4870c8de5b0SBaptiste Daroussin YYSTYPE *newvs; 4880c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 4890c8de5b0SBaptiste Daroussin YYLTYPE *newps; 4900c8de5b0SBaptiste Daroussin #endif 4910c8de5b0SBaptiste Daroussin 4920c8de5b0SBaptiste Daroussin if ((newsize = data->stacksize) == 0) 4930c8de5b0SBaptiste Daroussin newsize = YYINITSTACKSIZE; 4940c8de5b0SBaptiste Daroussin else if (newsize >= YYMAXDEPTH) 4950c8de5b0SBaptiste Daroussin return YYENOMEM; 4960c8de5b0SBaptiste Daroussin else if ((newsize *= 2) > YYMAXDEPTH) 4970c8de5b0SBaptiste Daroussin newsize = YYMAXDEPTH; 4980c8de5b0SBaptiste Daroussin 4990c8de5b0SBaptiste Daroussin i = (int) (data->s_mark - data->s_base); 500*c5b5d71aSJung-uk Kim newss = (YYINT *)realloc(data->s_base, newsize * sizeof(*newss)); 5010c8de5b0SBaptiste Daroussin if (newss == 0) 5020c8de5b0SBaptiste Daroussin return YYENOMEM; 5030c8de5b0SBaptiste Daroussin 5040c8de5b0SBaptiste Daroussin data->s_base = newss; 5050c8de5b0SBaptiste Daroussin data->s_mark = newss + i; 5060c8de5b0SBaptiste Daroussin 5070c8de5b0SBaptiste Daroussin newvs = (YYSTYPE *)realloc(data->l_base, newsize * sizeof(*newvs)); 5080c8de5b0SBaptiste Daroussin if (newvs == 0) 5090c8de5b0SBaptiste Daroussin return YYENOMEM; 5100c8de5b0SBaptiste Daroussin 5110c8de5b0SBaptiste Daroussin data->l_base = newvs; 5120c8de5b0SBaptiste Daroussin data->l_mark = newvs + i; 5130c8de5b0SBaptiste Daroussin 5140c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 5150c8de5b0SBaptiste Daroussin newps = (YYLTYPE *)realloc(data->p_base, newsize * sizeof(*newps)); 5160c8de5b0SBaptiste Daroussin if (newps == 0) 5170c8de5b0SBaptiste Daroussin return YYENOMEM; 5180c8de5b0SBaptiste Daroussin 5190c8de5b0SBaptiste Daroussin data->p_base = newps; 5200c8de5b0SBaptiste Daroussin data->p_mark = newps + i; 5210c8de5b0SBaptiste Daroussin #endif 5220c8de5b0SBaptiste Daroussin 5230c8de5b0SBaptiste Daroussin data->stacksize = newsize; 5240c8de5b0SBaptiste Daroussin data->s_last = data->s_base + newsize - 1; 5250c8de5b0SBaptiste Daroussin 5260c8de5b0SBaptiste Daroussin #if YYDEBUG 5270c8de5b0SBaptiste Daroussin if (yydebug) 5280c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug: stack size increased to %d\n", YYPREFIX, newsize); 5290c8de5b0SBaptiste Daroussin #endif 5300c8de5b0SBaptiste Daroussin return 0; 5310c8de5b0SBaptiste Daroussin } 5320c8de5b0SBaptiste Daroussin 5330c8de5b0SBaptiste Daroussin #if YYPURE || defined(YY_NO_LEAKS) 5340c8de5b0SBaptiste Daroussin static void yyfreestack(YYSTACKDATA *data) 5350c8de5b0SBaptiste Daroussin { 5360c8de5b0SBaptiste Daroussin free(data->s_base); 5370c8de5b0SBaptiste Daroussin free(data->l_base); 5380c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 5390c8de5b0SBaptiste Daroussin free(data->p_base); 5400c8de5b0SBaptiste Daroussin #endif 5410c8de5b0SBaptiste Daroussin memset(data, 0, sizeof(*data)); 5420c8de5b0SBaptiste Daroussin } 5430c8de5b0SBaptiste Daroussin #else 5440c8de5b0SBaptiste Daroussin #define yyfreestack(data) /* nothing */ 5450c8de5b0SBaptiste Daroussin #endif /* YYPURE || defined(YY_NO_LEAKS) */ 5460c8de5b0SBaptiste Daroussin #if YYBTYACC 5470c8de5b0SBaptiste Daroussin 5480c8de5b0SBaptiste Daroussin static YYParseState * 5490c8de5b0SBaptiste Daroussin yyNewState(unsigned size) 5500c8de5b0SBaptiste Daroussin { 5510c8de5b0SBaptiste Daroussin YYParseState *p = (YYParseState *) malloc(sizeof(YYParseState)); 5520c8de5b0SBaptiste Daroussin if (p == NULL) return NULL; 5530c8de5b0SBaptiste Daroussin 5540c8de5b0SBaptiste Daroussin p->yystack.stacksize = size; 5550c8de5b0SBaptiste Daroussin if (size == 0) 5560c8de5b0SBaptiste Daroussin { 5570c8de5b0SBaptiste Daroussin p->yystack.s_base = NULL; 5580c8de5b0SBaptiste Daroussin p->yystack.l_base = NULL; 5590c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 5600c8de5b0SBaptiste Daroussin p->yystack.p_base = NULL; 5610c8de5b0SBaptiste Daroussin #endif 5620c8de5b0SBaptiste Daroussin return p; 5630c8de5b0SBaptiste Daroussin } 564*c5b5d71aSJung-uk Kim p->yystack.s_base = (YYINT *) malloc(size * sizeof(YYINT)); 5650c8de5b0SBaptiste Daroussin if (p->yystack.s_base == NULL) return NULL; 5660c8de5b0SBaptiste Daroussin p->yystack.l_base = (YYSTYPE *) malloc(size * sizeof(YYSTYPE)); 5670c8de5b0SBaptiste Daroussin if (p->yystack.l_base == NULL) return NULL; 5680c8de5b0SBaptiste Daroussin memset(p->yystack.l_base, 0, size * sizeof(YYSTYPE)); 5690c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 5700c8de5b0SBaptiste Daroussin p->yystack.p_base = (YYLTYPE *) malloc(size * sizeof(YYLTYPE)); 5710c8de5b0SBaptiste Daroussin if (p->yystack.p_base == NULL) return NULL; 5720c8de5b0SBaptiste Daroussin memset(p->yystack.p_base, 0, size * sizeof(YYLTYPE)); 5730c8de5b0SBaptiste Daroussin #endif 5740c8de5b0SBaptiste Daroussin 5750c8de5b0SBaptiste Daroussin return p; 5760c8de5b0SBaptiste Daroussin } 5770c8de5b0SBaptiste Daroussin 5780c8de5b0SBaptiste Daroussin static void 5790c8de5b0SBaptiste Daroussin yyFreeState(YYParseState *p) 5800c8de5b0SBaptiste Daroussin { 5810c8de5b0SBaptiste Daroussin yyfreestack(&p->yystack); 5820c8de5b0SBaptiste Daroussin free(p); 5830c8de5b0SBaptiste Daroussin } 5840c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 5850c8de5b0SBaptiste Daroussin 5860c8de5b0SBaptiste Daroussin #define YYABORT goto yyabort 5870c8de5b0SBaptiste Daroussin #define YYREJECT goto yyabort 5880c8de5b0SBaptiste Daroussin #define YYACCEPT goto yyaccept 5890c8de5b0SBaptiste Daroussin #define YYERROR goto yyerrlab 5900c8de5b0SBaptiste Daroussin #if YYBTYACC 5910c8de5b0SBaptiste Daroussin #define YYVALID do { if (yyps->save) goto yyvalid; } while(0) 5920c8de5b0SBaptiste Daroussin #define YYVALID_NESTED do { if (yyps->save && \ 5930c8de5b0SBaptiste Daroussin yyps->save->save == 0) goto yyvalid; } while(0) 5940c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 5950c8de5b0SBaptiste Daroussin 5960c8de5b0SBaptiste Daroussin int 5970c8de5b0SBaptiste Daroussin YYPARSE_DECL() 5980c8de5b0SBaptiste Daroussin { 5990c8de5b0SBaptiste Daroussin int yym, yyn, yystate, yyresult; 6000c8de5b0SBaptiste Daroussin #if YYBTYACC 6010c8de5b0SBaptiste Daroussin int yynewerrflag; 6020c8de5b0SBaptiste Daroussin YYParseState *yyerrctx = NULL; 6030c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 6040c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6050c8de5b0SBaptiste Daroussin YYLTYPE yyerror_loc_range[2]; /* position of error start & end */ 6060c8de5b0SBaptiste Daroussin #endif 6070c8de5b0SBaptiste Daroussin #if YYDEBUG 6080c8de5b0SBaptiste Daroussin const char *yys; 6090c8de5b0SBaptiste Daroussin 6100c8de5b0SBaptiste Daroussin if ((yys = getenv("YYDEBUG")) != 0) 6110c8de5b0SBaptiste Daroussin { 6120c8de5b0SBaptiste Daroussin yyn = *yys; 6130c8de5b0SBaptiste Daroussin if (yyn >= '0' && yyn <= '9') 6140c8de5b0SBaptiste Daroussin yydebug = yyn - '0'; 6150c8de5b0SBaptiste Daroussin } 6160c8de5b0SBaptiste Daroussin if (yydebug) 6170c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug[<# of symbols on state stack>]\n", YYPREFIX); 6180c8de5b0SBaptiste Daroussin #endif 6190c8de5b0SBaptiste Daroussin 6200c8de5b0SBaptiste Daroussin #if YYBTYACC 6210c8de5b0SBaptiste Daroussin yyps = yyNewState(0); if (yyps == 0) goto yyenomem; 6220c8de5b0SBaptiste Daroussin yyps->save = 0; 6230c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 624*c5b5d71aSJung-uk Kim yym = 0; 625*c5b5d71aSJung-uk Kim yyn = 0; 6260c8de5b0SBaptiste Daroussin yynerrs = 0; 6270c8de5b0SBaptiste Daroussin yyerrflag = 0; 6280c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 6290c8de5b0SBaptiste Daroussin yystate = 0; 6300c8de5b0SBaptiste Daroussin 6310c8de5b0SBaptiste Daroussin #if YYPURE 6320c8de5b0SBaptiste Daroussin memset(&yystack, 0, sizeof(yystack)); 6330c8de5b0SBaptiste Daroussin #endif 6340c8de5b0SBaptiste Daroussin 6350c8de5b0SBaptiste Daroussin if (yystack.s_base == NULL && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 6360c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base; 6370c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base; 6380c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6390c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base; 6400c8de5b0SBaptiste Daroussin #endif 6410c8de5b0SBaptiste Daroussin yystate = 0; 6420c8de5b0SBaptiste Daroussin *yystack.s_mark = 0; 6430c8de5b0SBaptiste Daroussin 6440c8de5b0SBaptiste Daroussin yyloop: 6450c8de5b0SBaptiste Daroussin if ((yyn = yydefred[yystate]) != 0) goto yyreduce; 6460c8de5b0SBaptiste Daroussin if (yychar < 0) 6470c8de5b0SBaptiste Daroussin { 6480c8de5b0SBaptiste Daroussin #if YYBTYACC 6490c8de5b0SBaptiste Daroussin do { 6500c8de5b0SBaptiste Daroussin if (yylvp < yylve) 6510c8de5b0SBaptiste Daroussin { 6520c8de5b0SBaptiste Daroussin /* we're currently re-reading tokens */ 6530c8de5b0SBaptiste Daroussin yylval = *yylvp++; 6540c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6550c8de5b0SBaptiste Daroussin yylloc = *yylpp++; 6560c8de5b0SBaptiste Daroussin #endif 6570c8de5b0SBaptiste Daroussin yychar = *yylexp++; 6580c8de5b0SBaptiste Daroussin break; 6590c8de5b0SBaptiste Daroussin } 6600c8de5b0SBaptiste Daroussin if (yyps->save) 6610c8de5b0SBaptiste Daroussin { 6620c8de5b0SBaptiste Daroussin /* in trial mode; save scanner results for future parse attempts */ 6630c8de5b0SBaptiste Daroussin if (yylvp == yylvlim) 6640c8de5b0SBaptiste Daroussin { /* Enlarge lexical value queue */ 66511fce282SBaptiste Daroussin size_t p = (size_t) (yylvp - yylvals); 66611fce282SBaptiste Daroussin size_t s = (size_t) (yylvlim - yylvals); 6670c8de5b0SBaptiste Daroussin 6680c8de5b0SBaptiste Daroussin s += YYLVQUEUEGROWTH; 6690c8de5b0SBaptiste Daroussin if ((yylexemes = (short *) realloc(yylexemes, s * sizeof(short))) == NULL) goto yyenomem; 6700c8de5b0SBaptiste Daroussin if ((yylvals = (YYSTYPE *) realloc(yylvals, s * sizeof(YYSTYPE))) == NULL) goto yyenomem; 6710c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6720c8de5b0SBaptiste Daroussin if ((yylpsns = (YYLTYPE *) realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL) goto yyenomem; 6730c8de5b0SBaptiste Daroussin #endif 6740c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals + p; 6750c8de5b0SBaptiste Daroussin yylvlim = yylvals + s; 6760c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6770c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns + p; 6780c8de5b0SBaptiste Daroussin yylplim = yylpsns + s; 6790c8de5b0SBaptiste Daroussin #endif 6800c8de5b0SBaptiste Daroussin yylexp = yylexemes + p; 6810c8de5b0SBaptiste Daroussin } 6820c8de5b0SBaptiste Daroussin *yylexp = (short) YYLEX; 6830c8de5b0SBaptiste Daroussin *yylvp++ = yylval; 6840c8de5b0SBaptiste Daroussin yylve++; 6850c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6860c8de5b0SBaptiste Daroussin *yylpp++ = yylloc; 6870c8de5b0SBaptiste Daroussin yylpe++; 6880c8de5b0SBaptiste Daroussin #endif 6890c8de5b0SBaptiste Daroussin yychar = *yylexp++; 6900c8de5b0SBaptiste Daroussin break; 6910c8de5b0SBaptiste Daroussin } 6920c8de5b0SBaptiste Daroussin /* normal operation, no conflict encountered */ 6930c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 6940c8de5b0SBaptiste Daroussin yychar = YYLEX; 6950c8de5b0SBaptiste Daroussin #if YYBTYACC 6960c8de5b0SBaptiste Daroussin } while (0); 6970c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 6980c8de5b0SBaptiste Daroussin if (yychar < 0) yychar = YYEOF; 6990c8de5b0SBaptiste Daroussin #if YYDEBUG 7000c8de5b0SBaptiste Daroussin if (yydebug) 7010c8de5b0SBaptiste Daroussin { 702*c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 7030c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)", 7040c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yychar, yys); 7050c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING 7060c8de5b0SBaptiste Daroussin #if YYBTYACC 7070c8de5b0SBaptiste Daroussin if (!yytrial) 7080c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 7090c8de5b0SBaptiste Daroussin fprintf(stderr, " <%s>", YYSTYPE_TOSTRING(yychar, yylval)); 7100c8de5b0SBaptiste Daroussin #endif 7110c8de5b0SBaptiste Daroussin fputc('\n', stderr); 7120c8de5b0SBaptiste Daroussin } 7130c8de5b0SBaptiste Daroussin #endif 7140c8de5b0SBaptiste Daroussin } 7150c8de5b0SBaptiste Daroussin #if YYBTYACC 7160c8de5b0SBaptiste Daroussin 7170c8de5b0SBaptiste Daroussin /* Do we have a conflict? */ 7180c8de5b0SBaptiste Daroussin if (((yyn = yycindex[yystate]) != 0) && (yyn += yychar) >= 0 && 7190c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 7200c8de5b0SBaptiste Daroussin { 7210c8de5b0SBaptiste Daroussin YYINT ctry; 7220c8de5b0SBaptiste Daroussin 7230c8de5b0SBaptiste Daroussin if (yypath) 7240c8de5b0SBaptiste Daroussin { 7250c8de5b0SBaptiste Daroussin YYParseState *save; 7260c8de5b0SBaptiste Daroussin #if YYDEBUG 7270c8de5b0SBaptiste Daroussin if (yydebug) 7280c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: CONFLICT in state %d: following successful trial parse\n", 7290c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate); 7300c8de5b0SBaptiste Daroussin #endif 7310c8de5b0SBaptiste Daroussin /* Switch to the next conflict context */ 7320c8de5b0SBaptiste Daroussin save = yypath; 7330c8de5b0SBaptiste Daroussin yypath = save->save; 7340c8de5b0SBaptiste Daroussin save->save = NULL; 7350c8de5b0SBaptiste Daroussin ctry = save->ctry; 7360c8de5b0SBaptiste Daroussin if (save->state != yystate) YYABORT; 7370c8de5b0SBaptiste Daroussin yyFreeState(save); 7380c8de5b0SBaptiste Daroussin 7390c8de5b0SBaptiste Daroussin } 7400c8de5b0SBaptiste Daroussin else 7410c8de5b0SBaptiste Daroussin { 7420c8de5b0SBaptiste Daroussin 7430c8de5b0SBaptiste Daroussin /* Unresolved conflict - start/continue trial parse */ 7440c8de5b0SBaptiste Daroussin YYParseState *save; 7450c8de5b0SBaptiste Daroussin #if YYDEBUG 7460c8de5b0SBaptiste Daroussin if (yydebug) 7470c8de5b0SBaptiste Daroussin { 7480c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: CONFLICT in state %d. ", YYDEBUGSTR, yydepth, yystate); 7490c8de5b0SBaptiste Daroussin if (yyps->save) 7500c8de5b0SBaptiste Daroussin fputs("ALREADY in conflict, continuing trial parse.\n", stderr); 7510c8de5b0SBaptiste Daroussin else 7520c8de5b0SBaptiste Daroussin fputs("Starting trial parse.\n", stderr); 7530c8de5b0SBaptiste Daroussin } 7540c8de5b0SBaptiste Daroussin #endif 7550c8de5b0SBaptiste Daroussin save = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1)); 7560c8de5b0SBaptiste Daroussin if (save == NULL) goto yyenomem; 7570c8de5b0SBaptiste Daroussin save->save = yyps->save; 7580c8de5b0SBaptiste Daroussin save->state = yystate; 7590c8de5b0SBaptiste Daroussin save->errflag = yyerrflag; 7600c8de5b0SBaptiste Daroussin save->yystack.s_mark = save->yystack.s_base + (yystack.s_mark - yystack.s_base); 761*c5b5d71aSJung-uk Kim memcpy (save->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 7620c8de5b0SBaptiste Daroussin save->yystack.l_mark = save->yystack.l_base + (yystack.l_mark - yystack.l_base); 76311fce282SBaptiste Daroussin memcpy (save->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 7640c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7650c8de5b0SBaptiste Daroussin save->yystack.p_mark = save->yystack.p_base + (yystack.p_mark - yystack.p_base); 76611fce282SBaptiste Daroussin memcpy (save->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 7670c8de5b0SBaptiste Daroussin #endif 7680c8de5b0SBaptiste Daroussin ctry = yytable[yyn]; 7690c8de5b0SBaptiste Daroussin if (yyctable[ctry] == -1) 7700c8de5b0SBaptiste Daroussin { 7710c8de5b0SBaptiste Daroussin #if YYDEBUG 7720c8de5b0SBaptiste Daroussin if (yydebug && yychar >= YYEOF) 7730c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: backtracking 1 token\n", YYDEBUGSTR, yydepth); 7740c8de5b0SBaptiste Daroussin #endif 7750c8de5b0SBaptiste Daroussin ctry++; 7760c8de5b0SBaptiste Daroussin } 7770c8de5b0SBaptiste Daroussin save->ctry = ctry; 7780c8de5b0SBaptiste Daroussin if (yyps->save == NULL) 7790c8de5b0SBaptiste Daroussin { 7800c8de5b0SBaptiste Daroussin /* If this is a first conflict in the stack, start saving lexemes */ 7810c8de5b0SBaptiste Daroussin if (!yylexemes) 7820c8de5b0SBaptiste Daroussin { 7830c8de5b0SBaptiste Daroussin yylexemes = (short *) malloc((YYLVQUEUEGROWTH) * sizeof(short)); 7840c8de5b0SBaptiste Daroussin if (yylexemes == NULL) goto yyenomem; 7850c8de5b0SBaptiste Daroussin yylvals = (YYSTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYSTYPE)); 7860c8de5b0SBaptiste Daroussin if (yylvals == NULL) goto yyenomem; 7870c8de5b0SBaptiste Daroussin yylvlim = yylvals + YYLVQUEUEGROWTH; 7880c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7890c8de5b0SBaptiste Daroussin yylpsns = (YYLTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYLTYPE)); 7900c8de5b0SBaptiste Daroussin if (yylpsns == NULL) goto yyenomem; 7910c8de5b0SBaptiste Daroussin yylplim = yylpsns + YYLVQUEUEGROWTH; 7920c8de5b0SBaptiste Daroussin #endif 7930c8de5b0SBaptiste Daroussin } 7940c8de5b0SBaptiste Daroussin if (yylvp == yylve) 7950c8de5b0SBaptiste Daroussin { 7960c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals; 7970c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7980c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns; 7990c8de5b0SBaptiste Daroussin #endif 8000c8de5b0SBaptiste Daroussin yylexp = yylexemes; 8010c8de5b0SBaptiste Daroussin if (yychar >= YYEOF) 8020c8de5b0SBaptiste Daroussin { 8030c8de5b0SBaptiste Daroussin *yylve++ = yylval; 8040c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8050c8de5b0SBaptiste Daroussin *yylpe++ = yylloc; 8060c8de5b0SBaptiste Daroussin #endif 8070c8de5b0SBaptiste Daroussin *yylexp = (short) yychar; 8080c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 8090c8de5b0SBaptiste Daroussin } 8100c8de5b0SBaptiste Daroussin } 8110c8de5b0SBaptiste Daroussin } 8120c8de5b0SBaptiste Daroussin if (yychar >= YYEOF) 8130c8de5b0SBaptiste Daroussin { 8140c8de5b0SBaptiste Daroussin yylvp--; 8150c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8160c8de5b0SBaptiste Daroussin yylpp--; 8170c8de5b0SBaptiste Daroussin #endif 8180c8de5b0SBaptiste Daroussin yylexp--; 8190c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 8200c8de5b0SBaptiste Daroussin } 82111fce282SBaptiste Daroussin save->lexeme = (int) (yylvp - yylvals); 8220c8de5b0SBaptiste Daroussin yyps->save = save; 8230c8de5b0SBaptiste Daroussin } 8240c8de5b0SBaptiste Daroussin if (yytable[yyn] == ctry) 8250c8de5b0SBaptiste Daroussin { 8260c8de5b0SBaptiste Daroussin #if YYDEBUG 8270c8de5b0SBaptiste Daroussin if (yydebug) 8280c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n", 8290c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyctable[ctry]); 8300c8de5b0SBaptiste Daroussin #endif 8310c8de5b0SBaptiste Daroussin if (yychar < 0) 8320c8de5b0SBaptiste Daroussin { 8330c8de5b0SBaptiste Daroussin yylvp++; 8340c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8350c8de5b0SBaptiste Daroussin yylpp++; 8360c8de5b0SBaptiste Daroussin #endif 8370c8de5b0SBaptiste Daroussin yylexp++; 8380c8de5b0SBaptiste Daroussin } 8390c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) 8400c8de5b0SBaptiste Daroussin goto yyoverflow; 8410c8de5b0SBaptiste Daroussin yystate = yyctable[ctry]; 842*c5b5d71aSJung-uk Kim *++yystack.s_mark = (YYINT) yystate; 8430c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval; 8440c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8450c8de5b0SBaptiste Daroussin *++yystack.p_mark = yylloc; 8460c8de5b0SBaptiste Daroussin #endif 8470c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 8480c8de5b0SBaptiste Daroussin if (yyerrflag > 0) --yyerrflag; 8490c8de5b0SBaptiste Daroussin goto yyloop; 8500c8de5b0SBaptiste Daroussin } 8510c8de5b0SBaptiste Daroussin else 8520c8de5b0SBaptiste Daroussin { 8530c8de5b0SBaptiste Daroussin yyn = yyctable[ctry]; 8540c8de5b0SBaptiste Daroussin goto yyreduce; 8550c8de5b0SBaptiste Daroussin } 8560c8de5b0SBaptiste Daroussin } /* End of code dealing with conflicts */ 8570c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 8580c8de5b0SBaptiste Daroussin if (((yyn = yysindex[yystate]) != 0) && (yyn += yychar) >= 0 && 8590c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 8600c8de5b0SBaptiste Daroussin { 8610c8de5b0SBaptiste Daroussin #if YYDEBUG 8620c8de5b0SBaptiste Daroussin if (yydebug) 8630c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n", 8640c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yytable[yyn]); 8650c8de5b0SBaptiste Daroussin #endif 8660c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 8670c8de5b0SBaptiste Daroussin yystate = yytable[yyn]; 8680c8de5b0SBaptiste Daroussin *++yystack.s_mark = yytable[yyn]; 8690c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval; 8700c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8710c8de5b0SBaptiste Daroussin *++yystack.p_mark = yylloc; 8720c8de5b0SBaptiste Daroussin #endif 8730c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 8740c8de5b0SBaptiste Daroussin if (yyerrflag > 0) --yyerrflag; 8750c8de5b0SBaptiste Daroussin goto yyloop; 8760c8de5b0SBaptiste Daroussin } 8770c8de5b0SBaptiste Daroussin if (((yyn = yyrindex[yystate]) != 0) && (yyn += yychar) >= 0 && 8780c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 8790c8de5b0SBaptiste Daroussin { 8800c8de5b0SBaptiste Daroussin yyn = yytable[yyn]; 8810c8de5b0SBaptiste Daroussin goto yyreduce; 8820c8de5b0SBaptiste Daroussin } 8830c8de5b0SBaptiste Daroussin if (yyerrflag != 0) goto yyinrecovery; 8840c8de5b0SBaptiste Daroussin #if YYBTYACC 8850c8de5b0SBaptiste Daroussin 8860c8de5b0SBaptiste Daroussin yynewerrflag = 1; 8870c8de5b0SBaptiste Daroussin goto yyerrhandler; 888*c5b5d71aSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */ 8890c8de5b0SBaptiste Daroussin 8900c8de5b0SBaptiste Daroussin yyerrlab: 891*c5b5d71aSJung-uk Kim /* explicit YYERROR from an action -- pop the rhs of the rule reduced 892*c5b5d71aSJung-uk Kim * before looking for error recovery */ 893*c5b5d71aSJung-uk Kim yystack.s_mark -= yym; 894*c5b5d71aSJung-uk Kim yystate = *yystack.s_mark; 895*c5b5d71aSJung-uk Kim yystack.l_mark -= yym; 896*c5b5d71aSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 897*c5b5d71aSJung-uk Kim yystack.p_mark -= yym; 898*c5b5d71aSJung-uk Kim #endif 899*c5b5d71aSJung-uk Kim 9000c8de5b0SBaptiste Daroussin yynewerrflag = 0; 9010c8de5b0SBaptiste Daroussin yyerrhandler: 9020c8de5b0SBaptiste Daroussin while (yyps->save) 9030c8de5b0SBaptiste Daroussin { 9040c8de5b0SBaptiste Daroussin int ctry; 9050c8de5b0SBaptiste Daroussin YYParseState *save = yyps->save; 9060c8de5b0SBaptiste Daroussin #if YYDEBUG 9070c8de5b0SBaptiste Daroussin if (yydebug) 9080c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: ERROR in state %d, CONFLICT BACKTRACKING to state %d, %d tokens\n", 9090c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyps->save->state, 9100c8de5b0SBaptiste Daroussin (int)(yylvp - yylvals - yyps->save->lexeme)); 9110c8de5b0SBaptiste Daroussin #endif 9120c8de5b0SBaptiste Daroussin /* Memorize most forward-looking error state in case it's really an error. */ 9130c8de5b0SBaptiste Daroussin if (yyerrctx == NULL || yyerrctx->lexeme < yylvp - yylvals) 9140c8de5b0SBaptiste Daroussin { 9150c8de5b0SBaptiste Daroussin /* Free old saved error context state */ 9160c8de5b0SBaptiste Daroussin if (yyerrctx) yyFreeState(yyerrctx); 9170c8de5b0SBaptiste Daroussin /* Create and fill out new saved error context state */ 9180c8de5b0SBaptiste Daroussin yyerrctx = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1)); 9190c8de5b0SBaptiste Daroussin if (yyerrctx == NULL) goto yyenomem; 9200c8de5b0SBaptiste Daroussin yyerrctx->save = yyps->save; 9210c8de5b0SBaptiste Daroussin yyerrctx->state = yystate; 9220c8de5b0SBaptiste Daroussin yyerrctx->errflag = yyerrflag; 9230c8de5b0SBaptiste Daroussin yyerrctx->yystack.s_mark = yyerrctx->yystack.s_base + (yystack.s_mark - yystack.s_base); 924*c5b5d71aSJung-uk Kim memcpy (yyerrctx->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 9250c8de5b0SBaptiste Daroussin yyerrctx->yystack.l_mark = yyerrctx->yystack.l_base + (yystack.l_mark - yystack.l_base); 92611fce282SBaptiste Daroussin memcpy (yyerrctx->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 9270c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9280c8de5b0SBaptiste Daroussin yyerrctx->yystack.p_mark = yyerrctx->yystack.p_base + (yystack.p_mark - yystack.p_base); 92911fce282SBaptiste Daroussin memcpy (yyerrctx->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 9300c8de5b0SBaptiste Daroussin #endif 93111fce282SBaptiste Daroussin yyerrctx->lexeme = (int) (yylvp - yylvals); 9320c8de5b0SBaptiste Daroussin } 9330c8de5b0SBaptiste Daroussin yylvp = yylvals + save->lexeme; 9340c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9350c8de5b0SBaptiste Daroussin yylpp = yylpsns + save->lexeme; 9360c8de5b0SBaptiste Daroussin #endif 9370c8de5b0SBaptiste Daroussin yylexp = yylexemes + save->lexeme; 9380c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 9390c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (save->yystack.s_mark - save->yystack.s_base); 940*c5b5d71aSJung-uk Kim memcpy (yystack.s_base, save->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 9410c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (save->yystack.l_mark - save->yystack.l_base); 94211fce282SBaptiste Daroussin memcpy (yystack.l_base, save->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 9430c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9440c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (save->yystack.p_mark - save->yystack.p_base); 94511fce282SBaptiste Daroussin memcpy (yystack.p_base, save->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 9460c8de5b0SBaptiste Daroussin #endif 9470c8de5b0SBaptiste Daroussin ctry = ++save->ctry; 9480c8de5b0SBaptiste Daroussin yystate = save->state; 9490c8de5b0SBaptiste Daroussin /* We tried shift, try reduce now */ 9500c8de5b0SBaptiste Daroussin if ((yyn = yyctable[ctry]) >= 0) goto yyreduce; 9510c8de5b0SBaptiste Daroussin yyps->save = save->save; 9520c8de5b0SBaptiste Daroussin save->save = NULL; 9530c8de5b0SBaptiste Daroussin yyFreeState(save); 9540c8de5b0SBaptiste Daroussin 9550c8de5b0SBaptiste Daroussin /* Nothing left on the stack -- error */ 9560c8de5b0SBaptiste Daroussin if (!yyps->save) 9570c8de5b0SBaptiste Daroussin { 9580c8de5b0SBaptiste Daroussin #if YYDEBUG 9590c8de5b0SBaptiste Daroussin if (yydebug) 9600c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug[%d,trial]: trial parse FAILED, entering ERROR mode\n", 9610c8de5b0SBaptiste Daroussin YYPREFIX, yydepth); 9620c8de5b0SBaptiste Daroussin #endif 9630c8de5b0SBaptiste Daroussin /* Restore state as it was in the most forward-advanced error */ 9640c8de5b0SBaptiste Daroussin yylvp = yylvals + yyerrctx->lexeme; 9650c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9660c8de5b0SBaptiste Daroussin yylpp = yylpsns + yyerrctx->lexeme; 9670c8de5b0SBaptiste Daroussin #endif 9680c8de5b0SBaptiste Daroussin yylexp = yylexemes + yyerrctx->lexeme; 9690c8de5b0SBaptiste Daroussin yychar = yylexp[-1]; 9700c8de5b0SBaptiste Daroussin yylval = yylvp[-1]; 9710c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9720c8de5b0SBaptiste Daroussin yylloc = yylpp[-1]; 9730c8de5b0SBaptiste Daroussin #endif 9740c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (yyerrctx->yystack.s_mark - yyerrctx->yystack.s_base); 975*c5b5d71aSJung-uk Kim memcpy (yystack.s_base, yyerrctx->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 9760c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (yyerrctx->yystack.l_mark - yyerrctx->yystack.l_base); 97711fce282SBaptiste Daroussin memcpy (yystack.l_base, yyerrctx->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 9780c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9790c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (yyerrctx->yystack.p_mark - yyerrctx->yystack.p_base); 98011fce282SBaptiste Daroussin memcpy (yystack.p_base, yyerrctx->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 9810c8de5b0SBaptiste Daroussin #endif 9820c8de5b0SBaptiste Daroussin yystate = yyerrctx->state; 9830c8de5b0SBaptiste Daroussin yyFreeState(yyerrctx); 9840c8de5b0SBaptiste Daroussin yyerrctx = NULL; 9850c8de5b0SBaptiste Daroussin } 9860c8de5b0SBaptiste Daroussin yynewerrflag = 1; 9870c8de5b0SBaptiste Daroussin } 9880c8de5b0SBaptiste Daroussin if (yynewerrflag == 0) goto yyinrecovery; 9890c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 9900c8de5b0SBaptiste Daroussin 9910c8de5b0SBaptiste Daroussin YYERROR_CALL("syntax error"); 9920c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9930c8de5b0SBaptiste Daroussin yyerror_loc_range[0] = yylloc; /* lookahead position is error start position */ 9940c8de5b0SBaptiste Daroussin #endif 9950c8de5b0SBaptiste Daroussin 9960c8de5b0SBaptiste Daroussin #if !YYBTYACC 997*c5b5d71aSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */ 9980c8de5b0SBaptiste Daroussin yyerrlab: 9990c8de5b0SBaptiste Daroussin #endif 10000c8de5b0SBaptiste Daroussin ++yynerrs; 10010c8de5b0SBaptiste Daroussin 10020c8de5b0SBaptiste Daroussin yyinrecovery: 10030c8de5b0SBaptiste Daroussin if (yyerrflag < 3) 10040c8de5b0SBaptiste Daroussin { 10050c8de5b0SBaptiste Daroussin yyerrflag = 3; 10060c8de5b0SBaptiste Daroussin for (;;) 10070c8de5b0SBaptiste Daroussin { 10080c8de5b0SBaptiste Daroussin if (((yyn = yysindex[*yystack.s_mark]) != 0) && (yyn += YYERRCODE) >= 0 && 10090c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) YYERRCODE) 10100c8de5b0SBaptiste Daroussin { 10110c8de5b0SBaptiste Daroussin #if YYDEBUG 10120c8de5b0SBaptiste Daroussin if (yydebug) 10130c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, error recovery shifting to state %d\n", 10140c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, *yystack.s_mark, yytable[yyn]); 10150c8de5b0SBaptiste Daroussin #endif 10160c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 10170c8de5b0SBaptiste Daroussin yystate = yytable[yyn]; 10180c8de5b0SBaptiste Daroussin *++yystack.s_mark = yytable[yyn]; 10190c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval; 10200c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 10210c8de5b0SBaptiste Daroussin /* lookahead position is error end position */ 10220c8de5b0SBaptiste Daroussin yyerror_loc_range[1] = yylloc; 10230c8de5b0SBaptiste Daroussin YYLLOC_DEFAULT(yyloc, yyerror_loc_range, 2); /* position of error span */ 10240c8de5b0SBaptiste Daroussin *++yystack.p_mark = yyloc; 10250c8de5b0SBaptiste Daroussin #endif 10260c8de5b0SBaptiste Daroussin goto yyloop; 10270c8de5b0SBaptiste Daroussin } 10280c8de5b0SBaptiste Daroussin else 10290c8de5b0SBaptiste Daroussin { 10300c8de5b0SBaptiste Daroussin #if YYDEBUG 10310c8de5b0SBaptiste Daroussin if (yydebug) 10320c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: error recovery discarding state %d\n", 10330c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, *yystack.s_mark); 10340c8de5b0SBaptiste Daroussin #endif 10350c8de5b0SBaptiste Daroussin if (yystack.s_mark <= yystack.s_base) goto yyabort; 10360c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 10370c8de5b0SBaptiste Daroussin /* the current TOS position is the error start position */ 10380c8de5b0SBaptiste Daroussin yyerror_loc_range[0] = *yystack.p_mark; 10390c8de5b0SBaptiste Daroussin #endif 10400c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL) 10410c8de5b0SBaptiste Daroussin #if YYBTYACC 10420c8de5b0SBaptiste Daroussin if (!yytrial) 10430c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 10440c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 10450c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding state", 10460c8de5b0SBaptiste Daroussin yystos[*yystack.s_mark], yystack.l_mark, yystack.p_mark); 10470c8de5b0SBaptiste Daroussin #else 10480c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding state", 10490c8de5b0SBaptiste Daroussin yystos[*yystack.s_mark], yystack.l_mark); 10500c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 10510c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */ 10520c8de5b0SBaptiste Daroussin --yystack.s_mark; 10530c8de5b0SBaptiste Daroussin --yystack.l_mark; 10540c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 10550c8de5b0SBaptiste Daroussin --yystack.p_mark; 10560c8de5b0SBaptiste Daroussin #endif 10570c8de5b0SBaptiste Daroussin } 10580c8de5b0SBaptiste Daroussin } 10590c8de5b0SBaptiste Daroussin } 10600c8de5b0SBaptiste Daroussin else 10610c8de5b0SBaptiste Daroussin { 10620c8de5b0SBaptiste Daroussin if (yychar == YYEOF) goto yyabort; 10630c8de5b0SBaptiste Daroussin #if YYDEBUG 10640c8de5b0SBaptiste Daroussin if (yydebug) 10650c8de5b0SBaptiste Daroussin { 1066*c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 10670c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, error recovery discarding token %d (%s)\n", 10680c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yychar, yys); 10690c8de5b0SBaptiste Daroussin } 10700c8de5b0SBaptiste Daroussin #endif 10710c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL) 10720c8de5b0SBaptiste Daroussin #if YYBTYACC 10730c8de5b0SBaptiste Daroussin if (!yytrial) 10740c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 10750c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 10760c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding token", yychar, &yylval, &yylloc); 10770c8de5b0SBaptiste Daroussin #else 10780c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding token", yychar, &yylval); 10790c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 10800c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */ 10810c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 10820c8de5b0SBaptiste Daroussin goto yyloop; 10830c8de5b0SBaptiste Daroussin } 10840c8de5b0SBaptiste Daroussin 10850c8de5b0SBaptiste Daroussin yyreduce: 10860c8de5b0SBaptiste Daroussin yym = yylen[yyn]; 10870c8de5b0SBaptiste Daroussin #if YYDEBUG 10880c8de5b0SBaptiste Daroussin if (yydebug) 10890c8de5b0SBaptiste Daroussin { 10900c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, reducing by rule %d (%s)", 10910c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyn, yyrule[yyn]); 10920c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING 10930c8de5b0SBaptiste Daroussin #if YYBTYACC 10940c8de5b0SBaptiste Daroussin if (!yytrial) 10950c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 10960c8de5b0SBaptiste Daroussin if (yym > 0) 10970c8de5b0SBaptiste Daroussin { 10980c8de5b0SBaptiste Daroussin int i; 10990c8de5b0SBaptiste Daroussin fputc('<', stderr); 11000c8de5b0SBaptiste Daroussin for (i = yym; i > 0; i--) 11010c8de5b0SBaptiste Daroussin { 11020c8de5b0SBaptiste Daroussin if (i != yym) fputs(", ", stderr); 11030c8de5b0SBaptiste Daroussin fputs(YYSTYPE_TOSTRING(yystos[yystack.s_mark[1-i]], 11040c8de5b0SBaptiste Daroussin yystack.l_mark[1-i]), stderr); 11050c8de5b0SBaptiste Daroussin } 11060c8de5b0SBaptiste Daroussin fputc('>', stderr); 11070c8de5b0SBaptiste Daroussin } 11080c8de5b0SBaptiste Daroussin #endif 11090c8de5b0SBaptiste Daroussin fputc('\n', stderr); 11100c8de5b0SBaptiste Daroussin } 11110c8de5b0SBaptiste Daroussin #endif 11120c8de5b0SBaptiste Daroussin if (yym > 0) 11130c8de5b0SBaptiste Daroussin yyval = yystack.l_mark[1-yym]; 11140c8de5b0SBaptiste Daroussin else 11150c8de5b0SBaptiste Daroussin memset(&yyval, 0, sizeof yyval); 11160c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 11170c8de5b0SBaptiste Daroussin 11180c8de5b0SBaptiste Daroussin /* Perform position reduction */ 11190c8de5b0SBaptiste Daroussin memset(&yyloc, 0, sizeof(yyloc)); 11200c8de5b0SBaptiste Daroussin #if YYBTYACC 11210c8de5b0SBaptiste Daroussin if (!yytrial) 11220c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 11230c8de5b0SBaptiste Daroussin { 11240c8de5b0SBaptiste Daroussin YYLLOC_DEFAULT(yyloc, &yystack.p_mark[1-yym], yym); 11250c8de5b0SBaptiste Daroussin /* just in case YYERROR is invoked within the action, save 11260c8de5b0SBaptiste Daroussin the start of the rhs as the error start position */ 11270c8de5b0SBaptiste Daroussin yyerror_loc_range[0] = yystack.p_mark[1-yym]; 11280c8de5b0SBaptiste Daroussin } 11290c8de5b0SBaptiste Daroussin #endif 11300c8de5b0SBaptiste Daroussin 11310c8de5b0SBaptiste Daroussin switch (yyn) 11320c8de5b0SBaptiste Daroussin { 11330c8de5b0SBaptiste Daroussin case 1: 11340c8de5b0SBaptiste Daroussin #line 50 "inherit2.y" 11350c8de5b0SBaptiste Daroussin yyval.cval = yystack.l_mark[-1].cval; 11360c8de5b0SBaptiste Daroussin break; 11370c8de5b0SBaptiste Daroussin case 2: 11380c8de5b0SBaptiste Daroussin #line 50 "inherit2.y" 11390c8de5b0SBaptiste Daroussin yyval.tval = yystack.l_mark[-1].tval; 11400c8de5b0SBaptiste Daroussin break; 11410c8de5b0SBaptiste Daroussin case 3: 11420c8de5b0SBaptiste Daroussin #line 51 "inherit2.y" 11430c8de5b0SBaptiste Daroussin { yyval.nlist = yystack.l_mark[0].nlist; } 11440c8de5b0SBaptiste Daroussin break; 11450c8de5b0SBaptiste Daroussin case 4: 11460c8de5b0SBaptiste Daroussin #line 53 "inherit2.y" 11470c8de5b0SBaptiste Daroussin { yyval.nlist = yystack.l_mark[0].nlist; } 11480c8de5b0SBaptiste Daroussin break; 1149*c5b5d71aSJung-uk Kim case 5: 11500c8de5b0SBaptiste Daroussin #line 56 "inherit2.y" 11510c8de5b0SBaptiste Daroussin { yyval.cval = cGLOBAL; } 11520c8de5b0SBaptiste Daroussin break; 1153*c5b5d71aSJung-uk Kim case 6: 11540c8de5b0SBaptiste Daroussin #line 57 "inherit2.y" 11550c8de5b0SBaptiste Daroussin { yyval.cval = cLOCAL; } 11560c8de5b0SBaptiste Daroussin break; 1157*c5b5d71aSJung-uk Kim case 7: 11580c8de5b0SBaptiste Daroussin #line 60 "inherit2.y" 11590c8de5b0SBaptiste Daroussin { yyval.tval = tREAL; } 11600c8de5b0SBaptiste Daroussin break; 1161*c5b5d71aSJung-uk Kim case 8: 11620c8de5b0SBaptiste Daroussin #line 61 "inherit2.y" 11630c8de5b0SBaptiste Daroussin { yyval.tval = tINTEGER; } 11640c8de5b0SBaptiste Daroussin break; 1165*c5b5d71aSJung-uk Kim case 9: 11660c8de5b0SBaptiste Daroussin #line 65 "inherit2.y" 11670c8de5b0SBaptiste Daroussin { yyval.nlist->s = mksymbol(yystack.l_mark[-2].tval, yystack.l_mark[-3].cval, yystack.l_mark[0].id); 11680c8de5b0SBaptiste Daroussin yyval.nlist->next = yystack.l_mark[-1].nlist; 11690c8de5b0SBaptiste Daroussin } 11700c8de5b0SBaptiste Daroussin break; 1171*c5b5d71aSJung-uk Kim case 10: 11720c8de5b0SBaptiste Daroussin #line 69 "inherit2.y" 11730c8de5b0SBaptiste Daroussin { yyval.nlist->s = mksymbol(yystack.l_mark[-1].tval, yystack.l_mark[-2].cval, yystack.l_mark[0].id); 11740c8de5b0SBaptiste Daroussin yyval.nlist->next = NULL; 11750c8de5b0SBaptiste Daroussin } 11760c8de5b0SBaptiste Daroussin break; 1177*c5b5d71aSJung-uk Kim case 11: 11780c8de5b0SBaptiste Daroussin #line 74 "inherit2.y" 11790c8de5b0SBaptiste Daroussin yyval.cval = cLOCAL; 11800c8de5b0SBaptiste Daroussin break; 1181*c5b5d71aSJung-uk Kim case 12: 11820c8de5b0SBaptiste Daroussin #line 75 "inherit2.y" 11830c8de5b0SBaptiste Daroussin { yyval.nlist = yystack.l_mark[0].nlist; } 11840c8de5b0SBaptiste Daroussin break; 1185*c5b5d71aSJung-uk Kim #line 1186 "inherit2.tab.c" 11860c8de5b0SBaptiste Daroussin default: 11870c8de5b0SBaptiste Daroussin break; 11880c8de5b0SBaptiste Daroussin } 11890c8de5b0SBaptiste Daroussin yystack.s_mark -= yym; 11900c8de5b0SBaptiste Daroussin yystate = *yystack.s_mark; 11910c8de5b0SBaptiste Daroussin yystack.l_mark -= yym; 11920c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 11930c8de5b0SBaptiste Daroussin yystack.p_mark -= yym; 11940c8de5b0SBaptiste Daroussin #endif 11950c8de5b0SBaptiste Daroussin yym = yylhs[yyn]; 11960c8de5b0SBaptiste Daroussin if (yystate == 0 && yym == 0) 11970c8de5b0SBaptiste Daroussin { 11980c8de5b0SBaptiste Daroussin #if YYDEBUG 11990c8de5b0SBaptiste Daroussin if (yydebug) 12000c8de5b0SBaptiste Daroussin { 12010c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: after reduction, ", YYDEBUGSTR, yydepth); 12020c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING 12030c8de5b0SBaptiste Daroussin #if YYBTYACC 12040c8de5b0SBaptiste Daroussin if (!yytrial) 12050c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 12060c8de5b0SBaptiste Daroussin fprintf(stderr, "result is <%s>, ", YYSTYPE_TOSTRING(yystos[YYFINAL], yyval)); 12070c8de5b0SBaptiste Daroussin #endif 12080c8de5b0SBaptiste Daroussin fprintf(stderr, "shifting from state 0 to final state %d\n", YYFINAL); 12090c8de5b0SBaptiste Daroussin } 12100c8de5b0SBaptiste Daroussin #endif 12110c8de5b0SBaptiste Daroussin yystate = YYFINAL; 12120c8de5b0SBaptiste Daroussin *++yystack.s_mark = YYFINAL; 12130c8de5b0SBaptiste Daroussin *++yystack.l_mark = yyval; 12140c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 12150c8de5b0SBaptiste Daroussin *++yystack.p_mark = yyloc; 12160c8de5b0SBaptiste Daroussin #endif 12170c8de5b0SBaptiste Daroussin if (yychar < 0) 12180c8de5b0SBaptiste Daroussin { 12190c8de5b0SBaptiste Daroussin #if YYBTYACC 12200c8de5b0SBaptiste Daroussin do { 12210c8de5b0SBaptiste Daroussin if (yylvp < yylve) 12220c8de5b0SBaptiste Daroussin { 12230c8de5b0SBaptiste Daroussin /* we're currently re-reading tokens */ 12240c8de5b0SBaptiste Daroussin yylval = *yylvp++; 12250c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 12260c8de5b0SBaptiste Daroussin yylloc = *yylpp++; 12270c8de5b0SBaptiste Daroussin #endif 12280c8de5b0SBaptiste Daroussin yychar = *yylexp++; 12290c8de5b0SBaptiste Daroussin break; 12300c8de5b0SBaptiste Daroussin } 12310c8de5b0SBaptiste Daroussin if (yyps->save) 12320c8de5b0SBaptiste Daroussin { 12330c8de5b0SBaptiste Daroussin /* in trial mode; save scanner results for future parse attempts */ 12340c8de5b0SBaptiste Daroussin if (yylvp == yylvlim) 12350c8de5b0SBaptiste Daroussin { /* Enlarge lexical value queue */ 123611fce282SBaptiste Daroussin size_t p = (size_t) (yylvp - yylvals); 123711fce282SBaptiste Daroussin size_t s = (size_t) (yylvlim - yylvals); 12380c8de5b0SBaptiste Daroussin 12390c8de5b0SBaptiste Daroussin s += YYLVQUEUEGROWTH; 12400c8de5b0SBaptiste Daroussin if ((yylexemes = (short *) realloc(yylexemes, s * sizeof(short))) == NULL) 12410c8de5b0SBaptiste Daroussin goto yyenomem; 12420c8de5b0SBaptiste Daroussin if ((yylvals = (YYSTYPE *) realloc(yylvals, s * sizeof(YYSTYPE))) == NULL) 12430c8de5b0SBaptiste Daroussin goto yyenomem; 12440c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 12450c8de5b0SBaptiste Daroussin if ((yylpsns = (YYLTYPE *) realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL) 12460c8de5b0SBaptiste Daroussin goto yyenomem; 12470c8de5b0SBaptiste Daroussin #endif 12480c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals + p; 12490c8de5b0SBaptiste Daroussin yylvlim = yylvals + s; 12500c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 12510c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns + p; 12520c8de5b0SBaptiste Daroussin yylplim = yylpsns + s; 12530c8de5b0SBaptiste Daroussin #endif 12540c8de5b0SBaptiste Daroussin yylexp = yylexemes + p; 12550c8de5b0SBaptiste Daroussin } 12560c8de5b0SBaptiste Daroussin *yylexp = (short) YYLEX; 12570c8de5b0SBaptiste Daroussin *yylvp++ = yylval; 12580c8de5b0SBaptiste Daroussin yylve++; 12590c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 12600c8de5b0SBaptiste Daroussin *yylpp++ = yylloc; 12610c8de5b0SBaptiste Daroussin yylpe++; 12620c8de5b0SBaptiste Daroussin #endif 12630c8de5b0SBaptiste Daroussin yychar = *yylexp++; 12640c8de5b0SBaptiste Daroussin break; 12650c8de5b0SBaptiste Daroussin } 12660c8de5b0SBaptiste Daroussin /* normal operation, no conflict encountered */ 12670c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 12680c8de5b0SBaptiste Daroussin yychar = YYLEX; 12690c8de5b0SBaptiste Daroussin #if YYBTYACC 12700c8de5b0SBaptiste Daroussin } while (0); 12710c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 12720c8de5b0SBaptiste Daroussin if (yychar < 0) yychar = YYEOF; 12730c8de5b0SBaptiste Daroussin #if YYDEBUG 12740c8de5b0SBaptiste Daroussin if (yydebug) 12750c8de5b0SBaptiste Daroussin { 1276*c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 1277*c5b5d71aSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)\n", 12780c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, YYFINAL, yychar, yys); 12790c8de5b0SBaptiste Daroussin } 12800c8de5b0SBaptiste Daroussin #endif 12810c8de5b0SBaptiste Daroussin } 12820c8de5b0SBaptiste Daroussin if (yychar == YYEOF) goto yyaccept; 12830c8de5b0SBaptiste Daroussin goto yyloop; 12840c8de5b0SBaptiste Daroussin } 12850c8de5b0SBaptiste Daroussin if (((yyn = yygindex[yym]) != 0) && (yyn += yystate) >= 0 && 12860c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yystate) 12870c8de5b0SBaptiste Daroussin yystate = yytable[yyn]; 12880c8de5b0SBaptiste Daroussin else 12890c8de5b0SBaptiste Daroussin yystate = yydgoto[yym]; 12900c8de5b0SBaptiste Daroussin #if YYDEBUG 12910c8de5b0SBaptiste Daroussin if (yydebug) 12920c8de5b0SBaptiste Daroussin { 12930c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: after reduction, ", YYDEBUGSTR, yydepth); 12940c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING 12950c8de5b0SBaptiste Daroussin #if YYBTYACC 12960c8de5b0SBaptiste Daroussin if (!yytrial) 12970c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 12980c8de5b0SBaptiste Daroussin fprintf(stderr, "result is <%s>, ", YYSTYPE_TOSTRING(yystos[yystate], yyval)); 12990c8de5b0SBaptiste Daroussin #endif 13000c8de5b0SBaptiste Daroussin fprintf(stderr, "shifting from state %d to state %d\n", *yystack.s_mark, yystate); 13010c8de5b0SBaptiste Daroussin } 13020c8de5b0SBaptiste Daroussin #endif 13030c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 1304*c5b5d71aSJung-uk Kim *++yystack.s_mark = (YYINT) yystate; 13050c8de5b0SBaptiste Daroussin *++yystack.l_mark = yyval; 13060c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 13070c8de5b0SBaptiste Daroussin *++yystack.p_mark = yyloc; 13080c8de5b0SBaptiste Daroussin #endif 13090c8de5b0SBaptiste Daroussin goto yyloop; 13100c8de5b0SBaptiste Daroussin #if YYBTYACC 13110c8de5b0SBaptiste Daroussin 13120c8de5b0SBaptiste Daroussin /* Reduction declares that this path is valid. Set yypath and do a full parse */ 13130c8de5b0SBaptiste Daroussin yyvalid: 13140c8de5b0SBaptiste Daroussin if (yypath) YYABORT; 13150c8de5b0SBaptiste Daroussin while (yyps->save) 13160c8de5b0SBaptiste Daroussin { 13170c8de5b0SBaptiste Daroussin YYParseState *save = yyps->save; 13180c8de5b0SBaptiste Daroussin yyps->save = save->save; 13190c8de5b0SBaptiste Daroussin save->save = yypath; 13200c8de5b0SBaptiste Daroussin yypath = save; 13210c8de5b0SBaptiste Daroussin } 13220c8de5b0SBaptiste Daroussin #if YYDEBUG 13230c8de5b0SBaptiste Daroussin if (yydebug) 13240c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, CONFLICT trial successful, backtracking to state %d, %d tokens\n", 13250c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yypath->state, (int)(yylvp - yylvals - yypath->lexeme)); 13260c8de5b0SBaptiste Daroussin #endif 13270c8de5b0SBaptiste Daroussin if (yyerrctx) 13280c8de5b0SBaptiste Daroussin { 13290c8de5b0SBaptiste Daroussin yyFreeState(yyerrctx); 13300c8de5b0SBaptiste Daroussin yyerrctx = NULL; 13310c8de5b0SBaptiste Daroussin } 13320c8de5b0SBaptiste Daroussin yylvp = yylvals + yypath->lexeme; 13330c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 13340c8de5b0SBaptiste Daroussin yylpp = yylpsns + yypath->lexeme; 13350c8de5b0SBaptiste Daroussin #endif 13360c8de5b0SBaptiste Daroussin yylexp = yylexemes + yypath->lexeme; 13370c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 13380c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (yypath->yystack.s_mark - yypath->yystack.s_base); 1339*c5b5d71aSJung-uk Kim memcpy (yystack.s_base, yypath->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 13400c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (yypath->yystack.l_mark - yypath->yystack.l_base); 134111fce282SBaptiste Daroussin memcpy (yystack.l_base, yypath->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 13420c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 13430c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (yypath->yystack.p_mark - yypath->yystack.p_base); 134411fce282SBaptiste Daroussin memcpy (yystack.p_base, yypath->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 13450c8de5b0SBaptiste Daroussin #endif 13460c8de5b0SBaptiste Daroussin yystate = yypath->state; 13470c8de5b0SBaptiste Daroussin goto yyloop; 13480c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 13490c8de5b0SBaptiste Daroussin 13500c8de5b0SBaptiste Daroussin yyoverflow: 13510c8de5b0SBaptiste Daroussin YYERROR_CALL("yacc stack overflow"); 13520c8de5b0SBaptiste Daroussin #if YYBTYACC 13530c8de5b0SBaptiste Daroussin goto yyabort_nomem; 13540c8de5b0SBaptiste Daroussin yyenomem: 13550c8de5b0SBaptiste Daroussin YYERROR_CALL("memory exhausted"); 13560c8de5b0SBaptiste Daroussin yyabort_nomem: 13570c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 13580c8de5b0SBaptiste Daroussin yyresult = 2; 13590c8de5b0SBaptiste Daroussin goto yyreturn; 13600c8de5b0SBaptiste Daroussin 13610c8de5b0SBaptiste Daroussin yyabort: 13620c8de5b0SBaptiste Daroussin yyresult = 1; 13630c8de5b0SBaptiste Daroussin goto yyreturn; 13640c8de5b0SBaptiste Daroussin 13650c8de5b0SBaptiste Daroussin yyaccept: 13660c8de5b0SBaptiste Daroussin #if YYBTYACC 13670c8de5b0SBaptiste Daroussin if (yyps->save) goto yyvalid; 13680c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 13690c8de5b0SBaptiste Daroussin yyresult = 0; 13700c8de5b0SBaptiste Daroussin 13710c8de5b0SBaptiste Daroussin yyreturn: 13720c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL) 13730c8de5b0SBaptiste Daroussin if (yychar != YYEOF && yychar != YYEMPTY) 13740c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 13750c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding token", yychar, &yylval, &yylloc); 13760c8de5b0SBaptiste Daroussin #else 13770c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding token", yychar, &yylval); 13780c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 13790c8de5b0SBaptiste Daroussin 13800c8de5b0SBaptiste Daroussin { 13810c8de5b0SBaptiste Daroussin YYSTYPE *pv; 13820c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 13830c8de5b0SBaptiste Daroussin YYLTYPE *pp; 13840c8de5b0SBaptiste Daroussin 13850c8de5b0SBaptiste Daroussin for (pv = yystack.l_base, pp = yystack.p_base; pv <= yystack.l_mark; ++pv, ++pp) 13860c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding state", 13870c8de5b0SBaptiste Daroussin yystos[*(yystack.s_base + (pv - yystack.l_base))], pv, pp); 13880c8de5b0SBaptiste Daroussin #else 13890c8de5b0SBaptiste Daroussin for (pv = yystack.l_base; pv <= yystack.l_mark; ++pv) 13900c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding state", 13910c8de5b0SBaptiste Daroussin yystos[*(yystack.s_base + (pv - yystack.l_base))], pv); 13920c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 13930c8de5b0SBaptiste Daroussin } 13940c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */ 13950c8de5b0SBaptiste Daroussin 13960c8de5b0SBaptiste Daroussin #if YYBTYACC 13970c8de5b0SBaptiste Daroussin if (yyerrctx) 13980c8de5b0SBaptiste Daroussin { 13990c8de5b0SBaptiste Daroussin yyFreeState(yyerrctx); 14000c8de5b0SBaptiste Daroussin yyerrctx = NULL; 14010c8de5b0SBaptiste Daroussin } 14020c8de5b0SBaptiste Daroussin while (yyps) 14030c8de5b0SBaptiste Daroussin { 14040c8de5b0SBaptiste Daroussin YYParseState *save = yyps; 14050c8de5b0SBaptiste Daroussin yyps = save->save; 14060c8de5b0SBaptiste Daroussin save->save = NULL; 14070c8de5b0SBaptiste Daroussin yyFreeState(save); 14080c8de5b0SBaptiste Daroussin } 14090c8de5b0SBaptiste Daroussin while (yypath) 14100c8de5b0SBaptiste Daroussin { 14110c8de5b0SBaptiste Daroussin YYParseState *save = yypath; 14120c8de5b0SBaptiste Daroussin yypath = save->save; 14130c8de5b0SBaptiste Daroussin save->save = NULL; 14140c8de5b0SBaptiste Daroussin yyFreeState(save); 14150c8de5b0SBaptiste Daroussin } 14160c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 14170c8de5b0SBaptiste Daroussin yyfreestack(&yystack); 14180c8de5b0SBaptiste Daroussin return (yyresult); 14190c8de5b0SBaptiste Daroussin } 1420