10c8de5b0SBaptiste Daroussin /* original parser id follows */ 20c8de5b0SBaptiste Daroussin /* yysccsid[] = "@(#)yaccpar 1.9 (Berkeley) 02/21/93" */ 3c5b5d71aSJung-uk Kim /* (use YYMAJOR/YYMINOR for ifdefs dependent on parser version) */ 40c8de5b0SBaptiste Daroussin 50c8de5b0SBaptiste Daroussin #define YYBYACC 1 60c8de5b0SBaptiste Daroussin #define YYMAJOR 1 70c8de5b0SBaptiste Daroussin #define YYMINOR 9 80c8de5b0SBaptiste Daroussin #define YYCHECK "yyyymmdd" 90c8de5b0SBaptiste Daroussin 100c8de5b0SBaptiste Daroussin #define YYEMPTY (-1) 110c8de5b0SBaptiste Daroussin #define yyclearin (yychar = YYEMPTY) 120c8de5b0SBaptiste Daroussin #define yyerrok (yyerrflag = 0) 130c8de5b0SBaptiste Daroussin #define YYRECOVERING() (yyerrflag != 0) 140c8de5b0SBaptiste Daroussin #define YYENOMEM (-2) 150c8de5b0SBaptiste Daroussin #define YYEOF 0 160c8de5b0SBaptiste Daroussin #undef YYBTYACC 170c8de5b0SBaptiste Daroussin #define YYBTYACC 0 180c8de5b0SBaptiste Daroussin #define YYDEBUGSTR YYPREFIX "debug" 190c8de5b0SBaptiste Daroussin 200c8de5b0SBaptiste Daroussin #ifndef yyparse 210c8de5b0SBaptiste Daroussin #define yyparse 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 145c5b5d71aSJung-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 200*b53bb29fSJung-uk Kim typedef int YYINT; 2010c8de5b0SBaptiste Daroussin static const YYINT inherit2_lhs[] = { -1, 202c5b5d71aSJung-uk Kim 5, 6, 0, 0, 3, 3, 4, 4, 1, 1, 203c5b5d71aSJung-uk Kim 7, 2, 2040c8de5b0SBaptiste Daroussin }; 2050c8de5b0SBaptiste Daroussin static const YYINT inherit2_len[] = { 2, 206c5b5d71aSJung-uk Kim 0, 0, 5, 2, 1, 1, 1, 1, 2, 1, 207c5b5d71aSJung-uk Kim 0, 3, 2080c8de5b0SBaptiste Daroussin }; 2090c8de5b0SBaptiste Daroussin static const YYINT inherit2_defred[] = { 0, 210c5b5d71aSJung-uk Kim 5, 6, 7, 8, 0, 0, 11, 1, 4, 2, 211c5b5d71aSJung-uk Kim 2, 0, 0, 10, 0, 0, 9, 2120c8de5b0SBaptiste Daroussin }; 2132aca18c7SJung-uk Kim #if defined(YYDESTRUCT_CALL) || defined(YYSTYPE_TOSTRING) 2140c8de5b0SBaptiste Daroussin static const YYINT inherit2_stos[] = { 0, 215c5b5d71aSJung-uk Kim 257, 258, 259, 260, 263, 266, 267, 267, 265, 270, 216c5b5d71aSJung-uk Kim 268, 269, 269, 261, 264, 264, 261, 2170c8de5b0SBaptiste Daroussin }; 2182aca18c7SJung-uk Kim #endif /* YYDESTRUCT_CALL || YYSTYPE_TOSTRING */ 2190c8de5b0SBaptiste Daroussin static const YYINT inherit2_dgoto[] = { 5, 220c5b5d71aSJung-uk Kim 15, 9, 6, 7, 11, 12, 10, 2210c8de5b0SBaptiste Daroussin }; 2220c8de5b0SBaptiste Daroussin static const YYINT inherit2_sindex[] = { -257, 2230c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, -255, 0, 0, 0, 0, 224c5b5d71aSJung-uk Kim 0, -254, -254, 0, -253, -253, 0, 2250c8de5b0SBaptiste Daroussin }; 2260c8de5b0SBaptiste Daroussin static const YYINT inherit2_rindex[] = { 0, 2270c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 228c5b5d71aSJung-uk Kim 0, 0, 0, 0, 6, 9, 0, 2290c8de5b0SBaptiste Daroussin }; 2300c8de5b0SBaptiste Daroussin #if YYBTYACC 2310c8de5b0SBaptiste Daroussin static const YYINT inherit2_cindex[] = { 0, 2320c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 233c5b5d71aSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 2340c8de5b0SBaptiste Daroussin }; 2350c8de5b0SBaptiste Daroussin #endif 2360c8de5b0SBaptiste Daroussin static const YYINT inherit2_gindex[] = { 0, 237c5b5d71aSJung-uk Kim -3, 0, 0, 5, 0, 1, 0, 2380c8de5b0SBaptiste Daroussin }; 239c5b5d71aSJung-uk Kim #define YYTABLESIZE 12 2400c8de5b0SBaptiste Daroussin static const YYINT inherit2_table[] = { 1, 241c5b5d71aSJung-uk Kim 2, 3, 4, 3, 4, 12, 14, 17, 3, 16, 242c5b5d71aSJung-uk Kim 8, 13, 2430c8de5b0SBaptiste Daroussin }; 2440c8de5b0SBaptiste Daroussin static const YYINT inherit2_check[] = { 257, 245c5b5d71aSJung-uk Kim 258, 259, 260, 259, 260, 0, 261, 261, 0, 13, 246c5b5d71aSJung-uk Kim 6, 11, 2470c8de5b0SBaptiste Daroussin }; 24811fce282SBaptiste Daroussin #if YYBTYACC 24911fce282SBaptiste Daroussin static const YYINT inherit2_ctable[] = { -1, 25011fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 251c5b5d71aSJung-uk Kim -1, 25211fce282SBaptiste Daroussin }; 25311fce282SBaptiste Daroussin #endif 2540c8de5b0SBaptiste Daroussin #define YYFINAL 5 2550c8de5b0SBaptiste Daroussin #ifndef YYDEBUG 2560c8de5b0SBaptiste Daroussin #define YYDEBUG 0 2570c8de5b0SBaptiste Daroussin #endif 2580c8de5b0SBaptiste Daroussin #define YYMAXTOKEN 261 259c5b5d71aSJung-uk Kim #define YYUNDFTOKEN 271 2600c8de5b0SBaptiste Daroussin #define YYTRANSLATE(a) ((a) > YYMAXTOKEN ? YYUNDFTOKEN : (a)) 2610c8de5b0SBaptiste Daroussin #if YYDEBUG 2620c8de5b0SBaptiste Daroussin static const char *const inherit2_name[] = { 2630c8de5b0SBaptiste Daroussin 2640c8de5b0SBaptiste 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, 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,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 2690c8de5b0SBaptiste 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, 2700c8de5b0SBaptiste 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", 2710c8de5b0SBaptiste Daroussin "NAME","$accept","declaration","namelist","locnamelist","class","type","$$1", 272c5b5d71aSJung-uk Kim "$$2","$$3","illegal-symbol", 2730c8de5b0SBaptiste Daroussin }; 2740c8de5b0SBaptiste Daroussin static const char *const inherit2_rule[] = { 2750c8de5b0SBaptiste Daroussin "$accept : declaration", 2760c8de5b0SBaptiste Daroussin "$$1 :", 2770c8de5b0SBaptiste Daroussin "$$2 :", 2780c8de5b0SBaptiste Daroussin "declaration : class type $$1 $$2 namelist", 279c5b5d71aSJung-uk Kim "declaration : type locnamelist", 2800c8de5b0SBaptiste Daroussin "class : GLOBAL", 2810c8de5b0SBaptiste Daroussin "class : LOCAL", 2820c8de5b0SBaptiste Daroussin "type : REAL", 2830c8de5b0SBaptiste Daroussin "type : INTEGER", 2840c8de5b0SBaptiste Daroussin "namelist : namelist NAME", 2850c8de5b0SBaptiste Daroussin "namelist : NAME", 286c5b5d71aSJung-uk Kim "$$3 :", 287c5b5d71aSJung-uk Kim "locnamelist : $$3 $$2 namelist", 2880c8de5b0SBaptiste Daroussin 2890c8de5b0SBaptiste Daroussin }; 2900c8de5b0SBaptiste Daroussin #endif 2910c8de5b0SBaptiste Daroussin 292*b53bb29fSJung-uk Kim #if YYDEBUG 2930c8de5b0SBaptiste Daroussin int yydebug; 294*b53bb29fSJung-uk Kim #endif 2950c8de5b0SBaptiste Daroussin 2960c8de5b0SBaptiste Daroussin int yyerrflag; 2970c8de5b0SBaptiste Daroussin int yychar; 2980c8de5b0SBaptiste Daroussin YYSTYPE yyval; 2990c8de5b0SBaptiste Daroussin YYSTYPE yylval; 300*b53bb29fSJung-uk Kim int yynerrs; 301*b53bb29fSJung-uk Kim 3020c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 3030c8de5b0SBaptiste Daroussin YYLTYPE yyloc; /* position returned by actions */ 3040c8de5b0SBaptiste Daroussin YYLTYPE yylloc; /* position from the lexer */ 3050c8de5b0SBaptiste Daroussin #endif 3060c8de5b0SBaptiste Daroussin 3070c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 3080c8de5b0SBaptiste Daroussin #ifndef YYLLOC_DEFAULT 3090c8de5b0SBaptiste Daroussin #define YYLLOC_DEFAULT(loc, rhs, n) \ 3100c8de5b0SBaptiste Daroussin do \ 3110c8de5b0SBaptiste Daroussin { \ 3120c8de5b0SBaptiste Daroussin if (n == 0) \ 3130c8de5b0SBaptiste Daroussin { \ 314*b53bb29fSJung-uk Kim (loc).first_line = YYRHSLOC(rhs, 0).last_line; \ 315*b53bb29fSJung-uk Kim (loc).first_column = YYRHSLOC(rhs, 0).last_column; \ 316*b53bb29fSJung-uk Kim (loc).last_line = YYRHSLOC(rhs, 0).last_line; \ 317*b53bb29fSJung-uk Kim (loc).last_column = YYRHSLOC(rhs, 0).last_column; \ 3180c8de5b0SBaptiste Daroussin } \ 3190c8de5b0SBaptiste Daroussin else \ 3200c8de5b0SBaptiste Daroussin { \ 321*b53bb29fSJung-uk Kim (loc).first_line = YYRHSLOC(rhs, 1).first_line; \ 322*b53bb29fSJung-uk Kim (loc).first_column = YYRHSLOC(rhs, 1).first_column; \ 323*b53bb29fSJung-uk Kim (loc).last_line = YYRHSLOC(rhs, n).last_line; \ 324*b53bb29fSJung-uk Kim (loc).last_column = YYRHSLOC(rhs, n).last_column; \ 3250c8de5b0SBaptiste Daroussin } \ 3260c8de5b0SBaptiste Daroussin } while (0) 3270c8de5b0SBaptiste Daroussin #endif /* YYLLOC_DEFAULT */ 3280c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 3290c8de5b0SBaptiste Daroussin #if YYBTYACC 3300c8de5b0SBaptiste Daroussin 3310c8de5b0SBaptiste Daroussin #ifndef YYLVQUEUEGROWTH 3320c8de5b0SBaptiste Daroussin #define YYLVQUEUEGROWTH 32 3330c8de5b0SBaptiste Daroussin #endif 3340c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 3350c8de5b0SBaptiste Daroussin 3360c8de5b0SBaptiste Daroussin /* define the initial stack-sizes */ 3370c8de5b0SBaptiste Daroussin #ifdef YYSTACKSIZE 3380c8de5b0SBaptiste Daroussin #undef YYMAXDEPTH 3390c8de5b0SBaptiste Daroussin #define YYMAXDEPTH YYSTACKSIZE 3400c8de5b0SBaptiste Daroussin #else 3410c8de5b0SBaptiste Daroussin #ifdef YYMAXDEPTH 3420c8de5b0SBaptiste Daroussin #define YYSTACKSIZE YYMAXDEPTH 3430c8de5b0SBaptiste Daroussin #else 3440c8de5b0SBaptiste Daroussin #define YYSTACKSIZE 10000 3450c8de5b0SBaptiste Daroussin #define YYMAXDEPTH 10000 3460c8de5b0SBaptiste Daroussin #endif 3470c8de5b0SBaptiste Daroussin #endif 3480c8de5b0SBaptiste Daroussin 3490c8de5b0SBaptiste Daroussin #ifndef YYINITSTACKSIZE 3500c8de5b0SBaptiste Daroussin #define YYINITSTACKSIZE 200 3510c8de5b0SBaptiste Daroussin #endif 3520c8de5b0SBaptiste Daroussin 3530c8de5b0SBaptiste Daroussin typedef struct { 3540c8de5b0SBaptiste Daroussin unsigned stacksize; 355c5b5d71aSJung-uk Kim YYINT *s_base; 356c5b5d71aSJung-uk Kim YYINT *s_mark; 357c5b5d71aSJung-uk Kim YYINT *s_last; 3580c8de5b0SBaptiste Daroussin YYSTYPE *l_base; 3590c8de5b0SBaptiste Daroussin YYSTYPE *l_mark; 3600c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 3610c8de5b0SBaptiste Daroussin YYLTYPE *p_base; 3620c8de5b0SBaptiste Daroussin YYLTYPE *p_mark; 3630c8de5b0SBaptiste Daroussin #endif 3640c8de5b0SBaptiste Daroussin } YYSTACKDATA; 3650c8de5b0SBaptiste Daroussin #if YYBTYACC 3660c8de5b0SBaptiste Daroussin 3670c8de5b0SBaptiste Daroussin struct YYParseState_s 3680c8de5b0SBaptiste Daroussin { 3690c8de5b0SBaptiste Daroussin struct YYParseState_s *save; /* Previously saved parser state */ 3700c8de5b0SBaptiste Daroussin YYSTACKDATA yystack; /* saved parser stack */ 3710c8de5b0SBaptiste Daroussin int state; /* saved parser state */ 3720c8de5b0SBaptiste Daroussin int errflag; /* saved error recovery status */ 3730c8de5b0SBaptiste Daroussin int lexeme; /* saved index of the conflict lexeme in the lexical queue */ 3740c8de5b0SBaptiste Daroussin YYINT ctry; /* saved index in yyctable[] for this conflict */ 3750c8de5b0SBaptiste Daroussin }; 3760c8de5b0SBaptiste Daroussin typedef struct YYParseState_s YYParseState; 3770c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 3780c8de5b0SBaptiste Daroussin /* variables for the parser stack */ 3790c8de5b0SBaptiste Daroussin static YYSTACKDATA yystack; 3800c8de5b0SBaptiste Daroussin #if YYBTYACC 3810c8de5b0SBaptiste Daroussin 3820c8de5b0SBaptiste Daroussin /* Current parser state */ 3830c8de5b0SBaptiste Daroussin static YYParseState *yyps = 0; 3840c8de5b0SBaptiste Daroussin 3850c8de5b0SBaptiste Daroussin /* yypath != NULL: do the full parse, starting at *yypath parser state. */ 3860c8de5b0SBaptiste Daroussin static YYParseState *yypath = 0; 3870c8de5b0SBaptiste Daroussin 3880c8de5b0SBaptiste Daroussin /* Base of the lexical value queue */ 3890c8de5b0SBaptiste Daroussin static YYSTYPE *yylvals = 0; 3900c8de5b0SBaptiste Daroussin 3910c8de5b0SBaptiste Daroussin /* Current position at lexical value queue */ 3920c8de5b0SBaptiste Daroussin static YYSTYPE *yylvp = 0; 3930c8de5b0SBaptiste Daroussin 3940c8de5b0SBaptiste Daroussin /* End position of lexical value queue */ 3950c8de5b0SBaptiste Daroussin static YYSTYPE *yylve = 0; 3960c8de5b0SBaptiste Daroussin 3970c8de5b0SBaptiste Daroussin /* The last allocated position at the lexical value queue */ 3980c8de5b0SBaptiste Daroussin static YYSTYPE *yylvlim = 0; 3990c8de5b0SBaptiste Daroussin 4000c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 4010c8de5b0SBaptiste Daroussin /* Base of the lexical position queue */ 4020c8de5b0SBaptiste Daroussin static YYLTYPE *yylpsns = 0; 4030c8de5b0SBaptiste Daroussin 4040c8de5b0SBaptiste Daroussin /* Current position at lexical position queue */ 4050c8de5b0SBaptiste Daroussin static YYLTYPE *yylpp = 0; 4060c8de5b0SBaptiste Daroussin 4070c8de5b0SBaptiste Daroussin /* End position of lexical position queue */ 4080c8de5b0SBaptiste Daroussin static YYLTYPE *yylpe = 0; 4090c8de5b0SBaptiste Daroussin 4100c8de5b0SBaptiste Daroussin /* The last allocated position at the lexical position queue */ 4110c8de5b0SBaptiste Daroussin static YYLTYPE *yylplim = 0; 4120c8de5b0SBaptiste Daroussin #endif 4130c8de5b0SBaptiste Daroussin 4140c8de5b0SBaptiste Daroussin /* Current position at lexical token queue */ 4152aca18c7SJung-uk Kim static YYINT *yylexp = 0; 4160c8de5b0SBaptiste Daroussin 4172aca18c7SJung-uk Kim static YYINT *yylexemes = 0; 4180c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 4190c8de5b0SBaptiste Daroussin #line 78 "inherit2.y" 4200c8de5b0SBaptiste Daroussin 4210c8de5b0SBaptiste Daroussin extern int YYLEX_DECL(); 4220c8de5b0SBaptiste Daroussin extern void YYERROR_DECL(); 423*b53bb29fSJung-uk Kim #line 424 "inherit2.tab.c" 4240c8de5b0SBaptiste Daroussin 4250c8de5b0SBaptiste Daroussin /* Release memory associated with symbol. */ 4260c8de5b0SBaptiste Daroussin #if ! defined YYDESTRUCT_IS_DECLARED 4270c8de5b0SBaptiste Daroussin static void 4280c8de5b0SBaptiste Daroussin YYDESTRUCT_DECL() 4290c8de5b0SBaptiste Daroussin { 4300c8de5b0SBaptiste Daroussin switch (psymb) 4310c8de5b0SBaptiste Daroussin { 4320c8de5b0SBaptiste Daroussin case 263: 4330c8de5b0SBaptiste Daroussin #line 30 "inherit2.y" 4340c8de5b0SBaptiste Daroussin { 4350c8de5b0SBaptiste Daroussin namelist *p = (*val).nlist; 4360c8de5b0SBaptiste Daroussin while (p != NULL) 4370c8de5b0SBaptiste Daroussin { namelist *pp = p; 4380c8de5b0SBaptiste Daroussin p = p->next; 4390c8de5b0SBaptiste Daroussin free(pp->s); free(pp); 4400c8de5b0SBaptiste Daroussin } 4410c8de5b0SBaptiste Daroussin } 4420c8de5b0SBaptiste Daroussin break; 443*b53bb29fSJung-uk Kim #line 444 "inherit2.tab.c" 4440c8de5b0SBaptiste Daroussin case 264: 4450c8de5b0SBaptiste Daroussin #line 30 "inherit2.y" 4460c8de5b0SBaptiste Daroussin { 4470c8de5b0SBaptiste Daroussin namelist *p = (*val).nlist; 4480c8de5b0SBaptiste Daroussin while (p != NULL) 4490c8de5b0SBaptiste Daroussin { namelist *pp = p; 4500c8de5b0SBaptiste Daroussin p = p->next; 4510c8de5b0SBaptiste Daroussin free(pp->s); free(pp); 4520c8de5b0SBaptiste Daroussin } 4530c8de5b0SBaptiste Daroussin } 4540c8de5b0SBaptiste Daroussin break; 455*b53bb29fSJung-uk Kim #line 456 "inherit2.tab.c" 4560c8de5b0SBaptiste Daroussin case 265: 4570c8de5b0SBaptiste Daroussin #line 30 "inherit2.y" 4580c8de5b0SBaptiste Daroussin { 4590c8de5b0SBaptiste Daroussin namelist *p = (*val).nlist; 4600c8de5b0SBaptiste Daroussin while (p != NULL) 4610c8de5b0SBaptiste Daroussin { namelist *pp = p; 4620c8de5b0SBaptiste Daroussin p = p->next; 4630c8de5b0SBaptiste Daroussin free(pp->s); free(pp); 4640c8de5b0SBaptiste Daroussin } 4650c8de5b0SBaptiste Daroussin } 4660c8de5b0SBaptiste Daroussin break; 467*b53bb29fSJung-uk Kim #line 468 "inherit2.tab.c" 4680c8de5b0SBaptiste Daroussin } 4690c8de5b0SBaptiste Daroussin } 4700c8de5b0SBaptiste Daroussin #define YYDESTRUCT_IS_DECLARED 1 4710c8de5b0SBaptiste Daroussin #endif 4720c8de5b0SBaptiste Daroussin 4730c8de5b0SBaptiste Daroussin /* For use in generated program */ 4740c8de5b0SBaptiste Daroussin #define yydepth (int)(yystack.s_mark - yystack.s_base) 4750c8de5b0SBaptiste Daroussin #if YYBTYACC 4760c8de5b0SBaptiste Daroussin #define yytrial (yyps->save) 4770c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 4780c8de5b0SBaptiste Daroussin 4790c8de5b0SBaptiste Daroussin #if YYDEBUG 4800c8de5b0SBaptiste Daroussin #include <stdio.h> /* needed for printf */ 4810c8de5b0SBaptiste Daroussin #endif 4820c8de5b0SBaptiste Daroussin 4830c8de5b0SBaptiste Daroussin #include <stdlib.h> /* needed for malloc, etc */ 4840c8de5b0SBaptiste Daroussin #include <string.h> /* needed for memset */ 4850c8de5b0SBaptiste Daroussin 4860c8de5b0SBaptiste Daroussin /* allocate initial stack or double stack size, up to YYMAXDEPTH */ 4870c8de5b0SBaptiste Daroussin static int yygrowstack(YYSTACKDATA *data) 4880c8de5b0SBaptiste Daroussin { 4890c8de5b0SBaptiste Daroussin int i; 4900c8de5b0SBaptiste Daroussin unsigned newsize; 491c5b5d71aSJung-uk Kim YYINT *newss; 4920c8de5b0SBaptiste Daroussin YYSTYPE *newvs; 4930c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 4940c8de5b0SBaptiste Daroussin YYLTYPE *newps; 4950c8de5b0SBaptiste Daroussin #endif 4960c8de5b0SBaptiste Daroussin 4970c8de5b0SBaptiste Daroussin if ((newsize = data->stacksize) == 0) 4980c8de5b0SBaptiste Daroussin newsize = YYINITSTACKSIZE; 4990c8de5b0SBaptiste Daroussin else if (newsize >= YYMAXDEPTH) 5000c8de5b0SBaptiste Daroussin return YYENOMEM; 5010c8de5b0SBaptiste Daroussin else if ((newsize *= 2) > YYMAXDEPTH) 5020c8de5b0SBaptiste Daroussin newsize = YYMAXDEPTH; 5030c8de5b0SBaptiste Daroussin 5040c8de5b0SBaptiste Daroussin i = (int) (data->s_mark - data->s_base); 505c5b5d71aSJung-uk Kim newss = (YYINT *)realloc(data->s_base, newsize * sizeof(*newss)); 5060c8de5b0SBaptiste Daroussin if (newss == 0) 5070c8de5b0SBaptiste Daroussin return YYENOMEM; 5080c8de5b0SBaptiste Daroussin 5090c8de5b0SBaptiste Daroussin data->s_base = newss; 5100c8de5b0SBaptiste Daroussin data->s_mark = newss + i; 5110c8de5b0SBaptiste Daroussin 5120c8de5b0SBaptiste Daroussin newvs = (YYSTYPE *)realloc(data->l_base, newsize * sizeof(*newvs)); 5130c8de5b0SBaptiste Daroussin if (newvs == 0) 5140c8de5b0SBaptiste Daroussin return YYENOMEM; 5150c8de5b0SBaptiste Daroussin 5160c8de5b0SBaptiste Daroussin data->l_base = newvs; 5170c8de5b0SBaptiste Daroussin data->l_mark = newvs + i; 5180c8de5b0SBaptiste Daroussin 5190c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 5200c8de5b0SBaptiste Daroussin newps = (YYLTYPE *)realloc(data->p_base, newsize * sizeof(*newps)); 5210c8de5b0SBaptiste Daroussin if (newps == 0) 5220c8de5b0SBaptiste Daroussin return YYENOMEM; 5230c8de5b0SBaptiste Daroussin 5240c8de5b0SBaptiste Daroussin data->p_base = newps; 5250c8de5b0SBaptiste Daroussin data->p_mark = newps + i; 5260c8de5b0SBaptiste Daroussin #endif 5270c8de5b0SBaptiste Daroussin 5280c8de5b0SBaptiste Daroussin data->stacksize = newsize; 5290c8de5b0SBaptiste Daroussin data->s_last = data->s_base + newsize - 1; 5300c8de5b0SBaptiste Daroussin 5310c8de5b0SBaptiste Daroussin #if YYDEBUG 5320c8de5b0SBaptiste Daroussin if (yydebug) 5330c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug: stack size increased to %d\n", YYPREFIX, newsize); 5340c8de5b0SBaptiste Daroussin #endif 5350c8de5b0SBaptiste Daroussin return 0; 5360c8de5b0SBaptiste Daroussin } 5370c8de5b0SBaptiste Daroussin 5380c8de5b0SBaptiste Daroussin #if YYPURE || defined(YY_NO_LEAKS) 5390c8de5b0SBaptiste Daroussin static void yyfreestack(YYSTACKDATA *data) 5400c8de5b0SBaptiste Daroussin { 5410c8de5b0SBaptiste Daroussin free(data->s_base); 5420c8de5b0SBaptiste Daroussin free(data->l_base); 5430c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 5440c8de5b0SBaptiste Daroussin free(data->p_base); 5450c8de5b0SBaptiste Daroussin #endif 5460c8de5b0SBaptiste Daroussin memset(data, 0, sizeof(*data)); 5470c8de5b0SBaptiste Daroussin } 5480c8de5b0SBaptiste Daroussin #else 5490c8de5b0SBaptiste Daroussin #define yyfreestack(data) /* nothing */ 5500c8de5b0SBaptiste Daroussin #endif /* YYPURE || defined(YY_NO_LEAKS) */ 5510c8de5b0SBaptiste Daroussin #if YYBTYACC 5520c8de5b0SBaptiste Daroussin 5530c8de5b0SBaptiste Daroussin static YYParseState * 5540c8de5b0SBaptiste Daroussin yyNewState(unsigned size) 5550c8de5b0SBaptiste Daroussin { 5560c8de5b0SBaptiste Daroussin YYParseState *p = (YYParseState *) malloc(sizeof(YYParseState)); 5570c8de5b0SBaptiste Daroussin if (p == NULL) return NULL; 5580c8de5b0SBaptiste Daroussin 5590c8de5b0SBaptiste Daroussin p->yystack.stacksize = size; 5600c8de5b0SBaptiste Daroussin if (size == 0) 5610c8de5b0SBaptiste Daroussin { 5620c8de5b0SBaptiste Daroussin p->yystack.s_base = NULL; 5630c8de5b0SBaptiste Daroussin p->yystack.l_base = NULL; 5640c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 5650c8de5b0SBaptiste Daroussin p->yystack.p_base = NULL; 5660c8de5b0SBaptiste Daroussin #endif 5670c8de5b0SBaptiste Daroussin return p; 5680c8de5b0SBaptiste Daroussin } 569c5b5d71aSJung-uk Kim p->yystack.s_base = (YYINT *) malloc(size * sizeof(YYINT)); 5700c8de5b0SBaptiste Daroussin if (p->yystack.s_base == NULL) return NULL; 5710c8de5b0SBaptiste Daroussin p->yystack.l_base = (YYSTYPE *) malloc(size * sizeof(YYSTYPE)); 5720c8de5b0SBaptiste Daroussin if (p->yystack.l_base == NULL) return NULL; 5730c8de5b0SBaptiste Daroussin memset(p->yystack.l_base, 0, size * sizeof(YYSTYPE)); 5740c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 5750c8de5b0SBaptiste Daroussin p->yystack.p_base = (YYLTYPE *) malloc(size * sizeof(YYLTYPE)); 5760c8de5b0SBaptiste Daroussin if (p->yystack.p_base == NULL) return NULL; 5770c8de5b0SBaptiste Daroussin memset(p->yystack.p_base, 0, size * sizeof(YYLTYPE)); 5780c8de5b0SBaptiste Daroussin #endif 5790c8de5b0SBaptiste Daroussin 5800c8de5b0SBaptiste Daroussin return p; 5810c8de5b0SBaptiste Daroussin } 5820c8de5b0SBaptiste Daroussin 5830c8de5b0SBaptiste Daroussin static void 5840c8de5b0SBaptiste Daroussin yyFreeState(YYParseState *p) 5850c8de5b0SBaptiste Daroussin { 5860c8de5b0SBaptiste Daroussin yyfreestack(&p->yystack); 5870c8de5b0SBaptiste Daroussin free(p); 5880c8de5b0SBaptiste Daroussin } 5890c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 5900c8de5b0SBaptiste Daroussin 5910c8de5b0SBaptiste Daroussin #define YYABORT goto yyabort 5920c8de5b0SBaptiste Daroussin #define YYREJECT goto yyabort 5930c8de5b0SBaptiste Daroussin #define YYACCEPT goto yyaccept 5940c8de5b0SBaptiste Daroussin #define YYERROR goto yyerrlab 5950c8de5b0SBaptiste Daroussin #if YYBTYACC 5960c8de5b0SBaptiste Daroussin #define YYVALID do { if (yyps->save) goto yyvalid; } while(0) 5970c8de5b0SBaptiste Daroussin #define YYVALID_NESTED do { if (yyps->save && \ 5980c8de5b0SBaptiste Daroussin yyps->save->save == 0) goto yyvalid; } while(0) 5990c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 6000c8de5b0SBaptiste Daroussin 6010c8de5b0SBaptiste Daroussin int 6020c8de5b0SBaptiste Daroussin YYPARSE_DECL() 6030c8de5b0SBaptiste Daroussin { 6040c8de5b0SBaptiste Daroussin int yym, yyn, yystate, yyresult; 6050c8de5b0SBaptiste Daroussin #if YYBTYACC 6060c8de5b0SBaptiste Daroussin int yynewerrflag; 6070c8de5b0SBaptiste Daroussin YYParseState *yyerrctx = NULL; 6080c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 6090c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 610*b53bb29fSJung-uk Kim YYLTYPE yyerror_loc_range[3]; /* position of error start/end (0 unused) */ 6110c8de5b0SBaptiste Daroussin #endif 6120c8de5b0SBaptiste Daroussin #if YYDEBUG 6130c8de5b0SBaptiste Daroussin const char *yys; 6140c8de5b0SBaptiste Daroussin 6150c8de5b0SBaptiste Daroussin if ((yys = getenv("YYDEBUG")) != 0) 6160c8de5b0SBaptiste Daroussin { 6170c8de5b0SBaptiste Daroussin yyn = *yys; 6180c8de5b0SBaptiste Daroussin if (yyn >= '0' && yyn <= '9') 6190c8de5b0SBaptiste Daroussin yydebug = yyn - '0'; 6200c8de5b0SBaptiste Daroussin } 6210c8de5b0SBaptiste Daroussin if (yydebug) 6220c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug[<# of symbols on state stack>]\n", YYPREFIX); 6230c8de5b0SBaptiste Daroussin #endif 6246166fdceSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6256166fdceSJung-uk Kim memset(yyerror_loc_range, 0, sizeof(yyerror_loc_range)); 6266166fdceSJung-uk Kim #endif 6270c8de5b0SBaptiste Daroussin 6280c8de5b0SBaptiste Daroussin #if YYBTYACC 6290c8de5b0SBaptiste Daroussin yyps = yyNewState(0); if (yyps == 0) goto yyenomem; 6300c8de5b0SBaptiste Daroussin yyps->save = 0; 6310c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 632c5b5d71aSJung-uk Kim yym = 0; 633c5b5d71aSJung-uk Kim yyn = 0; 6340c8de5b0SBaptiste Daroussin yynerrs = 0; 6350c8de5b0SBaptiste Daroussin yyerrflag = 0; 6360c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 6370c8de5b0SBaptiste Daroussin yystate = 0; 6380c8de5b0SBaptiste Daroussin 6390c8de5b0SBaptiste Daroussin #if YYPURE 6400c8de5b0SBaptiste Daroussin memset(&yystack, 0, sizeof(yystack)); 6410c8de5b0SBaptiste Daroussin #endif 6420c8de5b0SBaptiste Daroussin 6430c8de5b0SBaptiste Daroussin if (yystack.s_base == NULL && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 6440c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base; 6450c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base; 6460c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6470c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base; 6480c8de5b0SBaptiste Daroussin #endif 6490c8de5b0SBaptiste Daroussin yystate = 0; 6500c8de5b0SBaptiste Daroussin *yystack.s_mark = 0; 6510c8de5b0SBaptiste Daroussin 6520c8de5b0SBaptiste Daroussin yyloop: 6530c8de5b0SBaptiste Daroussin if ((yyn = yydefred[yystate]) != 0) goto yyreduce; 6540c8de5b0SBaptiste Daroussin if (yychar < 0) 6550c8de5b0SBaptiste Daroussin { 6560c8de5b0SBaptiste Daroussin #if YYBTYACC 6570c8de5b0SBaptiste Daroussin do { 6580c8de5b0SBaptiste Daroussin if (yylvp < yylve) 6590c8de5b0SBaptiste Daroussin { 6600c8de5b0SBaptiste Daroussin /* we're currently re-reading tokens */ 6610c8de5b0SBaptiste Daroussin yylval = *yylvp++; 6620c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6630c8de5b0SBaptiste Daroussin yylloc = *yylpp++; 6640c8de5b0SBaptiste Daroussin #endif 6650c8de5b0SBaptiste Daroussin yychar = *yylexp++; 6660c8de5b0SBaptiste Daroussin break; 6670c8de5b0SBaptiste Daroussin } 6680c8de5b0SBaptiste Daroussin if (yyps->save) 6690c8de5b0SBaptiste Daroussin { 6700c8de5b0SBaptiste Daroussin /* in trial mode; save scanner results for future parse attempts */ 6710c8de5b0SBaptiste Daroussin if (yylvp == yylvlim) 6720c8de5b0SBaptiste Daroussin { /* Enlarge lexical value queue */ 67311fce282SBaptiste Daroussin size_t p = (size_t) (yylvp - yylvals); 67411fce282SBaptiste Daroussin size_t s = (size_t) (yylvlim - yylvals); 6750c8de5b0SBaptiste Daroussin 6760c8de5b0SBaptiste Daroussin s += YYLVQUEUEGROWTH; 677*b53bb29fSJung-uk Kim if ((yylexemes = (YYINT *)realloc(yylexemes, s * sizeof(YYINT))) == NULL) goto yyenomem; 678*b53bb29fSJung-uk Kim if ((yylvals = (YYSTYPE *)realloc(yylvals, s * sizeof(YYSTYPE))) == NULL) goto yyenomem; 6790c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 680*b53bb29fSJung-uk Kim if ((yylpsns = (YYLTYPE *)realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL) goto yyenomem; 6810c8de5b0SBaptiste Daroussin #endif 6820c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals + p; 6830c8de5b0SBaptiste Daroussin yylvlim = yylvals + s; 6840c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6850c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns + p; 6860c8de5b0SBaptiste Daroussin yylplim = yylpsns + s; 6870c8de5b0SBaptiste Daroussin #endif 6880c8de5b0SBaptiste Daroussin yylexp = yylexemes + p; 6890c8de5b0SBaptiste Daroussin } 6902aca18c7SJung-uk Kim *yylexp = (YYINT) YYLEX; 6910c8de5b0SBaptiste Daroussin *yylvp++ = yylval; 6920c8de5b0SBaptiste Daroussin yylve++; 6930c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 6940c8de5b0SBaptiste Daroussin *yylpp++ = yylloc; 6950c8de5b0SBaptiste Daroussin yylpe++; 6960c8de5b0SBaptiste Daroussin #endif 6970c8de5b0SBaptiste Daroussin yychar = *yylexp++; 6980c8de5b0SBaptiste Daroussin break; 6990c8de5b0SBaptiste Daroussin } 7000c8de5b0SBaptiste Daroussin /* normal operation, no conflict encountered */ 7010c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 7020c8de5b0SBaptiste Daroussin yychar = YYLEX; 7030c8de5b0SBaptiste Daroussin #if YYBTYACC 7040c8de5b0SBaptiste Daroussin } while (0); 7050c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 7060c8de5b0SBaptiste Daroussin if (yychar < 0) yychar = YYEOF; 7070c8de5b0SBaptiste Daroussin #if YYDEBUG 7080c8de5b0SBaptiste Daroussin if (yydebug) 7090c8de5b0SBaptiste Daroussin { 710c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 7110c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)", 7120c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yychar, yys); 7130c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING 7140c8de5b0SBaptiste Daroussin #if YYBTYACC 7150c8de5b0SBaptiste Daroussin if (!yytrial) 7160c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 7170c8de5b0SBaptiste Daroussin fprintf(stderr, " <%s>", YYSTYPE_TOSTRING(yychar, yylval)); 7180c8de5b0SBaptiste Daroussin #endif 7190c8de5b0SBaptiste Daroussin fputc('\n', stderr); 7200c8de5b0SBaptiste Daroussin } 7210c8de5b0SBaptiste Daroussin #endif 7220c8de5b0SBaptiste Daroussin } 7230c8de5b0SBaptiste Daroussin #if YYBTYACC 7240c8de5b0SBaptiste Daroussin 7250c8de5b0SBaptiste Daroussin /* Do we have a conflict? */ 7260c8de5b0SBaptiste Daroussin if (((yyn = yycindex[yystate]) != 0) && (yyn += yychar) >= 0 && 7270c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 7280c8de5b0SBaptiste Daroussin { 7290c8de5b0SBaptiste Daroussin YYINT ctry; 7300c8de5b0SBaptiste Daroussin 7310c8de5b0SBaptiste Daroussin if (yypath) 7320c8de5b0SBaptiste Daroussin { 7330c8de5b0SBaptiste Daroussin YYParseState *save; 7340c8de5b0SBaptiste Daroussin #if YYDEBUG 7350c8de5b0SBaptiste Daroussin if (yydebug) 7360c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: CONFLICT in state %d: following successful trial parse\n", 7370c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate); 7380c8de5b0SBaptiste Daroussin #endif 7390c8de5b0SBaptiste Daroussin /* Switch to the next conflict context */ 7400c8de5b0SBaptiste Daroussin save = yypath; 7410c8de5b0SBaptiste Daroussin yypath = save->save; 7420c8de5b0SBaptiste Daroussin save->save = NULL; 7430c8de5b0SBaptiste Daroussin ctry = save->ctry; 7440c8de5b0SBaptiste Daroussin if (save->state != yystate) YYABORT; 7450c8de5b0SBaptiste Daroussin yyFreeState(save); 7460c8de5b0SBaptiste Daroussin 7470c8de5b0SBaptiste Daroussin } 7480c8de5b0SBaptiste Daroussin else 7490c8de5b0SBaptiste Daroussin { 7500c8de5b0SBaptiste Daroussin 7510c8de5b0SBaptiste Daroussin /* Unresolved conflict - start/continue trial parse */ 7520c8de5b0SBaptiste Daroussin YYParseState *save; 7530c8de5b0SBaptiste Daroussin #if YYDEBUG 7540c8de5b0SBaptiste Daroussin if (yydebug) 7550c8de5b0SBaptiste Daroussin { 7560c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: CONFLICT in state %d. ", YYDEBUGSTR, yydepth, yystate); 7570c8de5b0SBaptiste Daroussin if (yyps->save) 7580c8de5b0SBaptiste Daroussin fputs("ALREADY in conflict, continuing trial parse.\n", stderr); 7590c8de5b0SBaptiste Daroussin else 7600c8de5b0SBaptiste Daroussin fputs("Starting trial parse.\n", stderr); 7610c8de5b0SBaptiste Daroussin } 7620c8de5b0SBaptiste Daroussin #endif 7630c8de5b0SBaptiste Daroussin save = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1)); 7640c8de5b0SBaptiste Daroussin if (save == NULL) goto yyenomem; 7650c8de5b0SBaptiste Daroussin save->save = yyps->save; 7660c8de5b0SBaptiste Daroussin save->state = yystate; 7670c8de5b0SBaptiste Daroussin save->errflag = yyerrflag; 7680c8de5b0SBaptiste Daroussin save->yystack.s_mark = save->yystack.s_base + (yystack.s_mark - yystack.s_base); 769c5b5d71aSJung-uk Kim memcpy (save->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 7700c8de5b0SBaptiste Daroussin save->yystack.l_mark = save->yystack.l_base + (yystack.l_mark - yystack.l_base); 77111fce282SBaptiste Daroussin memcpy (save->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 7720c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7730c8de5b0SBaptiste Daroussin save->yystack.p_mark = save->yystack.p_base + (yystack.p_mark - yystack.p_base); 77411fce282SBaptiste Daroussin memcpy (save->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 7750c8de5b0SBaptiste Daroussin #endif 7760c8de5b0SBaptiste Daroussin ctry = yytable[yyn]; 7770c8de5b0SBaptiste Daroussin if (yyctable[ctry] == -1) 7780c8de5b0SBaptiste Daroussin { 7790c8de5b0SBaptiste Daroussin #if YYDEBUG 7800c8de5b0SBaptiste Daroussin if (yydebug && yychar >= YYEOF) 7810c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: backtracking 1 token\n", YYDEBUGSTR, yydepth); 7820c8de5b0SBaptiste Daroussin #endif 7830c8de5b0SBaptiste Daroussin ctry++; 7840c8de5b0SBaptiste Daroussin } 7850c8de5b0SBaptiste Daroussin save->ctry = ctry; 7860c8de5b0SBaptiste Daroussin if (yyps->save == NULL) 7870c8de5b0SBaptiste Daroussin { 7880c8de5b0SBaptiste Daroussin /* If this is a first conflict in the stack, start saving lexemes */ 7890c8de5b0SBaptiste Daroussin if (!yylexemes) 7900c8de5b0SBaptiste Daroussin { 791*b53bb29fSJung-uk Kim yylexemes = (YYINT *) malloc((YYLVQUEUEGROWTH) * sizeof(YYINT)); 7920c8de5b0SBaptiste Daroussin if (yylexemes == NULL) goto yyenomem; 7930c8de5b0SBaptiste Daroussin yylvals = (YYSTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYSTYPE)); 7940c8de5b0SBaptiste Daroussin if (yylvals == NULL) goto yyenomem; 7950c8de5b0SBaptiste Daroussin yylvlim = yylvals + YYLVQUEUEGROWTH; 7960c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 7970c8de5b0SBaptiste Daroussin yylpsns = (YYLTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYLTYPE)); 7980c8de5b0SBaptiste Daroussin if (yylpsns == NULL) goto yyenomem; 7990c8de5b0SBaptiste Daroussin yylplim = yylpsns + YYLVQUEUEGROWTH; 8000c8de5b0SBaptiste Daroussin #endif 8010c8de5b0SBaptiste Daroussin } 8020c8de5b0SBaptiste Daroussin if (yylvp == yylve) 8030c8de5b0SBaptiste Daroussin { 8040c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals; 8050c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8060c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns; 8070c8de5b0SBaptiste Daroussin #endif 8080c8de5b0SBaptiste Daroussin yylexp = yylexemes; 8090c8de5b0SBaptiste Daroussin if (yychar >= YYEOF) 8100c8de5b0SBaptiste Daroussin { 8110c8de5b0SBaptiste Daroussin *yylve++ = yylval; 8120c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8130c8de5b0SBaptiste Daroussin *yylpe++ = yylloc; 8140c8de5b0SBaptiste Daroussin #endif 8152aca18c7SJung-uk Kim *yylexp = (YYINT) yychar; 8160c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 8170c8de5b0SBaptiste Daroussin } 8180c8de5b0SBaptiste Daroussin } 8190c8de5b0SBaptiste Daroussin } 8200c8de5b0SBaptiste Daroussin if (yychar >= YYEOF) 8210c8de5b0SBaptiste Daroussin { 8220c8de5b0SBaptiste Daroussin yylvp--; 8230c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8240c8de5b0SBaptiste Daroussin yylpp--; 8250c8de5b0SBaptiste Daroussin #endif 8260c8de5b0SBaptiste Daroussin yylexp--; 8270c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 8280c8de5b0SBaptiste Daroussin } 82911fce282SBaptiste Daroussin save->lexeme = (int) (yylvp - yylvals); 8300c8de5b0SBaptiste Daroussin yyps->save = save; 8310c8de5b0SBaptiste Daroussin } 8320c8de5b0SBaptiste Daroussin if (yytable[yyn] == ctry) 8330c8de5b0SBaptiste Daroussin { 8340c8de5b0SBaptiste Daroussin #if YYDEBUG 8350c8de5b0SBaptiste Daroussin if (yydebug) 8360c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n", 8370c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyctable[ctry]); 8380c8de5b0SBaptiste Daroussin #endif 8390c8de5b0SBaptiste Daroussin if (yychar < 0) 8400c8de5b0SBaptiste Daroussin { 8410c8de5b0SBaptiste Daroussin yylvp++; 8420c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8430c8de5b0SBaptiste Daroussin yylpp++; 8440c8de5b0SBaptiste Daroussin #endif 8450c8de5b0SBaptiste Daroussin yylexp++; 8460c8de5b0SBaptiste Daroussin } 8470c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) 8480c8de5b0SBaptiste Daroussin goto yyoverflow; 8490c8de5b0SBaptiste Daroussin yystate = yyctable[ctry]; 850c5b5d71aSJung-uk Kim *++yystack.s_mark = (YYINT) yystate; 8510c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval; 8520c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8530c8de5b0SBaptiste Daroussin *++yystack.p_mark = yylloc; 8540c8de5b0SBaptiste Daroussin #endif 8550c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 8560c8de5b0SBaptiste Daroussin if (yyerrflag > 0) --yyerrflag; 8570c8de5b0SBaptiste Daroussin goto yyloop; 8580c8de5b0SBaptiste Daroussin } 8590c8de5b0SBaptiste Daroussin else 8600c8de5b0SBaptiste Daroussin { 8610c8de5b0SBaptiste Daroussin yyn = yyctable[ctry]; 8620c8de5b0SBaptiste Daroussin goto yyreduce; 8630c8de5b0SBaptiste Daroussin } 8640c8de5b0SBaptiste Daroussin } /* End of code dealing with conflicts */ 8650c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 8660c8de5b0SBaptiste Daroussin if (((yyn = yysindex[yystate]) != 0) && (yyn += yychar) >= 0 && 8670c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 8680c8de5b0SBaptiste Daroussin { 8690c8de5b0SBaptiste Daroussin #if YYDEBUG 8700c8de5b0SBaptiste Daroussin if (yydebug) 8710c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n", 8720c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yytable[yyn]); 8730c8de5b0SBaptiste Daroussin #endif 8740c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 8750c8de5b0SBaptiste Daroussin yystate = yytable[yyn]; 8760c8de5b0SBaptiste Daroussin *++yystack.s_mark = yytable[yyn]; 8770c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval; 8780c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 8790c8de5b0SBaptiste Daroussin *++yystack.p_mark = yylloc; 8800c8de5b0SBaptiste Daroussin #endif 8810c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 8820c8de5b0SBaptiste Daroussin if (yyerrflag > 0) --yyerrflag; 8830c8de5b0SBaptiste Daroussin goto yyloop; 8840c8de5b0SBaptiste Daroussin } 8850c8de5b0SBaptiste Daroussin if (((yyn = yyrindex[yystate]) != 0) && (yyn += yychar) >= 0 && 8860c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 8870c8de5b0SBaptiste Daroussin { 8880c8de5b0SBaptiste Daroussin yyn = yytable[yyn]; 8890c8de5b0SBaptiste Daroussin goto yyreduce; 8900c8de5b0SBaptiste Daroussin } 8910c8de5b0SBaptiste Daroussin if (yyerrflag != 0) goto yyinrecovery; 8920c8de5b0SBaptiste Daroussin #if YYBTYACC 8930c8de5b0SBaptiste Daroussin 8940c8de5b0SBaptiste Daroussin yynewerrflag = 1; 8950c8de5b0SBaptiste Daroussin goto yyerrhandler; 896c5b5d71aSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */ 8970c8de5b0SBaptiste Daroussin 8980c8de5b0SBaptiste Daroussin yyerrlab: 899c5b5d71aSJung-uk Kim /* explicit YYERROR from an action -- pop the rhs of the rule reduced 900c5b5d71aSJung-uk Kim * before looking for error recovery */ 901c5b5d71aSJung-uk Kim yystack.s_mark -= yym; 902c5b5d71aSJung-uk Kim yystate = *yystack.s_mark; 903c5b5d71aSJung-uk Kim yystack.l_mark -= yym; 904c5b5d71aSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 905c5b5d71aSJung-uk Kim yystack.p_mark -= yym; 906c5b5d71aSJung-uk Kim #endif 907c5b5d71aSJung-uk Kim 9080c8de5b0SBaptiste Daroussin yynewerrflag = 0; 9090c8de5b0SBaptiste Daroussin yyerrhandler: 9100c8de5b0SBaptiste Daroussin while (yyps->save) 9110c8de5b0SBaptiste Daroussin { 9120c8de5b0SBaptiste Daroussin int ctry; 9130c8de5b0SBaptiste Daroussin YYParseState *save = yyps->save; 9140c8de5b0SBaptiste Daroussin #if YYDEBUG 9150c8de5b0SBaptiste Daroussin if (yydebug) 9160c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: ERROR in state %d, CONFLICT BACKTRACKING to state %d, %d tokens\n", 9170c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyps->save->state, 9180c8de5b0SBaptiste Daroussin (int)(yylvp - yylvals - yyps->save->lexeme)); 9190c8de5b0SBaptiste Daroussin #endif 9200c8de5b0SBaptiste Daroussin /* Memorize most forward-looking error state in case it's really an error. */ 9210c8de5b0SBaptiste Daroussin if (yyerrctx == NULL || yyerrctx->lexeme < yylvp - yylvals) 9220c8de5b0SBaptiste Daroussin { 9230c8de5b0SBaptiste Daroussin /* Free old saved error context state */ 9240c8de5b0SBaptiste Daroussin if (yyerrctx) yyFreeState(yyerrctx); 9250c8de5b0SBaptiste Daroussin /* Create and fill out new saved error context state */ 9260c8de5b0SBaptiste Daroussin yyerrctx = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1)); 9270c8de5b0SBaptiste Daroussin if (yyerrctx == NULL) goto yyenomem; 9280c8de5b0SBaptiste Daroussin yyerrctx->save = yyps->save; 9290c8de5b0SBaptiste Daroussin yyerrctx->state = yystate; 9300c8de5b0SBaptiste Daroussin yyerrctx->errflag = yyerrflag; 9310c8de5b0SBaptiste Daroussin yyerrctx->yystack.s_mark = yyerrctx->yystack.s_base + (yystack.s_mark - yystack.s_base); 932c5b5d71aSJung-uk Kim memcpy (yyerrctx->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 9330c8de5b0SBaptiste Daroussin yyerrctx->yystack.l_mark = yyerrctx->yystack.l_base + (yystack.l_mark - yystack.l_base); 93411fce282SBaptiste Daroussin memcpy (yyerrctx->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 9350c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9360c8de5b0SBaptiste Daroussin yyerrctx->yystack.p_mark = yyerrctx->yystack.p_base + (yystack.p_mark - yystack.p_base); 93711fce282SBaptiste Daroussin memcpy (yyerrctx->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 9380c8de5b0SBaptiste Daroussin #endif 93911fce282SBaptiste Daroussin yyerrctx->lexeme = (int) (yylvp - yylvals); 9400c8de5b0SBaptiste Daroussin } 9410c8de5b0SBaptiste Daroussin yylvp = yylvals + save->lexeme; 9420c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9430c8de5b0SBaptiste Daroussin yylpp = yylpsns + save->lexeme; 9440c8de5b0SBaptiste Daroussin #endif 9450c8de5b0SBaptiste Daroussin yylexp = yylexemes + save->lexeme; 9460c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 9470c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (save->yystack.s_mark - save->yystack.s_base); 948c5b5d71aSJung-uk Kim memcpy (yystack.s_base, save->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 9490c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (save->yystack.l_mark - save->yystack.l_base); 95011fce282SBaptiste Daroussin memcpy (yystack.l_base, save->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 9510c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9520c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (save->yystack.p_mark - save->yystack.p_base); 95311fce282SBaptiste Daroussin memcpy (yystack.p_base, save->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 9540c8de5b0SBaptiste Daroussin #endif 9550c8de5b0SBaptiste Daroussin ctry = ++save->ctry; 9560c8de5b0SBaptiste Daroussin yystate = save->state; 9570c8de5b0SBaptiste Daroussin /* We tried shift, try reduce now */ 9580c8de5b0SBaptiste Daroussin if ((yyn = yyctable[ctry]) >= 0) goto yyreduce; 9590c8de5b0SBaptiste Daroussin yyps->save = save->save; 9600c8de5b0SBaptiste Daroussin save->save = NULL; 9610c8de5b0SBaptiste Daroussin yyFreeState(save); 9620c8de5b0SBaptiste Daroussin 9630c8de5b0SBaptiste Daroussin /* Nothing left on the stack -- error */ 9640c8de5b0SBaptiste Daroussin if (!yyps->save) 9650c8de5b0SBaptiste Daroussin { 9660c8de5b0SBaptiste Daroussin #if YYDEBUG 9670c8de5b0SBaptiste Daroussin if (yydebug) 9680c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug[%d,trial]: trial parse FAILED, entering ERROR mode\n", 9690c8de5b0SBaptiste Daroussin YYPREFIX, yydepth); 9700c8de5b0SBaptiste Daroussin #endif 9710c8de5b0SBaptiste Daroussin /* Restore state as it was in the most forward-advanced error */ 9720c8de5b0SBaptiste Daroussin yylvp = yylvals + yyerrctx->lexeme; 9730c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9740c8de5b0SBaptiste Daroussin yylpp = yylpsns + yyerrctx->lexeme; 9750c8de5b0SBaptiste Daroussin #endif 9760c8de5b0SBaptiste Daroussin yylexp = yylexemes + yyerrctx->lexeme; 9770c8de5b0SBaptiste Daroussin yychar = yylexp[-1]; 9780c8de5b0SBaptiste Daroussin yylval = yylvp[-1]; 9790c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9800c8de5b0SBaptiste Daroussin yylloc = yylpp[-1]; 9810c8de5b0SBaptiste Daroussin #endif 9820c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (yyerrctx->yystack.s_mark - yyerrctx->yystack.s_base); 983c5b5d71aSJung-uk Kim memcpy (yystack.s_base, yyerrctx->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 9840c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (yyerrctx->yystack.l_mark - yyerrctx->yystack.l_base); 98511fce282SBaptiste Daroussin memcpy (yystack.l_base, yyerrctx->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 9860c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 9870c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (yyerrctx->yystack.p_mark - yyerrctx->yystack.p_base); 98811fce282SBaptiste Daroussin memcpy (yystack.p_base, yyerrctx->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 9890c8de5b0SBaptiste Daroussin #endif 9900c8de5b0SBaptiste Daroussin yystate = yyerrctx->state; 9910c8de5b0SBaptiste Daroussin yyFreeState(yyerrctx); 9920c8de5b0SBaptiste Daroussin yyerrctx = NULL; 9930c8de5b0SBaptiste Daroussin } 9940c8de5b0SBaptiste Daroussin yynewerrflag = 1; 9950c8de5b0SBaptiste Daroussin } 9960c8de5b0SBaptiste Daroussin if (yynewerrflag == 0) goto yyinrecovery; 9970c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 9980c8de5b0SBaptiste Daroussin 9990c8de5b0SBaptiste Daroussin YYERROR_CALL("syntax error"); 10000c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1001*b53bb29fSJung-uk Kim yyerror_loc_range[1] = yylloc; /* lookahead position is error start position */ 10020c8de5b0SBaptiste Daroussin #endif 10030c8de5b0SBaptiste Daroussin 10040c8de5b0SBaptiste Daroussin #if !YYBTYACC 1005c5b5d71aSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */ 10060c8de5b0SBaptiste Daroussin yyerrlab: 10070c8de5b0SBaptiste Daroussin #endif 10080c8de5b0SBaptiste Daroussin ++yynerrs; 10090c8de5b0SBaptiste Daroussin 10100c8de5b0SBaptiste Daroussin yyinrecovery: 10110c8de5b0SBaptiste Daroussin if (yyerrflag < 3) 10120c8de5b0SBaptiste Daroussin { 10130c8de5b0SBaptiste Daroussin yyerrflag = 3; 10140c8de5b0SBaptiste Daroussin for (;;) 10150c8de5b0SBaptiste Daroussin { 10160c8de5b0SBaptiste Daroussin if (((yyn = yysindex[*yystack.s_mark]) != 0) && (yyn += YYERRCODE) >= 0 && 10170c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) YYERRCODE) 10180c8de5b0SBaptiste Daroussin { 10190c8de5b0SBaptiste Daroussin #if YYDEBUG 10200c8de5b0SBaptiste Daroussin if (yydebug) 10210c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, error recovery shifting to state %d\n", 10220c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, *yystack.s_mark, yytable[yyn]); 10230c8de5b0SBaptiste Daroussin #endif 10240c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 10250c8de5b0SBaptiste Daroussin yystate = yytable[yyn]; 10260c8de5b0SBaptiste Daroussin *++yystack.s_mark = yytable[yyn]; 10270c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval; 10280c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 10290c8de5b0SBaptiste Daroussin /* lookahead position is error end position */ 1030*b53bb29fSJung-uk Kim yyerror_loc_range[2] = yylloc; 10310c8de5b0SBaptiste Daroussin YYLLOC_DEFAULT(yyloc, yyerror_loc_range, 2); /* position of error span */ 10320c8de5b0SBaptiste Daroussin *++yystack.p_mark = yyloc; 10330c8de5b0SBaptiste Daroussin #endif 10340c8de5b0SBaptiste Daroussin goto yyloop; 10350c8de5b0SBaptiste Daroussin } 10360c8de5b0SBaptiste Daroussin else 10370c8de5b0SBaptiste Daroussin { 10380c8de5b0SBaptiste Daroussin #if YYDEBUG 10390c8de5b0SBaptiste Daroussin if (yydebug) 10400c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: error recovery discarding state %d\n", 10410c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, *yystack.s_mark); 10420c8de5b0SBaptiste Daroussin #endif 10430c8de5b0SBaptiste Daroussin if (yystack.s_mark <= yystack.s_base) goto yyabort; 10440c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 10450c8de5b0SBaptiste Daroussin /* the current TOS position is the error start position */ 1046*b53bb29fSJung-uk Kim yyerror_loc_range[1] = *yystack.p_mark; 10470c8de5b0SBaptiste Daroussin #endif 10480c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL) 10490c8de5b0SBaptiste Daroussin #if YYBTYACC 10500c8de5b0SBaptiste Daroussin if (!yytrial) 10510c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 10520c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 10530c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding state", 10540c8de5b0SBaptiste Daroussin yystos[*yystack.s_mark], yystack.l_mark, yystack.p_mark); 10550c8de5b0SBaptiste Daroussin #else 10560c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding state", 10570c8de5b0SBaptiste Daroussin yystos[*yystack.s_mark], yystack.l_mark); 10580c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 10590c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */ 10600c8de5b0SBaptiste Daroussin --yystack.s_mark; 10610c8de5b0SBaptiste Daroussin --yystack.l_mark; 10620c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 10630c8de5b0SBaptiste Daroussin --yystack.p_mark; 10640c8de5b0SBaptiste Daroussin #endif 10650c8de5b0SBaptiste Daroussin } 10660c8de5b0SBaptiste Daroussin } 10670c8de5b0SBaptiste Daroussin } 10680c8de5b0SBaptiste Daroussin else 10690c8de5b0SBaptiste Daroussin { 10700c8de5b0SBaptiste Daroussin if (yychar == YYEOF) goto yyabort; 10710c8de5b0SBaptiste Daroussin #if YYDEBUG 10720c8de5b0SBaptiste Daroussin if (yydebug) 10730c8de5b0SBaptiste Daroussin { 1074c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 10750c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, error recovery discarding token %d (%s)\n", 10760c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yychar, yys); 10770c8de5b0SBaptiste Daroussin } 10780c8de5b0SBaptiste Daroussin #endif 10790c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL) 10800c8de5b0SBaptiste Daroussin #if YYBTYACC 10810c8de5b0SBaptiste Daroussin if (!yytrial) 10820c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 10830c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 10840c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding token", yychar, &yylval, &yylloc); 10850c8de5b0SBaptiste Daroussin #else 10860c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding token", yychar, &yylval); 10870c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 10880c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */ 10890c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 10900c8de5b0SBaptiste Daroussin goto yyloop; 10910c8de5b0SBaptiste Daroussin } 10920c8de5b0SBaptiste Daroussin 10930c8de5b0SBaptiste Daroussin yyreduce: 10940c8de5b0SBaptiste Daroussin yym = yylen[yyn]; 10950c8de5b0SBaptiste Daroussin #if YYDEBUG 10960c8de5b0SBaptiste Daroussin if (yydebug) 10970c8de5b0SBaptiste Daroussin { 10980c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, reducing by rule %d (%s)", 10990c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyn, yyrule[yyn]); 11000c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING 11010c8de5b0SBaptiste Daroussin #if YYBTYACC 11020c8de5b0SBaptiste Daroussin if (!yytrial) 11030c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 11040c8de5b0SBaptiste Daroussin if (yym > 0) 11050c8de5b0SBaptiste Daroussin { 11060c8de5b0SBaptiste Daroussin int i; 11070c8de5b0SBaptiste Daroussin fputc('<', stderr); 11080c8de5b0SBaptiste Daroussin for (i = yym; i > 0; i--) 11090c8de5b0SBaptiste Daroussin { 11100c8de5b0SBaptiste Daroussin if (i != yym) fputs(", ", stderr); 11110c8de5b0SBaptiste Daroussin fputs(YYSTYPE_TOSTRING(yystos[yystack.s_mark[1-i]], 11120c8de5b0SBaptiste Daroussin yystack.l_mark[1-i]), stderr); 11130c8de5b0SBaptiste Daroussin } 11140c8de5b0SBaptiste Daroussin fputc('>', stderr); 11150c8de5b0SBaptiste Daroussin } 11160c8de5b0SBaptiste Daroussin #endif 11170c8de5b0SBaptiste Daroussin fputc('\n', stderr); 11180c8de5b0SBaptiste Daroussin } 11190c8de5b0SBaptiste Daroussin #endif 11200c8de5b0SBaptiste Daroussin if (yym > 0) 11210c8de5b0SBaptiste Daroussin yyval = yystack.l_mark[1-yym]; 11220c8de5b0SBaptiste Daroussin else 11230c8de5b0SBaptiste Daroussin memset(&yyval, 0, sizeof yyval); 11240c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 11250c8de5b0SBaptiste Daroussin 11260c8de5b0SBaptiste Daroussin /* Perform position reduction */ 11270c8de5b0SBaptiste Daroussin memset(&yyloc, 0, sizeof(yyloc)); 11280c8de5b0SBaptiste Daroussin #if YYBTYACC 11290c8de5b0SBaptiste Daroussin if (!yytrial) 11300c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 11310c8de5b0SBaptiste Daroussin { 1132*b53bb29fSJung-uk Kim YYLLOC_DEFAULT(yyloc, &yystack.p_mark[-yym], yym); 11330c8de5b0SBaptiste Daroussin /* just in case YYERROR is invoked within the action, save 11340c8de5b0SBaptiste Daroussin the start of the rhs as the error start position */ 1135*b53bb29fSJung-uk Kim yyerror_loc_range[1] = yystack.p_mark[1-yym]; 11360c8de5b0SBaptiste Daroussin } 11370c8de5b0SBaptiste Daroussin #endif 11380c8de5b0SBaptiste Daroussin 11390c8de5b0SBaptiste Daroussin switch (yyn) 11400c8de5b0SBaptiste Daroussin { 11410c8de5b0SBaptiste Daroussin case 1: 11420c8de5b0SBaptiste Daroussin #line 50 "inherit2.y" 11430c8de5b0SBaptiste Daroussin yyval.cval = yystack.l_mark[-1].cval; 11440c8de5b0SBaptiste Daroussin break; 11450c8de5b0SBaptiste Daroussin case 2: 11460c8de5b0SBaptiste Daroussin #line 50 "inherit2.y" 11470c8de5b0SBaptiste Daroussin yyval.tval = yystack.l_mark[-1].tval; 11480c8de5b0SBaptiste Daroussin break; 11490c8de5b0SBaptiste Daroussin case 3: 11500c8de5b0SBaptiste Daroussin #line 51 "inherit2.y" 11510c8de5b0SBaptiste Daroussin { yyval.nlist = yystack.l_mark[0].nlist; } 11520c8de5b0SBaptiste Daroussin break; 11530c8de5b0SBaptiste Daroussin case 4: 11540c8de5b0SBaptiste Daroussin #line 53 "inherit2.y" 11550c8de5b0SBaptiste Daroussin { yyval.nlist = yystack.l_mark[0].nlist; } 11560c8de5b0SBaptiste Daroussin break; 1157c5b5d71aSJung-uk Kim case 5: 11580c8de5b0SBaptiste Daroussin #line 56 "inherit2.y" 11590c8de5b0SBaptiste Daroussin { yyval.cval = cGLOBAL; } 11600c8de5b0SBaptiste Daroussin break; 1161c5b5d71aSJung-uk Kim case 6: 11620c8de5b0SBaptiste Daroussin #line 57 "inherit2.y" 11630c8de5b0SBaptiste Daroussin { yyval.cval = cLOCAL; } 11640c8de5b0SBaptiste Daroussin break; 1165c5b5d71aSJung-uk Kim case 7: 11660c8de5b0SBaptiste Daroussin #line 60 "inherit2.y" 11670c8de5b0SBaptiste Daroussin { yyval.tval = tREAL; } 11680c8de5b0SBaptiste Daroussin break; 1169c5b5d71aSJung-uk Kim case 8: 11700c8de5b0SBaptiste Daroussin #line 61 "inherit2.y" 11710c8de5b0SBaptiste Daroussin { yyval.tval = tINTEGER; } 11720c8de5b0SBaptiste Daroussin break; 1173c5b5d71aSJung-uk Kim case 9: 11740c8de5b0SBaptiste Daroussin #line 65 "inherit2.y" 11750c8de5b0SBaptiste Daroussin { yyval.nlist->s = mksymbol(yystack.l_mark[-2].tval, yystack.l_mark[-3].cval, yystack.l_mark[0].id); 11760c8de5b0SBaptiste Daroussin yyval.nlist->next = yystack.l_mark[-1].nlist; 11770c8de5b0SBaptiste Daroussin } 11780c8de5b0SBaptiste Daroussin break; 1179c5b5d71aSJung-uk Kim case 10: 11800c8de5b0SBaptiste Daroussin #line 69 "inherit2.y" 11810c8de5b0SBaptiste Daroussin { yyval.nlist->s = mksymbol(yystack.l_mark[-1].tval, yystack.l_mark[-2].cval, yystack.l_mark[0].id); 11820c8de5b0SBaptiste Daroussin yyval.nlist->next = NULL; 11830c8de5b0SBaptiste Daroussin } 11840c8de5b0SBaptiste Daroussin break; 1185c5b5d71aSJung-uk Kim case 11: 11860c8de5b0SBaptiste Daroussin #line 74 "inherit2.y" 11870c8de5b0SBaptiste Daroussin yyval.cval = cLOCAL; 11880c8de5b0SBaptiste Daroussin break; 1189c5b5d71aSJung-uk Kim case 12: 11900c8de5b0SBaptiste Daroussin #line 75 "inherit2.y" 11910c8de5b0SBaptiste Daroussin { yyval.nlist = yystack.l_mark[0].nlist; } 11920c8de5b0SBaptiste Daroussin break; 1193*b53bb29fSJung-uk Kim #line 1194 "inherit2.tab.c" 11940c8de5b0SBaptiste Daroussin default: 11950c8de5b0SBaptiste Daroussin break; 11960c8de5b0SBaptiste Daroussin } 11970c8de5b0SBaptiste Daroussin yystack.s_mark -= yym; 11980c8de5b0SBaptiste Daroussin yystate = *yystack.s_mark; 11990c8de5b0SBaptiste Daroussin yystack.l_mark -= yym; 12000c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 12010c8de5b0SBaptiste Daroussin yystack.p_mark -= yym; 12020c8de5b0SBaptiste Daroussin #endif 12030c8de5b0SBaptiste Daroussin yym = yylhs[yyn]; 12040c8de5b0SBaptiste Daroussin if (yystate == 0 && yym == 0) 12050c8de5b0SBaptiste Daroussin { 12060c8de5b0SBaptiste Daroussin #if YYDEBUG 12070c8de5b0SBaptiste Daroussin if (yydebug) 12080c8de5b0SBaptiste Daroussin { 12090c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: after reduction, ", YYDEBUGSTR, yydepth); 12100c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING 12110c8de5b0SBaptiste Daroussin #if YYBTYACC 12120c8de5b0SBaptiste Daroussin if (!yytrial) 12130c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 12140c8de5b0SBaptiste Daroussin fprintf(stderr, "result is <%s>, ", YYSTYPE_TOSTRING(yystos[YYFINAL], yyval)); 12150c8de5b0SBaptiste Daroussin #endif 12160c8de5b0SBaptiste Daroussin fprintf(stderr, "shifting from state 0 to final state %d\n", YYFINAL); 12170c8de5b0SBaptiste Daroussin } 12180c8de5b0SBaptiste Daroussin #endif 12190c8de5b0SBaptiste Daroussin yystate = YYFINAL; 12200c8de5b0SBaptiste Daroussin *++yystack.s_mark = YYFINAL; 12210c8de5b0SBaptiste Daroussin *++yystack.l_mark = yyval; 12220c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 12230c8de5b0SBaptiste Daroussin *++yystack.p_mark = yyloc; 12240c8de5b0SBaptiste Daroussin #endif 12250c8de5b0SBaptiste Daroussin if (yychar < 0) 12260c8de5b0SBaptiste Daroussin { 12270c8de5b0SBaptiste Daroussin #if YYBTYACC 12280c8de5b0SBaptiste Daroussin do { 12290c8de5b0SBaptiste Daroussin if (yylvp < yylve) 12300c8de5b0SBaptiste Daroussin { 12310c8de5b0SBaptiste Daroussin /* we're currently re-reading tokens */ 12320c8de5b0SBaptiste Daroussin yylval = *yylvp++; 12330c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 12340c8de5b0SBaptiste Daroussin yylloc = *yylpp++; 12350c8de5b0SBaptiste Daroussin #endif 12360c8de5b0SBaptiste Daroussin yychar = *yylexp++; 12370c8de5b0SBaptiste Daroussin break; 12380c8de5b0SBaptiste Daroussin } 12390c8de5b0SBaptiste Daroussin if (yyps->save) 12400c8de5b0SBaptiste Daroussin { 12410c8de5b0SBaptiste Daroussin /* in trial mode; save scanner results for future parse attempts */ 12420c8de5b0SBaptiste Daroussin if (yylvp == yylvlim) 12430c8de5b0SBaptiste Daroussin { /* Enlarge lexical value queue */ 124411fce282SBaptiste Daroussin size_t p = (size_t) (yylvp - yylvals); 124511fce282SBaptiste Daroussin size_t s = (size_t) (yylvlim - yylvals); 12460c8de5b0SBaptiste Daroussin 12470c8de5b0SBaptiste Daroussin s += YYLVQUEUEGROWTH; 1248*b53bb29fSJung-uk Kim if ((yylexemes = (YYINT *)realloc(yylexemes, s * sizeof(YYINT))) == NULL) 12490c8de5b0SBaptiste Daroussin goto yyenomem; 1250*b53bb29fSJung-uk Kim if ((yylvals = (YYSTYPE *)realloc(yylvals, s * sizeof(YYSTYPE))) == NULL) 12510c8de5b0SBaptiste Daroussin goto yyenomem; 12520c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1253*b53bb29fSJung-uk Kim if ((yylpsns = (YYLTYPE *)realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL) 12540c8de5b0SBaptiste Daroussin goto yyenomem; 12550c8de5b0SBaptiste Daroussin #endif 12560c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals + p; 12570c8de5b0SBaptiste Daroussin yylvlim = yylvals + s; 12580c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 12590c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns + p; 12600c8de5b0SBaptiste Daroussin yylplim = yylpsns + s; 12610c8de5b0SBaptiste Daroussin #endif 12620c8de5b0SBaptiste Daroussin yylexp = yylexemes + p; 12630c8de5b0SBaptiste Daroussin } 12642aca18c7SJung-uk Kim *yylexp = (YYINT) YYLEX; 12650c8de5b0SBaptiste Daroussin *yylvp++ = yylval; 12660c8de5b0SBaptiste Daroussin yylve++; 12670c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 12680c8de5b0SBaptiste Daroussin *yylpp++ = yylloc; 12690c8de5b0SBaptiste Daroussin yylpe++; 12700c8de5b0SBaptiste Daroussin #endif 12710c8de5b0SBaptiste Daroussin yychar = *yylexp++; 12720c8de5b0SBaptiste Daroussin break; 12730c8de5b0SBaptiste Daroussin } 12740c8de5b0SBaptiste Daroussin /* normal operation, no conflict encountered */ 12750c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 12760c8de5b0SBaptiste Daroussin yychar = YYLEX; 12770c8de5b0SBaptiste Daroussin #if YYBTYACC 12780c8de5b0SBaptiste Daroussin } while (0); 12790c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 12800c8de5b0SBaptiste Daroussin if (yychar < 0) yychar = YYEOF; 12810c8de5b0SBaptiste Daroussin #if YYDEBUG 12820c8de5b0SBaptiste Daroussin if (yydebug) 12830c8de5b0SBaptiste Daroussin { 1284c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 1285c5b5d71aSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)\n", 12860c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, YYFINAL, yychar, yys); 12870c8de5b0SBaptiste Daroussin } 12880c8de5b0SBaptiste Daroussin #endif 12890c8de5b0SBaptiste Daroussin } 12900c8de5b0SBaptiste Daroussin if (yychar == YYEOF) goto yyaccept; 12910c8de5b0SBaptiste Daroussin goto yyloop; 12920c8de5b0SBaptiste Daroussin } 12930c8de5b0SBaptiste Daroussin if (((yyn = yygindex[yym]) != 0) && (yyn += yystate) >= 0 && 12940c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yystate) 12950c8de5b0SBaptiste Daroussin yystate = yytable[yyn]; 12960c8de5b0SBaptiste Daroussin else 12970c8de5b0SBaptiste Daroussin yystate = yydgoto[yym]; 12980c8de5b0SBaptiste Daroussin #if YYDEBUG 12990c8de5b0SBaptiste Daroussin if (yydebug) 13000c8de5b0SBaptiste Daroussin { 13010c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: after reduction, ", YYDEBUGSTR, yydepth); 13020c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING 13030c8de5b0SBaptiste Daroussin #if YYBTYACC 13040c8de5b0SBaptiste Daroussin if (!yytrial) 13050c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 13060c8de5b0SBaptiste Daroussin fprintf(stderr, "result is <%s>, ", YYSTYPE_TOSTRING(yystos[yystate], yyval)); 13070c8de5b0SBaptiste Daroussin #endif 13080c8de5b0SBaptiste Daroussin fprintf(stderr, "shifting from state %d to state %d\n", *yystack.s_mark, yystate); 13090c8de5b0SBaptiste Daroussin } 13100c8de5b0SBaptiste Daroussin #endif 13110c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 1312c5b5d71aSJung-uk Kim *++yystack.s_mark = (YYINT) yystate; 13130c8de5b0SBaptiste Daroussin *++yystack.l_mark = yyval; 13140c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 13150c8de5b0SBaptiste Daroussin *++yystack.p_mark = yyloc; 13160c8de5b0SBaptiste Daroussin #endif 13170c8de5b0SBaptiste Daroussin goto yyloop; 13180c8de5b0SBaptiste Daroussin #if YYBTYACC 13190c8de5b0SBaptiste Daroussin 13200c8de5b0SBaptiste Daroussin /* Reduction declares that this path is valid. Set yypath and do a full parse */ 13210c8de5b0SBaptiste Daroussin yyvalid: 13220c8de5b0SBaptiste Daroussin if (yypath) YYABORT; 13230c8de5b0SBaptiste Daroussin while (yyps->save) 13240c8de5b0SBaptiste Daroussin { 13250c8de5b0SBaptiste Daroussin YYParseState *save = yyps->save; 13260c8de5b0SBaptiste Daroussin yyps->save = save->save; 13270c8de5b0SBaptiste Daroussin save->save = yypath; 13280c8de5b0SBaptiste Daroussin yypath = save; 13290c8de5b0SBaptiste Daroussin } 13300c8de5b0SBaptiste Daroussin #if YYDEBUG 13310c8de5b0SBaptiste Daroussin if (yydebug) 13320c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, CONFLICT trial successful, backtracking to state %d, %d tokens\n", 13330c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yypath->state, (int)(yylvp - yylvals - yypath->lexeme)); 13340c8de5b0SBaptiste Daroussin #endif 13350c8de5b0SBaptiste Daroussin if (yyerrctx) 13360c8de5b0SBaptiste Daroussin { 13370c8de5b0SBaptiste Daroussin yyFreeState(yyerrctx); 13380c8de5b0SBaptiste Daroussin yyerrctx = NULL; 13390c8de5b0SBaptiste Daroussin } 13400c8de5b0SBaptiste Daroussin yylvp = yylvals + yypath->lexeme; 13410c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 13420c8de5b0SBaptiste Daroussin yylpp = yylpsns + yypath->lexeme; 13430c8de5b0SBaptiste Daroussin #endif 13440c8de5b0SBaptiste Daroussin yylexp = yylexemes + yypath->lexeme; 13450c8de5b0SBaptiste Daroussin yychar = YYEMPTY; 13460c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (yypath->yystack.s_mark - yypath->yystack.s_base); 1347c5b5d71aSJung-uk Kim memcpy (yystack.s_base, yypath->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 13480c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (yypath->yystack.l_mark - yypath->yystack.l_base); 134911fce282SBaptiste Daroussin memcpy (yystack.l_base, yypath->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 13500c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 13510c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (yypath->yystack.p_mark - yypath->yystack.p_base); 135211fce282SBaptiste Daroussin memcpy (yystack.p_base, yypath->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 13530c8de5b0SBaptiste Daroussin #endif 13540c8de5b0SBaptiste Daroussin yystate = yypath->state; 13550c8de5b0SBaptiste Daroussin goto yyloop; 13560c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 13570c8de5b0SBaptiste Daroussin 13580c8de5b0SBaptiste Daroussin yyoverflow: 13590c8de5b0SBaptiste Daroussin YYERROR_CALL("yacc stack overflow"); 13600c8de5b0SBaptiste Daroussin #if YYBTYACC 13610c8de5b0SBaptiste Daroussin goto yyabort_nomem; 13620c8de5b0SBaptiste Daroussin yyenomem: 13630c8de5b0SBaptiste Daroussin YYERROR_CALL("memory exhausted"); 13640c8de5b0SBaptiste Daroussin yyabort_nomem: 13650c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 13660c8de5b0SBaptiste Daroussin yyresult = 2; 13670c8de5b0SBaptiste Daroussin goto yyreturn; 13680c8de5b0SBaptiste Daroussin 13690c8de5b0SBaptiste Daroussin yyabort: 13700c8de5b0SBaptiste Daroussin yyresult = 1; 13710c8de5b0SBaptiste Daroussin goto yyreturn; 13720c8de5b0SBaptiste Daroussin 13730c8de5b0SBaptiste Daroussin yyaccept: 13740c8de5b0SBaptiste Daroussin #if YYBTYACC 13750c8de5b0SBaptiste Daroussin if (yyps->save) goto yyvalid; 13760c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 13770c8de5b0SBaptiste Daroussin yyresult = 0; 13780c8de5b0SBaptiste Daroussin 13790c8de5b0SBaptiste Daroussin yyreturn: 13800c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL) 13810c8de5b0SBaptiste Daroussin if (yychar != YYEOF && yychar != YYEMPTY) 13820c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 13830c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding token", yychar, &yylval, &yylloc); 13840c8de5b0SBaptiste Daroussin #else 13850c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding token", yychar, &yylval); 13860c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 13870c8de5b0SBaptiste Daroussin 13880c8de5b0SBaptiste Daroussin { 13890c8de5b0SBaptiste Daroussin YYSTYPE *pv; 13900c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 13910c8de5b0SBaptiste Daroussin YYLTYPE *pp; 13920c8de5b0SBaptiste Daroussin 13930c8de5b0SBaptiste Daroussin for (pv = yystack.l_base, pp = yystack.p_base; pv <= yystack.l_mark; ++pv, ++pp) 13940c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding state", 13950c8de5b0SBaptiste Daroussin yystos[*(yystack.s_base + (pv - yystack.l_base))], pv, pp); 13960c8de5b0SBaptiste Daroussin #else 13970c8de5b0SBaptiste Daroussin for (pv = yystack.l_base; pv <= yystack.l_mark; ++pv) 13980c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding state", 13990c8de5b0SBaptiste Daroussin yystos[*(yystack.s_base + (pv - yystack.l_base))], pv); 14000c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 14010c8de5b0SBaptiste Daroussin } 14020c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */ 14030c8de5b0SBaptiste Daroussin 14040c8de5b0SBaptiste Daroussin #if YYBTYACC 14050c8de5b0SBaptiste Daroussin if (yyerrctx) 14060c8de5b0SBaptiste Daroussin { 14070c8de5b0SBaptiste Daroussin yyFreeState(yyerrctx); 14080c8de5b0SBaptiste Daroussin yyerrctx = NULL; 14090c8de5b0SBaptiste Daroussin } 14100c8de5b0SBaptiste Daroussin while (yyps) 14110c8de5b0SBaptiste Daroussin { 14120c8de5b0SBaptiste Daroussin YYParseState *save = yyps; 14130c8de5b0SBaptiste Daroussin yyps = save->save; 14140c8de5b0SBaptiste Daroussin save->save = NULL; 14150c8de5b0SBaptiste Daroussin yyFreeState(save); 14160c8de5b0SBaptiste Daroussin } 14170c8de5b0SBaptiste Daroussin while (yypath) 14180c8de5b0SBaptiste Daroussin { 14190c8de5b0SBaptiste Daroussin YYParseState *save = yypath; 14200c8de5b0SBaptiste Daroussin yypath = save->save; 14210c8de5b0SBaptiste Daroussin save->save = NULL; 14220c8de5b0SBaptiste Daroussin yyFreeState(save); 14230c8de5b0SBaptiste Daroussin } 14240c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */ 14250c8de5b0SBaptiste Daroussin yyfreestack(&yystack); 14260c8de5b0SBaptiste Daroussin return (yyresult); 14270c8de5b0SBaptiste Daroussin } 1428