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