1*b53bb29fSJung-uk Kim /* original parser id follows */ 2*b53bb29fSJung-uk Kim /* yysccsid[] = "@(#)yaccpar 1.9 (Berkeley) 02/21/93" */ 3*b53bb29fSJung-uk Kim /* (use YYMAJOR/YYMINOR for ifdefs dependent on parser version) */ 4*b53bb29fSJung-uk Kim 5*b53bb29fSJung-uk Kim #define YYBYACC 1 6*b53bb29fSJung-uk Kim #define YYMAJOR 1 7*b53bb29fSJung-uk Kim #define YYMINOR 9 8*b53bb29fSJung-uk Kim #define YYCHECK "yyyymmdd" 9*b53bb29fSJung-uk Kim 10*b53bb29fSJung-uk Kim #define YYEMPTY (-1) 11*b53bb29fSJung-uk Kim #define yyclearin (yychar = YYEMPTY) 12*b53bb29fSJung-uk Kim #define yyerrok (yyerrflag = 0) 13*b53bb29fSJung-uk Kim #define YYRECOVERING() (yyerrflag != 0) 14*b53bb29fSJung-uk Kim #define YYENOMEM (-2) 15*b53bb29fSJung-uk Kim #define YYEOF 0 16*b53bb29fSJung-uk Kim #undef YYBTYACC 17*b53bb29fSJung-uk Kim #define YYBTYACC 0 18*b53bb29fSJung-uk Kim #define YYDEBUGSTR YYPREFIX "debug" 19*b53bb29fSJung-uk Kim #define YYPREFIX "yy" 20*b53bb29fSJung-uk Kim 21*b53bb29fSJung-uk Kim #define YYPURE 0 22*b53bb29fSJung-uk Kim 23*b53bb29fSJung-uk Kim #line 2 "calc.y" 24*b53bb29fSJung-uk Kim # include <stdio.h> 25*b53bb29fSJung-uk Kim # include <ctype.h> 26*b53bb29fSJung-uk Kim 27*b53bb29fSJung-uk Kim int regs[26]; 28*b53bb29fSJung-uk Kim int base; 29*b53bb29fSJung-uk Kim 30*b53bb29fSJung-uk Kim extern int yylex(void); 31*b53bb29fSJung-uk Kim static void yyerror(const char *s); 32*b53bb29fSJung-uk Kim 33*b53bb29fSJung-uk Kim #line 34 "stdin2.calc.c" 34*b53bb29fSJung-uk Kim 35*b53bb29fSJung-uk Kim #if ! defined(YYSTYPE) && ! defined(YYSTYPE_IS_DECLARED) 36*b53bb29fSJung-uk Kim /* Default: YYSTYPE is the semantic value type. */ 37*b53bb29fSJung-uk Kim typedef int YYSTYPE; 38*b53bb29fSJung-uk Kim # define YYSTYPE_IS_DECLARED 1 39*b53bb29fSJung-uk Kim #endif 40*b53bb29fSJung-uk Kim 41*b53bb29fSJung-uk Kim /* compatibility with bison */ 42*b53bb29fSJung-uk Kim #ifdef YYPARSE_PARAM 43*b53bb29fSJung-uk Kim /* compatibility with FreeBSD */ 44*b53bb29fSJung-uk Kim # ifdef YYPARSE_PARAM_TYPE 45*b53bb29fSJung-uk Kim # define YYPARSE_DECL() yyparse(YYPARSE_PARAM_TYPE YYPARSE_PARAM) 46*b53bb29fSJung-uk Kim # else 47*b53bb29fSJung-uk Kim # define YYPARSE_DECL() yyparse(void *YYPARSE_PARAM) 48*b53bb29fSJung-uk Kim # endif 49*b53bb29fSJung-uk Kim #else 50*b53bb29fSJung-uk Kim # define YYPARSE_DECL() yyparse(void) 51*b53bb29fSJung-uk Kim #endif 52*b53bb29fSJung-uk Kim 53*b53bb29fSJung-uk Kim /* Parameters sent to lex. */ 54*b53bb29fSJung-uk Kim #ifdef YYLEX_PARAM 55*b53bb29fSJung-uk Kim # define YYLEX_DECL() yylex(void *YYLEX_PARAM) 56*b53bb29fSJung-uk Kim # define YYLEX yylex(YYLEX_PARAM) 57*b53bb29fSJung-uk Kim #else 58*b53bb29fSJung-uk Kim # define YYLEX_DECL() yylex(void) 59*b53bb29fSJung-uk Kim # define YYLEX yylex() 60*b53bb29fSJung-uk Kim #endif 61*b53bb29fSJung-uk Kim 62*b53bb29fSJung-uk Kim #if !(defined(yylex) || defined(YYSTATE)) 63*b53bb29fSJung-uk Kim int YYLEX_DECL(); 64*b53bb29fSJung-uk Kim #endif 65*b53bb29fSJung-uk Kim 66*b53bb29fSJung-uk Kim /* Parameters sent to yyerror. */ 67*b53bb29fSJung-uk Kim #ifndef YYERROR_DECL 68*b53bb29fSJung-uk Kim #define YYERROR_DECL() yyerror(const char *s) 69*b53bb29fSJung-uk Kim #endif 70*b53bb29fSJung-uk Kim #ifndef YYERROR_CALL 71*b53bb29fSJung-uk Kim #define YYERROR_CALL(msg) yyerror(msg) 72*b53bb29fSJung-uk Kim #endif 73*b53bb29fSJung-uk Kim 74*b53bb29fSJung-uk Kim extern int YYPARSE_DECL(); 75*b53bb29fSJung-uk Kim 76*b53bb29fSJung-uk Kim #define DIGIT 257 77*b53bb29fSJung-uk Kim #define LETTER 258 78*b53bb29fSJung-uk Kim #define UMINUS 259 79*b53bb29fSJung-uk Kim #define YYERRCODE 256 80*b53bb29fSJung-uk Kim typedef int YYINT; 81*b53bb29fSJung-uk Kim static const YYINT yylhs[] = { -1, 82*b53bb29fSJung-uk Kim 0, 0, 0, 1, 1, 2, 2, 2, 2, 2, 83*b53bb29fSJung-uk Kim 2, 2, 2, 2, 2, 2, 3, 3, 84*b53bb29fSJung-uk Kim }; 85*b53bb29fSJung-uk Kim static const YYINT yylen[] = { 2, 86*b53bb29fSJung-uk Kim 0, 3, 3, 1, 3, 3, 3, 3, 3, 3, 87*b53bb29fSJung-uk Kim 3, 3, 3, 2, 1, 1, 1, 2, 88*b53bb29fSJung-uk Kim }; 89*b53bb29fSJung-uk Kim static const YYINT yydefred[] = { 1, 90*b53bb29fSJung-uk Kim 0, 0, 17, 0, 0, 0, 0, 0, 0, 3, 91*b53bb29fSJung-uk Kim 0, 15, 14, 0, 2, 0, 0, 0, 0, 0, 92*b53bb29fSJung-uk Kim 0, 0, 18, 0, 6, 0, 0, 0, 0, 9, 93*b53bb29fSJung-uk Kim 10, 11, 94*b53bb29fSJung-uk Kim }; 95*b53bb29fSJung-uk Kim #if defined(YYDESTRUCT_CALL) || defined(YYSTYPE_TOSTRING) 96*b53bb29fSJung-uk Kim static const YYINT yystos[] = { 0, 97*b53bb29fSJung-uk Kim 261, 256, 257, 258, 45, 40, 262, 263, 264, 10, 98*b53bb29fSJung-uk Kim 61, 258, 263, 263, 10, 124, 38, 43, 45, 42, 99*b53bb29fSJung-uk Kim 47, 37, 257, 263, 41, 263, 263, 263, 263, 263, 100*b53bb29fSJung-uk Kim 263, 263, 101*b53bb29fSJung-uk Kim }; 102*b53bb29fSJung-uk Kim #endif /* YYDESTRUCT_CALL || YYSTYPE_TOSTRING */ 103*b53bb29fSJung-uk Kim static const YYINT yydgoto[] = { 1, 104*b53bb29fSJung-uk Kim 7, 8, 9, 105*b53bb29fSJung-uk Kim }; 106*b53bb29fSJung-uk Kim static const YYINT yysindex[] = { 0, 107*b53bb29fSJung-uk Kim -40, -7, 0, -55, -38, -38, 1, -29, -247, 0, 108*b53bb29fSJung-uk Kim -38, 0, 0, 22, 0, -38, -38, -38, -38, -38, 109*b53bb29fSJung-uk Kim -38, -38, 0, -29, 0, 51, 60, -20, -20, 0, 110*b53bb29fSJung-uk Kim 0, 0, 111*b53bb29fSJung-uk Kim }; 112*b53bb29fSJung-uk Kim static const YYINT yyrindex[] = { 0, 113*b53bb29fSJung-uk Kim 0, 0, 0, 2, 0, 0, 0, 9, -9, 0, 114*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 115*b53bb29fSJung-uk Kim 0, 0, 0, 10, 0, -6, 14, 5, 13, 0, 116*b53bb29fSJung-uk Kim 0, 0, 117*b53bb29fSJung-uk Kim }; 118*b53bb29fSJung-uk Kim #if YYBTYACC 119*b53bb29fSJung-uk Kim static const YYINT yycindex[] = { 0, 120*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 121*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 122*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 123*b53bb29fSJung-uk Kim 0, 0, 124*b53bb29fSJung-uk Kim }; 125*b53bb29fSJung-uk Kim #endif 126*b53bb29fSJung-uk Kim static const YYINT yygindex[] = { 0, 127*b53bb29fSJung-uk Kim 0, 65, 0, 128*b53bb29fSJung-uk Kim }; 129*b53bb29fSJung-uk Kim #define YYTABLESIZE 220 130*b53bb29fSJung-uk Kim static const YYINT yytable[] = { 6, 131*b53bb29fSJung-uk Kim 16, 6, 10, 13, 5, 11, 5, 22, 17, 23, 132*b53bb29fSJung-uk Kim 15, 15, 20, 18, 7, 19, 22, 21, 4, 5, 133*b53bb29fSJung-uk Kim 0, 20, 8, 12, 0, 0, 21, 16, 16, 0, 134*b53bb29fSJung-uk Kim 0, 16, 16, 16, 13, 16, 0, 16, 15, 15, 135*b53bb29fSJung-uk Kim 0, 0, 7, 15, 15, 7, 15, 7, 15, 7, 136*b53bb29fSJung-uk Kim 8, 12, 0, 8, 12, 8, 0, 8, 22, 17, 137*b53bb29fSJung-uk Kim 0, 0, 25, 20, 18, 0, 19, 0, 21, 13, 138*b53bb29fSJung-uk Kim 14, 0, 0, 0, 0, 24, 0, 0, 0, 0, 139*b53bb29fSJung-uk Kim 26, 27, 28, 29, 30, 31, 32, 22, 17, 0, 140*b53bb29fSJung-uk Kim 0, 0, 20, 18, 16, 19, 22, 21, 0, 0, 141*b53bb29fSJung-uk Kim 0, 20, 18, 0, 19, 0, 21, 0, 0, 0, 142*b53bb29fSJung-uk Kim 0, 0, 0, 0, 16, 0, 0, 13, 0, 0, 143*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 15, 0, 0, 7, 0, 144*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 8, 12, 0, 0, 145*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 16, 0, 0, 0, 0, 146*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 147*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 148*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 149*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 150*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 151*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 152*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 2, 3, 4, 3, 12, 153*b53bb29fSJung-uk Kim }; 154*b53bb29fSJung-uk Kim static const YYINT yycheck[] = { 40, 155*b53bb29fSJung-uk Kim 10, 40, 10, 10, 45, 61, 45, 37, 38, 257, 156*b53bb29fSJung-uk Kim 10, 10, 42, 43, 10, 45, 37, 47, 10, 10, 157*b53bb29fSJung-uk Kim -1, 42, 10, 10, -1, -1, 47, 37, 38, -1, 158*b53bb29fSJung-uk Kim -1, 41, 42, 43, 41, 45, -1, 47, 37, 38, 159*b53bb29fSJung-uk Kim -1, -1, 38, 42, 43, 41, 45, 43, 47, 45, 160*b53bb29fSJung-uk Kim 38, 38, -1, 41, 41, 43, -1, 45, 37, 38, 161*b53bb29fSJung-uk Kim -1, -1, 41, 42, 43, -1, 45, -1, 47, 5, 162*b53bb29fSJung-uk Kim 6, -1, -1, -1, -1, 11, -1, -1, -1, -1, 163*b53bb29fSJung-uk Kim 16, 17, 18, 19, 20, 21, 22, 37, 38, -1, 164*b53bb29fSJung-uk Kim -1, -1, 42, 43, 124, 45, 37, 47, -1, -1, 165*b53bb29fSJung-uk Kim -1, 42, 43, -1, 45, -1, 47, -1, -1, -1, 166*b53bb29fSJung-uk Kim -1, -1, -1, -1, 124, -1, -1, 124, -1, -1, 167*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, 124, -1, -1, 124, -1, 168*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, 124, 124, -1, -1, 169*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, 124, -1, -1, -1, -1, 170*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 171*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 172*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 173*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 174*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 175*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 176*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, 256, 257, 258, 257, 258, 177*b53bb29fSJung-uk Kim }; 178*b53bb29fSJung-uk Kim #if YYBTYACC 179*b53bb29fSJung-uk Kim static const YYINT yyctable[] = { -1, 180*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 181*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 182*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 183*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 184*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 185*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 186*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 187*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 188*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 189*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 190*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 191*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 192*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 193*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 194*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 195*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 196*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 197*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 198*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 199*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 200*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 201*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, 202*b53bb29fSJung-uk Kim }; 203*b53bb29fSJung-uk Kim #endif 204*b53bb29fSJung-uk Kim #define YYFINAL 1 205*b53bb29fSJung-uk Kim #ifndef YYDEBUG 206*b53bb29fSJung-uk Kim #define YYDEBUG 0 207*b53bb29fSJung-uk Kim #endif 208*b53bb29fSJung-uk Kim #define YYMAXTOKEN 259 209*b53bb29fSJung-uk Kim #define YYUNDFTOKEN 265 210*b53bb29fSJung-uk Kim #define YYTRANSLATE(a) ((a) > YYMAXTOKEN ? YYUNDFTOKEN : (a)) 211*b53bb29fSJung-uk Kim #if YYDEBUG 212*b53bb29fSJung-uk Kim static const char *const yyname[] = { 213*b53bb29fSJung-uk Kim 214*b53bb29fSJung-uk Kim "$end",0,0,0,0,0,0,0,0,0,"'\\n'",0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 215*b53bb29fSJung-uk Kim 0,0,0,"'%'","'&'",0,"'('","')'","'*'","'+'",0,"'-'",0,"'/'",0,0,0,0,0,0,0,0,0,0, 216*b53bb29fSJung-uk Kim 0,0,0,"'='",0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 217*b53bb29fSJung-uk Kim 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,"'|'",0,0,0,0,0,0,0,0,0, 218*b53bb29fSJung-uk Kim 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 219*b53bb29fSJung-uk Kim 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 220*b53bb29fSJung-uk Kim 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 221*b53bb29fSJung-uk Kim 0,0,"error","DIGIT","LETTER","UMINUS","$accept","list","stat","expr","number", 222*b53bb29fSJung-uk Kim "illegal-symbol", 223*b53bb29fSJung-uk Kim }; 224*b53bb29fSJung-uk Kim static const char *const yyrule[] = { 225*b53bb29fSJung-uk Kim "$accept : list", 226*b53bb29fSJung-uk Kim "list :", 227*b53bb29fSJung-uk Kim "list : list stat '\\n'", 228*b53bb29fSJung-uk Kim "list : list error '\\n'", 229*b53bb29fSJung-uk Kim "stat : expr", 230*b53bb29fSJung-uk Kim "stat : LETTER '=' expr", 231*b53bb29fSJung-uk Kim "expr : '(' expr ')'", 232*b53bb29fSJung-uk Kim "expr : expr '+' expr", 233*b53bb29fSJung-uk Kim "expr : expr '-' expr", 234*b53bb29fSJung-uk Kim "expr : expr '*' expr", 235*b53bb29fSJung-uk Kim "expr : expr '/' expr", 236*b53bb29fSJung-uk Kim "expr : expr '%' expr", 237*b53bb29fSJung-uk Kim "expr : expr '&' expr", 238*b53bb29fSJung-uk Kim "expr : expr '|' expr", 239*b53bb29fSJung-uk Kim "expr : '-' expr", 240*b53bb29fSJung-uk Kim "expr : LETTER", 241*b53bb29fSJung-uk Kim "expr : number", 242*b53bb29fSJung-uk Kim "number : DIGIT", 243*b53bb29fSJung-uk Kim "number : number DIGIT", 244*b53bb29fSJung-uk Kim 245*b53bb29fSJung-uk Kim }; 246*b53bb29fSJung-uk Kim #endif 247*b53bb29fSJung-uk Kim 248*b53bb29fSJung-uk Kim #if YYDEBUG 249*b53bb29fSJung-uk Kim int yydebug; 250*b53bb29fSJung-uk Kim #endif 251*b53bb29fSJung-uk Kim 252*b53bb29fSJung-uk Kim int yyerrflag; 253*b53bb29fSJung-uk Kim int yychar; 254*b53bb29fSJung-uk Kim YYSTYPE yyval; 255*b53bb29fSJung-uk Kim YYSTYPE yylval; 256*b53bb29fSJung-uk Kim int yynerrs; 257*b53bb29fSJung-uk Kim 258*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 259*b53bb29fSJung-uk Kim YYLTYPE yyloc; /* position returned by actions */ 260*b53bb29fSJung-uk Kim YYLTYPE yylloc; /* position from the lexer */ 261*b53bb29fSJung-uk Kim #endif 262*b53bb29fSJung-uk Kim 263*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 264*b53bb29fSJung-uk Kim #ifndef YYLLOC_DEFAULT 265*b53bb29fSJung-uk Kim #define YYLLOC_DEFAULT(loc, rhs, n) \ 266*b53bb29fSJung-uk Kim do \ 267*b53bb29fSJung-uk Kim { \ 268*b53bb29fSJung-uk Kim if (n == 0) \ 269*b53bb29fSJung-uk Kim { \ 270*b53bb29fSJung-uk Kim (loc).first_line = YYRHSLOC(rhs, 0).last_line; \ 271*b53bb29fSJung-uk Kim (loc).first_column = YYRHSLOC(rhs, 0).last_column; \ 272*b53bb29fSJung-uk Kim (loc).last_line = YYRHSLOC(rhs, 0).last_line; \ 273*b53bb29fSJung-uk Kim (loc).last_column = YYRHSLOC(rhs, 0).last_column; \ 274*b53bb29fSJung-uk Kim } \ 275*b53bb29fSJung-uk Kim else \ 276*b53bb29fSJung-uk Kim { \ 277*b53bb29fSJung-uk Kim (loc).first_line = YYRHSLOC(rhs, 1).first_line; \ 278*b53bb29fSJung-uk Kim (loc).first_column = YYRHSLOC(rhs, 1).first_column; \ 279*b53bb29fSJung-uk Kim (loc).last_line = YYRHSLOC(rhs, n).last_line; \ 280*b53bb29fSJung-uk Kim (loc).last_column = YYRHSLOC(rhs, n).last_column; \ 281*b53bb29fSJung-uk Kim } \ 282*b53bb29fSJung-uk Kim } while (0) 283*b53bb29fSJung-uk Kim #endif /* YYLLOC_DEFAULT */ 284*b53bb29fSJung-uk Kim #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 285*b53bb29fSJung-uk Kim #if YYBTYACC 286*b53bb29fSJung-uk Kim 287*b53bb29fSJung-uk Kim #ifndef YYLVQUEUEGROWTH 288*b53bb29fSJung-uk Kim #define YYLVQUEUEGROWTH 32 289*b53bb29fSJung-uk Kim #endif 290*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 291*b53bb29fSJung-uk Kim 292*b53bb29fSJung-uk Kim /* define the initial stack-sizes */ 293*b53bb29fSJung-uk Kim #ifdef YYSTACKSIZE 294*b53bb29fSJung-uk Kim #undef YYMAXDEPTH 295*b53bb29fSJung-uk Kim #define YYMAXDEPTH YYSTACKSIZE 296*b53bb29fSJung-uk Kim #else 297*b53bb29fSJung-uk Kim #ifdef YYMAXDEPTH 298*b53bb29fSJung-uk Kim #define YYSTACKSIZE YYMAXDEPTH 299*b53bb29fSJung-uk Kim #else 300*b53bb29fSJung-uk Kim #define YYSTACKSIZE 10000 301*b53bb29fSJung-uk Kim #define YYMAXDEPTH 10000 302*b53bb29fSJung-uk Kim #endif 303*b53bb29fSJung-uk Kim #endif 304*b53bb29fSJung-uk Kim 305*b53bb29fSJung-uk Kim #ifndef YYINITSTACKSIZE 306*b53bb29fSJung-uk Kim #define YYINITSTACKSIZE 200 307*b53bb29fSJung-uk Kim #endif 308*b53bb29fSJung-uk Kim 309*b53bb29fSJung-uk Kim typedef struct { 310*b53bb29fSJung-uk Kim unsigned stacksize; 311*b53bb29fSJung-uk Kim YYINT *s_base; 312*b53bb29fSJung-uk Kim YYINT *s_mark; 313*b53bb29fSJung-uk Kim YYINT *s_last; 314*b53bb29fSJung-uk Kim YYSTYPE *l_base; 315*b53bb29fSJung-uk Kim YYSTYPE *l_mark; 316*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 317*b53bb29fSJung-uk Kim YYLTYPE *p_base; 318*b53bb29fSJung-uk Kim YYLTYPE *p_mark; 319*b53bb29fSJung-uk Kim #endif 320*b53bb29fSJung-uk Kim } YYSTACKDATA; 321*b53bb29fSJung-uk Kim #if YYBTYACC 322*b53bb29fSJung-uk Kim 323*b53bb29fSJung-uk Kim struct YYParseState_s 324*b53bb29fSJung-uk Kim { 325*b53bb29fSJung-uk Kim struct YYParseState_s *save; /* Previously saved parser state */ 326*b53bb29fSJung-uk Kim YYSTACKDATA yystack; /* saved parser stack */ 327*b53bb29fSJung-uk Kim int state; /* saved parser state */ 328*b53bb29fSJung-uk Kim int errflag; /* saved error recovery status */ 329*b53bb29fSJung-uk Kim int lexeme; /* saved index of the conflict lexeme in the lexical queue */ 330*b53bb29fSJung-uk Kim YYINT ctry; /* saved index in yyctable[] for this conflict */ 331*b53bb29fSJung-uk Kim }; 332*b53bb29fSJung-uk Kim typedef struct YYParseState_s YYParseState; 333*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 334*b53bb29fSJung-uk Kim /* variables for the parser stack */ 335*b53bb29fSJung-uk Kim static YYSTACKDATA yystack; 336*b53bb29fSJung-uk Kim #if YYBTYACC 337*b53bb29fSJung-uk Kim 338*b53bb29fSJung-uk Kim /* Current parser state */ 339*b53bb29fSJung-uk Kim static YYParseState *yyps = 0; 340*b53bb29fSJung-uk Kim 341*b53bb29fSJung-uk Kim /* yypath != NULL: do the full parse, starting at *yypath parser state. */ 342*b53bb29fSJung-uk Kim static YYParseState *yypath = 0; 343*b53bb29fSJung-uk Kim 344*b53bb29fSJung-uk Kim /* Base of the lexical value queue */ 345*b53bb29fSJung-uk Kim static YYSTYPE *yylvals = 0; 346*b53bb29fSJung-uk Kim 347*b53bb29fSJung-uk Kim /* Current position at lexical value queue */ 348*b53bb29fSJung-uk Kim static YYSTYPE *yylvp = 0; 349*b53bb29fSJung-uk Kim 350*b53bb29fSJung-uk Kim /* End position of lexical value queue */ 351*b53bb29fSJung-uk Kim static YYSTYPE *yylve = 0; 352*b53bb29fSJung-uk Kim 353*b53bb29fSJung-uk Kim /* The last allocated position at the lexical value queue */ 354*b53bb29fSJung-uk Kim static YYSTYPE *yylvlim = 0; 355*b53bb29fSJung-uk Kim 356*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 357*b53bb29fSJung-uk Kim /* Base of the lexical position queue */ 358*b53bb29fSJung-uk Kim static YYLTYPE *yylpsns = 0; 359*b53bb29fSJung-uk Kim 360*b53bb29fSJung-uk Kim /* Current position at lexical position queue */ 361*b53bb29fSJung-uk Kim static YYLTYPE *yylpp = 0; 362*b53bb29fSJung-uk Kim 363*b53bb29fSJung-uk Kim /* End position of lexical position queue */ 364*b53bb29fSJung-uk Kim static YYLTYPE *yylpe = 0; 365*b53bb29fSJung-uk Kim 366*b53bb29fSJung-uk Kim /* The last allocated position at the lexical position queue */ 367*b53bb29fSJung-uk Kim static YYLTYPE *yylplim = 0; 368*b53bb29fSJung-uk Kim #endif 369*b53bb29fSJung-uk Kim 370*b53bb29fSJung-uk Kim /* Current position at lexical token queue */ 371*b53bb29fSJung-uk Kim static YYINT *yylexp = 0; 372*b53bb29fSJung-uk Kim 373*b53bb29fSJung-uk Kim static YYINT *yylexemes = 0; 374*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 375*b53bb29fSJung-uk Kim #line 66 "calc.y" 376*b53bb29fSJung-uk Kim /* start of programs */ 377*b53bb29fSJung-uk Kim 378*b53bb29fSJung-uk Kim int 379*b53bb29fSJung-uk Kim main (void) 380*b53bb29fSJung-uk Kim { 381*b53bb29fSJung-uk Kim while(!feof(stdin)) { 382*b53bb29fSJung-uk Kim yyparse(); 383*b53bb29fSJung-uk Kim } 384*b53bb29fSJung-uk Kim return 0; 385*b53bb29fSJung-uk Kim } 386*b53bb29fSJung-uk Kim 387*b53bb29fSJung-uk Kim static void 388*b53bb29fSJung-uk Kim yyerror(const char *s) 389*b53bb29fSJung-uk Kim { 390*b53bb29fSJung-uk Kim fprintf(stderr, "%s\n", s); 391*b53bb29fSJung-uk Kim } 392*b53bb29fSJung-uk Kim 393*b53bb29fSJung-uk Kim int 394*b53bb29fSJung-uk Kim yylex(void) 395*b53bb29fSJung-uk Kim { 396*b53bb29fSJung-uk Kim /* lexical analysis routine */ 397*b53bb29fSJung-uk Kim /* returns LETTER for a lower case letter, yylval = 0 through 25 */ 398*b53bb29fSJung-uk Kim /* return DIGIT for a digit, yylval = 0 through 9 */ 399*b53bb29fSJung-uk Kim /* all other characters are returned immediately */ 400*b53bb29fSJung-uk Kim 401*b53bb29fSJung-uk Kim int c; 402*b53bb29fSJung-uk Kim 403*b53bb29fSJung-uk Kim while( (c=getchar()) == ' ' ) { /* skip blanks */ } 404*b53bb29fSJung-uk Kim 405*b53bb29fSJung-uk Kim /* c is now nonblank */ 406*b53bb29fSJung-uk Kim 407*b53bb29fSJung-uk Kim if( islower( c )) { 408*b53bb29fSJung-uk Kim yylval = c - 'a'; 409*b53bb29fSJung-uk Kim return ( LETTER ); 410*b53bb29fSJung-uk Kim } 411*b53bb29fSJung-uk Kim if( isdigit( c )) { 412*b53bb29fSJung-uk Kim yylval = c - '0'; 413*b53bb29fSJung-uk Kim return ( DIGIT ); 414*b53bb29fSJung-uk Kim } 415*b53bb29fSJung-uk Kim return( c ); 416*b53bb29fSJung-uk Kim } 417*b53bb29fSJung-uk Kim #line 418 "stdin2.calc.c" 418*b53bb29fSJung-uk Kim 419*b53bb29fSJung-uk Kim /* For use in generated program */ 420*b53bb29fSJung-uk Kim #define yydepth (int)(yystack.s_mark - yystack.s_base) 421*b53bb29fSJung-uk Kim #if YYBTYACC 422*b53bb29fSJung-uk Kim #define yytrial (yyps->save) 423*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 424*b53bb29fSJung-uk Kim 425*b53bb29fSJung-uk Kim #if YYDEBUG 426*b53bb29fSJung-uk Kim #include <stdio.h> /* needed for printf */ 427*b53bb29fSJung-uk Kim #endif 428*b53bb29fSJung-uk Kim 429*b53bb29fSJung-uk Kim #include <stdlib.h> /* needed for malloc, etc */ 430*b53bb29fSJung-uk Kim #include <string.h> /* needed for memset */ 431*b53bb29fSJung-uk Kim 432*b53bb29fSJung-uk Kim /* allocate initial stack or double stack size, up to YYMAXDEPTH */ 433*b53bb29fSJung-uk Kim static int yygrowstack(YYSTACKDATA *data) 434*b53bb29fSJung-uk Kim { 435*b53bb29fSJung-uk Kim int i; 436*b53bb29fSJung-uk Kim unsigned newsize; 437*b53bb29fSJung-uk Kim YYINT *newss; 438*b53bb29fSJung-uk Kim YYSTYPE *newvs; 439*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 440*b53bb29fSJung-uk Kim YYLTYPE *newps; 441*b53bb29fSJung-uk Kim #endif 442*b53bb29fSJung-uk Kim 443*b53bb29fSJung-uk Kim if ((newsize = data->stacksize) == 0) 444*b53bb29fSJung-uk Kim newsize = YYINITSTACKSIZE; 445*b53bb29fSJung-uk Kim else if (newsize >= YYMAXDEPTH) 446*b53bb29fSJung-uk Kim return YYENOMEM; 447*b53bb29fSJung-uk Kim else if ((newsize *= 2) > YYMAXDEPTH) 448*b53bb29fSJung-uk Kim newsize = YYMAXDEPTH; 449*b53bb29fSJung-uk Kim 450*b53bb29fSJung-uk Kim i = (int) (data->s_mark - data->s_base); 451*b53bb29fSJung-uk Kim newss = (YYINT *)realloc(data->s_base, newsize * sizeof(*newss)); 452*b53bb29fSJung-uk Kim if (newss == 0) 453*b53bb29fSJung-uk Kim return YYENOMEM; 454*b53bb29fSJung-uk Kim 455*b53bb29fSJung-uk Kim data->s_base = newss; 456*b53bb29fSJung-uk Kim data->s_mark = newss + i; 457*b53bb29fSJung-uk Kim 458*b53bb29fSJung-uk Kim newvs = (YYSTYPE *)realloc(data->l_base, newsize * sizeof(*newvs)); 459*b53bb29fSJung-uk Kim if (newvs == 0) 460*b53bb29fSJung-uk Kim return YYENOMEM; 461*b53bb29fSJung-uk Kim 462*b53bb29fSJung-uk Kim data->l_base = newvs; 463*b53bb29fSJung-uk Kim data->l_mark = newvs + i; 464*b53bb29fSJung-uk Kim 465*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 466*b53bb29fSJung-uk Kim newps = (YYLTYPE *)realloc(data->p_base, newsize * sizeof(*newps)); 467*b53bb29fSJung-uk Kim if (newps == 0) 468*b53bb29fSJung-uk Kim return YYENOMEM; 469*b53bb29fSJung-uk Kim 470*b53bb29fSJung-uk Kim data->p_base = newps; 471*b53bb29fSJung-uk Kim data->p_mark = newps + i; 472*b53bb29fSJung-uk Kim #endif 473*b53bb29fSJung-uk Kim 474*b53bb29fSJung-uk Kim data->stacksize = newsize; 475*b53bb29fSJung-uk Kim data->s_last = data->s_base + newsize - 1; 476*b53bb29fSJung-uk Kim 477*b53bb29fSJung-uk Kim #if YYDEBUG 478*b53bb29fSJung-uk Kim if (yydebug) 479*b53bb29fSJung-uk Kim fprintf(stderr, "%sdebug: stack size increased to %d\n", YYPREFIX, newsize); 480*b53bb29fSJung-uk Kim #endif 481*b53bb29fSJung-uk Kim return 0; 482*b53bb29fSJung-uk Kim } 483*b53bb29fSJung-uk Kim 484*b53bb29fSJung-uk Kim #if YYPURE || defined(YY_NO_LEAKS) 485*b53bb29fSJung-uk Kim static void yyfreestack(YYSTACKDATA *data) 486*b53bb29fSJung-uk Kim { 487*b53bb29fSJung-uk Kim free(data->s_base); 488*b53bb29fSJung-uk Kim free(data->l_base); 489*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 490*b53bb29fSJung-uk Kim free(data->p_base); 491*b53bb29fSJung-uk Kim #endif 492*b53bb29fSJung-uk Kim memset(data, 0, sizeof(*data)); 493*b53bb29fSJung-uk Kim } 494*b53bb29fSJung-uk Kim #else 495*b53bb29fSJung-uk Kim #define yyfreestack(data) /* nothing */ 496*b53bb29fSJung-uk Kim #endif /* YYPURE || defined(YY_NO_LEAKS) */ 497*b53bb29fSJung-uk Kim #if YYBTYACC 498*b53bb29fSJung-uk Kim 499*b53bb29fSJung-uk Kim static YYParseState * 500*b53bb29fSJung-uk Kim yyNewState(unsigned size) 501*b53bb29fSJung-uk Kim { 502*b53bb29fSJung-uk Kim YYParseState *p = (YYParseState *) malloc(sizeof(YYParseState)); 503*b53bb29fSJung-uk Kim if (p == NULL) return NULL; 504*b53bb29fSJung-uk Kim 505*b53bb29fSJung-uk Kim p->yystack.stacksize = size; 506*b53bb29fSJung-uk Kim if (size == 0) 507*b53bb29fSJung-uk Kim { 508*b53bb29fSJung-uk Kim p->yystack.s_base = NULL; 509*b53bb29fSJung-uk Kim p->yystack.l_base = NULL; 510*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 511*b53bb29fSJung-uk Kim p->yystack.p_base = NULL; 512*b53bb29fSJung-uk Kim #endif 513*b53bb29fSJung-uk Kim return p; 514*b53bb29fSJung-uk Kim } 515*b53bb29fSJung-uk Kim p->yystack.s_base = (YYINT *) malloc(size * sizeof(YYINT)); 516*b53bb29fSJung-uk Kim if (p->yystack.s_base == NULL) return NULL; 517*b53bb29fSJung-uk Kim p->yystack.l_base = (YYSTYPE *) malloc(size * sizeof(YYSTYPE)); 518*b53bb29fSJung-uk Kim if (p->yystack.l_base == NULL) return NULL; 519*b53bb29fSJung-uk Kim memset(p->yystack.l_base, 0, size * sizeof(YYSTYPE)); 520*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 521*b53bb29fSJung-uk Kim p->yystack.p_base = (YYLTYPE *) malloc(size * sizeof(YYLTYPE)); 522*b53bb29fSJung-uk Kim if (p->yystack.p_base == NULL) return NULL; 523*b53bb29fSJung-uk Kim memset(p->yystack.p_base, 0, size * sizeof(YYLTYPE)); 524*b53bb29fSJung-uk Kim #endif 525*b53bb29fSJung-uk Kim 526*b53bb29fSJung-uk Kim return p; 527*b53bb29fSJung-uk Kim } 528*b53bb29fSJung-uk Kim 529*b53bb29fSJung-uk Kim static void 530*b53bb29fSJung-uk Kim yyFreeState(YYParseState *p) 531*b53bb29fSJung-uk Kim { 532*b53bb29fSJung-uk Kim yyfreestack(&p->yystack); 533*b53bb29fSJung-uk Kim free(p); 534*b53bb29fSJung-uk Kim } 535*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 536*b53bb29fSJung-uk Kim 537*b53bb29fSJung-uk Kim #define YYABORT goto yyabort 538*b53bb29fSJung-uk Kim #define YYREJECT goto yyabort 539*b53bb29fSJung-uk Kim #define YYACCEPT goto yyaccept 540*b53bb29fSJung-uk Kim #define YYERROR goto yyerrlab 541*b53bb29fSJung-uk Kim #if YYBTYACC 542*b53bb29fSJung-uk Kim #define YYVALID do { if (yyps->save) goto yyvalid; } while(0) 543*b53bb29fSJung-uk Kim #define YYVALID_NESTED do { if (yyps->save && \ 544*b53bb29fSJung-uk Kim yyps->save->save == 0) goto yyvalid; } while(0) 545*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 546*b53bb29fSJung-uk Kim 547*b53bb29fSJung-uk Kim int 548*b53bb29fSJung-uk Kim YYPARSE_DECL() 549*b53bb29fSJung-uk Kim { 550*b53bb29fSJung-uk Kim int yym, yyn, yystate, yyresult; 551*b53bb29fSJung-uk Kim #if YYBTYACC 552*b53bb29fSJung-uk Kim int yynewerrflag; 553*b53bb29fSJung-uk Kim YYParseState *yyerrctx = NULL; 554*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 555*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 556*b53bb29fSJung-uk Kim YYLTYPE yyerror_loc_range[3]; /* position of error start/end (0 unused) */ 557*b53bb29fSJung-uk Kim #endif 558*b53bb29fSJung-uk Kim #if YYDEBUG 559*b53bb29fSJung-uk Kim const char *yys; 560*b53bb29fSJung-uk Kim 561*b53bb29fSJung-uk Kim if ((yys = getenv("YYDEBUG")) != 0) 562*b53bb29fSJung-uk Kim { 563*b53bb29fSJung-uk Kim yyn = *yys; 564*b53bb29fSJung-uk Kim if (yyn >= '0' && yyn <= '9') 565*b53bb29fSJung-uk Kim yydebug = yyn - '0'; 566*b53bb29fSJung-uk Kim } 567*b53bb29fSJung-uk Kim if (yydebug) 568*b53bb29fSJung-uk Kim fprintf(stderr, "%sdebug[<# of symbols on state stack>]\n", YYPREFIX); 569*b53bb29fSJung-uk Kim #endif 570*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 571*b53bb29fSJung-uk Kim memset(yyerror_loc_range, 0, sizeof(yyerror_loc_range)); 572*b53bb29fSJung-uk Kim #endif 573*b53bb29fSJung-uk Kim 574*b53bb29fSJung-uk Kim #if YYBTYACC 575*b53bb29fSJung-uk Kim yyps = yyNewState(0); if (yyps == 0) goto yyenomem; 576*b53bb29fSJung-uk Kim yyps->save = 0; 577*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 578*b53bb29fSJung-uk Kim yym = 0; 579*b53bb29fSJung-uk Kim yyn = 0; 580*b53bb29fSJung-uk Kim yynerrs = 0; 581*b53bb29fSJung-uk Kim yyerrflag = 0; 582*b53bb29fSJung-uk Kim yychar = YYEMPTY; 583*b53bb29fSJung-uk Kim yystate = 0; 584*b53bb29fSJung-uk Kim 585*b53bb29fSJung-uk Kim #if YYPURE 586*b53bb29fSJung-uk Kim memset(&yystack, 0, sizeof(yystack)); 587*b53bb29fSJung-uk Kim #endif 588*b53bb29fSJung-uk Kim 589*b53bb29fSJung-uk Kim if (yystack.s_base == NULL && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 590*b53bb29fSJung-uk Kim yystack.s_mark = yystack.s_base; 591*b53bb29fSJung-uk Kim yystack.l_mark = yystack.l_base; 592*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 593*b53bb29fSJung-uk Kim yystack.p_mark = yystack.p_base; 594*b53bb29fSJung-uk Kim #endif 595*b53bb29fSJung-uk Kim yystate = 0; 596*b53bb29fSJung-uk Kim *yystack.s_mark = 0; 597*b53bb29fSJung-uk Kim 598*b53bb29fSJung-uk Kim yyloop: 599*b53bb29fSJung-uk Kim if ((yyn = yydefred[yystate]) != 0) goto yyreduce; 600*b53bb29fSJung-uk Kim if (yychar < 0) 601*b53bb29fSJung-uk Kim { 602*b53bb29fSJung-uk Kim #if YYBTYACC 603*b53bb29fSJung-uk Kim do { 604*b53bb29fSJung-uk Kim if (yylvp < yylve) 605*b53bb29fSJung-uk Kim { 606*b53bb29fSJung-uk Kim /* we're currently re-reading tokens */ 607*b53bb29fSJung-uk Kim yylval = *yylvp++; 608*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 609*b53bb29fSJung-uk Kim yylloc = *yylpp++; 610*b53bb29fSJung-uk Kim #endif 611*b53bb29fSJung-uk Kim yychar = *yylexp++; 612*b53bb29fSJung-uk Kim break; 613*b53bb29fSJung-uk Kim } 614*b53bb29fSJung-uk Kim if (yyps->save) 615*b53bb29fSJung-uk Kim { 616*b53bb29fSJung-uk Kim /* in trial mode; save scanner results for future parse attempts */ 617*b53bb29fSJung-uk Kim if (yylvp == yylvlim) 618*b53bb29fSJung-uk Kim { /* Enlarge lexical value queue */ 619*b53bb29fSJung-uk Kim size_t p = (size_t) (yylvp - yylvals); 620*b53bb29fSJung-uk Kim size_t s = (size_t) (yylvlim - yylvals); 621*b53bb29fSJung-uk Kim 622*b53bb29fSJung-uk Kim s += YYLVQUEUEGROWTH; 623*b53bb29fSJung-uk Kim if ((yylexemes = (YYINT *)realloc(yylexemes, s * sizeof(YYINT))) == NULL) goto yyenomem; 624*b53bb29fSJung-uk Kim if ((yylvals = (YYSTYPE *)realloc(yylvals, s * sizeof(YYSTYPE))) == NULL) goto yyenomem; 625*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 626*b53bb29fSJung-uk Kim if ((yylpsns = (YYLTYPE *)realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL) goto yyenomem; 627*b53bb29fSJung-uk Kim #endif 628*b53bb29fSJung-uk Kim yylvp = yylve = yylvals + p; 629*b53bb29fSJung-uk Kim yylvlim = yylvals + s; 630*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 631*b53bb29fSJung-uk Kim yylpp = yylpe = yylpsns + p; 632*b53bb29fSJung-uk Kim yylplim = yylpsns + s; 633*b53bb29fSJung-uk Kim #endif 634*b53bb29fSJung-uk Kim yylexp = yylexemes + p; 635*b53bb29fSJung-uk Kim } 636*b53bb29fSJung-uk Kim *yylexp = (YYINT) YYLEX; 637*b53bb29fSJung-uk Kim *yylvp++ = yylval; 638*b53bb29fSJung-uk Kim yylve++; 639*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 640*b53bb29fSJung-uk Kim *yylpp++ = yylloc; 641*b53bb29fSJung-uk Kim yylpe++; 642*b53bb29fSJung-uk Kim #endif 643*b53bb29fSJung-uk Kim yychar = *yylexp++; 644*b53bb29fSJung-uk Kim break; 645*b53bb29fSJung-uk Kim } 646*b53bb29fSJung-uk Kim /* normal operation, no conflict encountered */ 647*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 648*b53bb29fSJung-uk Kim yychar = YYLEX; 649*b53bb29fSJung-uk Kim #if YYBTYACC 650*b53bb29fSJung-uk Kim } while (0); 651*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 652*b53bb29fSJung-uk Kim if (yychar < 0) yychar = YYEOF; 653*b53bb29fSJung-uk Kim #if YYDEBUG 654*b53bb29fSJung-uk Kim if (yydebug) 655*b53bb29fSJung-uk Kim { 656*b53bb29fSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 657*b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)", 658*b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, yystate, yychar, yys); 659*b53bb29fSJung-uk Kim #ifdef YYSTYPE_TOSTRING 660*b53bb29fSJung-uk Kim #if YYBTYACC 661*b53bb29fSJung-uk Kim if (!yytrial) 662*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 663*b53bb29fSJung-uk Kim fprintf(stderr, " <%s>", YYSTYPE_TOSTRING(yychar, yylval)); 664*b53bb29fSJung-uk Kim #endif 665*b53bb29fSJung-uk Kim fputc('\n', stderr); 666*b53bb29fSJung-uk Kim } 667*b53bb29fSJung-uk Kim #endif 668*b53bb29fSJung-uk Kim } 669*b53bb29fSJung-uk Kim #if YYBTYACC 670*b53bb29fSJung-uk Kim 671*b53bb29fSJung-uk Kim /* Do we have a conflict? */ 672*b53bb29fSJung-uk Kim if (((yyn = yycindex[yystate]) != 0) && (yyn += yychar) >= 0 && 673*b53bb29fSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 674*b53bb29fSJung-uk Kim { 675*b53bb29fSJung-uk Kim YYINT ctry; 676*b53bb29fSJung-uk Kim 677*b53bb29fSJung-uk Kim if (yypath) 678*b53bb29fSJung-uk Kim { 679*b53bb29fSJung-uk Kim YYParseState *save; 680*b53bb29fSJung-uk Kim #if YYDEBUG 681*b53bb29fSJung-uk Kim if (yydebug) 682*b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: CONFLICT in state %d: following successful trial parse\n", 683*b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, yystate); 684*b53bb29fSJung-uk Kim #endif 685*b53bb29fSJung-uk Kim /* Switch to the next conflict context */ 686*b53bb29fSJung-uk Kim save = yypath; 687*b53bb29fSJung-uk Kim yypath = save->save; 688*b53bb29fSJung-uk Kim save->save = NULL; 689*b53bb29fSJung-uk Kim ctry = save->ctry; 690*b53bb29fSJung-uk Kim if (save->state != yystate) YYABORT; 691*b53bb29fSJung-uk Kim yyFreeState(save); 692*b53bb29fSJung-uk Kim 693*b53bb29fSJung-uk Kim } 694*b53bb29fSJung-uk Kim else 695*b53bb29fSJung-uk Kim { 696*b53bb29fSJung-uk Kim 697*b53bb29fSJung-uk Kim /* Unresolved conflict - start/continue trial parse */ 698*b53bb29fSJung-uk Kim YYParseState *save; 699*b53bb29fSJung-uk Kim #if YYDEBUG 700*b53bb29fSJung-uk Kim if (yydebug) 701*b53bb29fSJung-uk Kim { 702*b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: CONFLICT in state %d. ", YYDEBUGSTR, yydepth, yystate); 703*b53bb29fSJung-uk Kim if (yyps->save) 704*b53bb29fSJung-uk Kim fputs("ALREADY in conflict, continuing trial parse.\n", stderr); 705*b53bb29fSJung-uk Kim else 706*b53bb29fSJung-uk Kim fputs("Starting trial parse.\n", stderr); 707*b53bb29fSJung-uk Kim } 708*b53bb29fSJung-uk Kim #endif 709*b53bb29fSJung-uk Kim save = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1)); 710*b53bb29fSJung-uk Kim if (save == NULL) goto yyenomem; 711*b53bb29fSJung-uk Kim save->save = yyps->save; 712*b53bb29fSJung-uk Kim save->state = yystate; 713*b53bb29fSJung-uk Kim save->errflag = yyerrflag; 714*b53bb29fSJung-uk Kim save->yystack.s_mark = save->yystack.s_base + (yystack.s_mark - yystack.s_base); 715*b53bb29fSJung-uk Kim memcpy (save->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 716*b53bb29fSJung-uk Kim save->yystack.l_mark = save->yystack.l_base + (yystack.l_mark - yystack.l_base); 717*b53bb29fSJung-uk Kim memcpy (save->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 718*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 719*b53bb29fSJung-uk Kim save->yystack.p_mark = save->yystack.p_base + (yystack.p_mark - yystack.p_base); 720*b53bb29fSJung-uk Kim memcpy (save->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 721*b53bb29fSJung-uk Kim #endif 722*b53bb29fSJung-uk Kim ctry = yytable[yyn]; 723*b53bb29fSJung-uk Kim if (yyctable[ctry] == -1) 724*b53bb29fSJung-uk Kim { 725*b53bb29fSJung-uk Kim #if YYDEBUG 726*b53bb29fSJung-uk Kim if (yydebug && yychar >= YYEOF) 727*b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: backtracking 1 token\n", YYDEBUGSTR, yydepth); 728*b53bb29fSJung-uk Kim #endif 729*b53bb29fSJung-uk Kim ctry++; 730*b53bb29fSJung-uk Kim } 731*b53bb29fSJung-uk Kim save->ctry = ctry; 732*b53bb29fSJung-uk Kim if (yyps->save == NULL) 733*b53bb29fSJung-uk Kim { 734*b53bb29fSJung-uk Kim /* If this is a first conflict in the stack, start saving lexemes */ 735*b53bb29fSJung-uk Kim if (!yylexemes) 736*b53bb29fSJung-uk Kim { 737*b53bb29fSJung-uk Kim yylexemes = (YYINT *) malloc((YYLVQUEUEGROWTH) * sizeof(YYINT)); 738*b53bb29fSJung-uk Kim if (yylexemes == NULL) goto yyenomem; 739*b53bb29fSJung-uk Kim yylvals = (YYSTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYSTYPE)); 740*b53bb29fSJung-uk Kim if (yylvals == NULL) goto yyenomem; 741*b53bb29fSJung-uk Kim yylvlim = yylvals + YYLVQUEUEGROWTH; 742*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 743*b53bb29fSJung-uk Kim yylpsns = (YYLTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYLTYPE)); 744*b53bb29fSJung-uk Kim if (yylpsns == NULL) goto yyenomem; 745*b53bb29fSJung-uk Kim yylplim = yylpsns + YYLVQUEUEGROWTH; 746*b53bb29fSJung-uk Kim #endif 747*b53bb29fSJung-uk Kim } 748*b53bb29fSJung-uk Kim if (yylvp == yylve) 749*b53bb29fSJung-uk Kim { 750*b53bb29fSJung-uk Kim yylvp = yylve = yylvals; 751*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 752*b53bb29fSJung-uk Kim yylpp = yylpe = yylpsns; 753*b53bb29fSJung-uk Kim #endif 754*b53bb29fSJung-uk Kim yylexp = yylexemes; 755*b53bb29fSJung-uk Kim if (yychar >= YYEOF) 756*b53bb29fSJung-uk Kim { 757*b53bb29fSJung-uk Kim *yylve++ = yylval; 758*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 759*b53bb29fSJung-uk Kim *yylpe++ = yylloc; 760*b53bb29fSJung-uk Kim #endif 761*b53bb29fSJung-uk Kim *yylexp = (YYINT) yychar; 762*b53bb29fSJung-uk Kim yychar = YYEMPTY; 763*b53bb29fSJung-uk Kim } 764*b53bb29fSJung-uk Kim } 765*b53bb29fSJung-uk Kim } 766*b53bb29fSJung-uk Kim if (yychar >= YYEOF) 767*b53bb29fSJung-uk Kim { 768*b53bb29fSJung-uk Kim yylvp--; 769*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 770*b53bb29fSJung-uk Kim yylpp--; 771*b53bb29fSJung-uk Kim #endif 772*b53bb29fSJung-uk Kim yylexp--; 773*b53bb29fSJung-uk Kim yychar = YYEMPTY; 774*b53bb29fSJung-uk Kim } 775*b53bb29fSJung-uk Kim save->lexeme = (int) (yylvp - yylvals); 776*b53bb29fSJung-uk Kim yyps->save = save; 777*b53bb29fSJung-uk Kim } 778*b53bb29fSJung-uk Kim if (yytable[yyn] == ctry) 779*b53bb29fSJung-uk Kim { 780*b53bb29fSJung-uk Kim #if YYDEBUG 781*b53bb29fSJung-uk Kim if (yydebug) 782*b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n", 783*b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, yystate, yyctable[ctry]); 784*b53bb29fSJung-uk Kim #endif 785*b53bb29fSJung-uk Kim if (yychar < 0) 786*b53bb29fSJung-uk Kim { 787*b53bb29fSJung-uk Kim yylvp++; 788*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 789*b53bb29fSJung-uk Kim yylpp++; 790*b53bb29fSJung-uk Kim #endif 791*b53bb29fSJung-uk Kim yylexp++; 792*b53bb29fSJung-uk Kim } 793*b53bb29fSJung-uk Kim if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) 794*b53bb29fSJung-uk Kim goto yyoverflow; 795*b53bb29fSJung-uk Kim yystate = yyctable[ctry]; 796*b53bb29fSJung-uk Kim *++yystack.s_mark = (YYINT) yystate; 797*b53bb29fSJung-uk Kim *++yystack.l_mark = yylval; 798*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 799*b53bb29fSJung-uk Kim *++yystack.p_mark = yylloc; 800*b53bb29fSJung-uk Kim #endif 801*b53bb29fSJung-uk Kim yychar = YYEMPTY; 802*b53bb29fSJung-uk Kim if (yyerrflag > 0) --yyerrflag; 803*b53bb29fSJung-uk Kim goto yyloop; 804*b53bb29fSJung-uk Kim } 805*b53bb29fSJung-uk Kim else 806*b53bb29fSJung-uk Kim { 807*b53bb29fSJung-uk Kim yyn = yyctable[ctry]; 808*b53bb29fSJung-uk Kim goto yyreduce; 809*b53bb29fSJung-uk Kim } 810*b53bb29fSJung-uk Kim } /* End of code dealing with conflicts */ 811*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 812*b53bb29fSJung-uk Kim if (((yyn = yysindex[yystate]) != 0) && (yyn += yychar) >= 0 && 813*b53bb29fSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 814*b53bb29fSJung-uk Kim { 815*b53bb29fSJung-uk Kim #if YYDEBUG 816*b53bb29fSJung-uk Kim if (yydebug) 817*b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n", 818*b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, yystate, yytable[yyn]); 819*b53bb29fSJung-uk Kim #endif 820*b53bb29fSJung-uk Kim if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 821*b53bb29fSJung-uk Kim yystate = yytable[yyn]; 822*b53bb29fSJung-uk Kim *++yystack.s_mark = yytable[yyn]; 823*b53bb29fSJung-uk Kim *++yystack.l_mark = yylval; 824*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 825*b53bb29fSJung-uk Kim *++yystack.p_mark = yylloc; 826*b53bb29fSJung-uk Kim #endif 827*b53bb29fSJung-uk Kim yychar = YYEMPTY; 828*b53bb29fSJung-uk Kim if (yyerrflag > 0) --yyerrflag; 829*b53bb29fSJung-uk Kim goto yyloop; 830*b53bb29fSJung-uk Kim } 831*b53bb29fSJung-uk Kim if (((yyn = yyrindex[yystate]) != 0) && (yyn += yychar) >= 0 && 832*b53bb29fSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 833*b53bb29fSJung-uk Kim { 834*b53bb29fSJung-uk Kim yyn = yytable[yyn]; 835*b53bb29fSJung-uk Kim goto yyreduce; 836*b53bb29fSJung-uk Kim } 837*b53bb29fSJung-uk Kim if (yyerrflag != 0) goto yyinrecovery; 838*b53bb29fSJung-uk Kim #if YYBTYACC 839*b53bb29fSJung-uk Kim 840*b53bb29fSJung-uk Kim yynewerrflag = 1; 841*b53bb29fSJung-uk Kim goto yyerrhandler; 842*b53bb29fSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */ 843*b53bb29fSJung-uk Kim 844*b53bb29fSJung-uk Kim yyerrlab: 845*b53bb29fSJung-uk Kim /* explicit YYERROR from an action -- pop the rhs of the rule reduced 846*b53bb29fSJung-uk Kim * before looking for error recovery */ 847*b53bb29fSJung-uk Kim yystack.s_mark -= yym; 848*b53bb29fSJung-uk Kim yystate = *yystack.s_mark; 849*b53bb29fSJung-uk Kim yystack.l_mark -= yym; 850*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 851*b53bb29fSJung-uk Kim yystack.p_mark -= yym; 852*b53bb29fSJung-uk Kim #endif 853*b53bb29fSJung-uk Kim 854*b53bb29fSJung-uk Kim yynewerrflag = 0; 855*b53bb29fSJung-uk Kim yyerrhandler: 856*b53bb29fSJung-uk Kim while (yyps->save) 857*b53bb29fSJung-uk Kim { 858*b53bb29fSJung-uk Kim int ctry; 859*b53bb29fSJung-uk Kim YYParseState *save = yyps->save; 860*b53bb29fSJung-uk Kim #if YYDEBUG 861*b53bb29fSJung-uk Kim if (yydebug) 862*b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: ERROR in state %d, CONFLICT BACKTRACKING to state %d, %d tokens\n", 863*b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, yystate, yyps->save->state, 864*b53bb29fSJung-uk Kim (int)(yylvp - yylvals - yyps->save->lexeme)); 865*b53bb29fSJung-uk Kim #endif 866*b53bb29fSJung-uk Kim /* Memorize most forward-looking error state in case it's really an error. */ 867*b53bb29fSJung-uk Kim if (yyerrctx == NULL || yyerrctx->lexeme < yylvp - yylvals) 868*b53bb29fSJung-uk Kim { 869*b53bb29fSJung-uk Kim /* Free old saved error context state */ 870*b53bb29fSJung-uk Kim if (yyerrctx) yyFreeState(yyerrctx); 871*b53bb29fSJung-uk Kim /* Create and fill out new saved error context state */ 872*b53bb29fSJung-uk Kim yyerrctx = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1)); 873*b53bb29fSJung-uk Kim if (yyerrctx == NULL) goto yyenomem; 874*b53bb29fSJung-uk Kim yyerrctx->save = yyps->save; 875*b53bb29fSJung-uk Kim yyerrctx->state = yystate; 876*b53bb29fSJung-uk Kim yyerrctx->errflag = yyerrflag; 877*b53bb29fSJung-uk Kim yyerrctx->yystack.s_mark = yyerrctx->yystack.s_base + (yystack.s_mark - yystack.s_base); 878*b53bb29fSJung-uk Kim memcpy (yyerrctx->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 879*b53bb29fSJung-uk Kim yyerrctx->yystack.l_mark = yyerrctx->yystack.l_base + (yystack.l_mark - yystack.l_base); 880*b53bb29fSJung-uk Kim memcpy (yyerrctx->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 881*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 882*b53bb29fSJung-uk Kim yyerrctx->yystack.p_mark = yyerrctx->yystack.p_base + (yystack.p_mark - yystack.p_base); 883*b53bb29fSJung-uk Kim memcpy (yyerrctx->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 884*b53bb29fSJung-uk Kim #endif 885*b53bb29fSJung-uk Kim yyerrctx->lexeme = (int) (yylvp - yylvals); 886*b53bb29fSJung-uk Kim } 887*b53bb29fSJung-uk Kim yylvp = yylvals + save->lexeme; 888*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 889*b53bb29fSJung-uk Kim yylpp = yylpsns + save->lexeme; 890*b53bb29fSJung-uk Kim #endif 891*b53bb29fSJung-uk Kim yylexp = yylexemes + save->lexeme; 892*b53bb29fSJung-uk Kim yychar = YYEMPTY; 893*b53bb29fSJung-uk Kim yystack.s_mark = yystack.s_base + (save->yystack.s_mark - save->yystack.s_base); 894*b53bb29fSJung-uk Kim memcpy (yystack.s_base, save->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 895*b53bb29fSJung-uk Kim yystack.l_mark = yystack.l_base + (save->yystack.l_mark - save->yystack.l_base); 896*b53bb29fSJung-uk Kim memcpy (yystack.l_base, save->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 897*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 898*b53bb29fSJung-uk Kim yystack.p_mark = yystack.p_base + (save->yystack.p_mark - save->yystack.p_base); 899*b53bb29fSJung-uk Kim memcpy (yystack.p_base, save->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 900*b53bb29fSJung-uk Kim #endif 901*b53bb29fSJung-uk Kim ctry = ++save->ctry; 902*b53bb29fSJung-uk Kim yystate = save->state; 903*b53bb29fSJung-uk Kim /* We tried shift, try reduce now */ 904*b53bb29fSJung-uk Kim if ((yyn = yyctable[ctry]) >= 0) goto yyreduce; 905*b53bb29fSJung-uk Kim yyps->save = save->save; 906*b53bb29fSJung-uk Kim save->save = NULL; 907*b53bb29fSJung-uk Kim yyFreeState(save); 908*b53bb29fSJung-uk Kim 909*b53bb29fSJung-uk Kim /* Nothing left on the stack -- error */ 910*b53bb29fSJung-uk Kim if (!yyps->save) 911*b53bb29fSJung-uk Kim { 912*b53bb29fSJung-uk Kim #if YYDEBUG 913*b53bb29fSJung-uk Kim if (yydebug) 914*b53bb29fSJung-uk Kim fprintf(stderr, "%sdebug[%d,trial]: trial parse FAILED, entering ERROR mode\n", 915*b53bb29fSJung-uk Kim YYPREFIX, yydepth); 916*b53bb29fSJung-uk Kim #endif 917*b53bb29fSJung-uk Kim /* Restore state as it was in the most forward-advanced error */ 918*b53bb29fSJung-uk Kim yylvp = yylvals + yyerrctx->lexeme; 919*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 920*b53bb29fSJung-uk Kim yylpp = yylpsns + yyerrctx->lexeme; 921*b53bb29fSJung-uk Kim #endif 922*b53bb29fSJung-uk Kim yylexp = yylexemes + yyerrctx->lexeme; 923*b53bb29fSJung-uk Kim yychar = yylexp[-1]; 924*b53bb29fSJung-uk Kim yylval = yylvp[-1]; 925*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 926*b53bb29fSJung-uk Kim yylloc = yylpp[-1]; 927*b53bb29fSJung-uk Kim #endif 928*b53bb29fSJung-uk Kim yystack.s_mark = yystack.s_base + (yyerrctx->yystack.s_mark - yyerrctx->yystack.s_base); 929*b53bb29fSJung-uk Kim memcpy (yystack.s_base, yyerrctx->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 930*b53bb29fSJung-uk Kim yystack.l_mark = yystack.l_base + (yyerrctx->yystack.l_mark - yyerrctx->yystack.l_base); 931*b53bb29fSJung-uk Kim memcpy (yystack.l_base, yyerrctx->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 932*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 933*b53bb29fSJung-uk Kim yystack.p_mark = yystack.p_base + (yyerrctx->yystack.p_mark - yyerrctx->yystack.p_base); 934*b53bb29fSJung-uk Kim memcpy (yystack.p_base, yyerrctx->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 935*b53bb29fSJung-uk Kim #endif 936*b53bb29fSJung-uk Kim yystate = yyerrctx->state; 937*b53bb29fSJung-uk Kim yyFreeState(yyerrctx); 938*b53bb29fSJung-uk Kim yyerrctx = NULL; 939*b53bb29fSJung-uk Kim } 940*b53bb29fSJung-uk Kim yynewerrflag = 1; 941*b53bb29fSJung-uk Kim } 942*b53bb29fSJung-uk Kim if (yynewerrflag == 0) goto yyinrecovery; 943*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 944*b53bb29fSJung-uk Kim 945*b53bb29fSJung-uk Kim YYERROR_CALL("syntax error"); 946*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 947*b53bb29fSJung-uk Kim yyerror_loc_range[1] = yylloc; /* lookahead position is error start position */ 948*b53bb29fSJung-uk Kim #endif 949*b53bb29fSJung-uk Kim 950*b53bb29fSJung-uk Kim #if !YYBTYACC 951*b53bb29fSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */ 952*b53bb29fSJung-uk Kim yyerrlab: 953*b53bb29fSJung-uk Kim #endif 954*b53bb29fSJung-uk Kim ++yynerrs; 955*b53bb29fSJung-uk Kim 956*b53bb29fSJung-uk Kim yyinrecovery: 957*b53bb29fSJung-uk Kim if (yyerrflag < 3) 958*b53bb29fSJung-uk Kim { 959*b53bb29fSJung-uk Kim yyerrflag = 3; 960*b53bb29fSJung-uk Kim for (;;) 961*b53bb29fSJung-uk Kim { 962*b53bb29fSJung-uk Kim if (((yyn = yysindex[*yystack.s_mark]) != 0) && (yyn += YYERRCODE) >= 0 && 963*b53bb29fSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) YYERRCODE) 964*b53bb29fSJung-uk Kim { 965*b53bb29fSJung-uk Kim #if YYDEBUG 966*b53bb29fSJung-uk Kim if (yydebug) 967*b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, error recovery shifting to state %d\n", 968*b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, *yystack.s_mark, yytable[yyn]); 969*b53bb29fSJung-uk Kim #endif 970*b53bb29fSJung-uk Kim if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 971*b53bb29fSJung-uk Kim yystate = yytable[yyn]; 972*b53bb29fSJung-uk Kim *++yystack.s_mark = yytable[yyn]; 973*b53bb29fSJung-uk Kim *++yystack.l_mark = yylval; 974*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 975*b53bb29fSJung-uk Kim /* lookahead position is error end position */ 976*b53bb29fSJung-uk Kim yyerror_loc_range[2] = yylloc; 977*b53bb29fSJung-uk Kim YYLLOC_DEFAULT(yyloc, yyerror_loc_range, 2); /* position of error span */ 978*b53bb29fSJung-uk Kim *++yystack.p_mark = yyloc; 979*b53bb29fSJung-uk Kim #endif 980*b53bb29fSJung-uk Kim goto yyloop; 981*b53bb29fSJung-uk Kim } 982*b53bb29fSJung-uk Kim else 983*b53bb29fSJung-uk Kim { 984*b53bb29fSJung-uk Kim #if YYDEBUG 985*b53bb29fSJung-uk Kim if (yydebug) 986*b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: error recovery discarding state %d\n", 987*b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, *yystack.s_mark); 988*b53bb29fSJung-uk Kim #endif 989*b53bb29fSJung-uk Kim if (yystack.s_mark <= yystack.s_base) goto yyabort; 990*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 991*b53bb29fSJung-uk Kim /* the current TOS position is the error start position */ 992*b53bb29fSJung-uk Kim yyerror_loc_range[1] = *yystack.p_mark; 993*b53bb29fSJung-uk Kim #endif 994*b53bb29fSJung-uk Kim #if defined(YYDESTRUCT_CALL) 995*b53bb29fSJung-uk Kim #if YYBTYACC 996*b53bb29fSJung-uk Kim if (!yytrial) 997*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 998*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 999*b53bb29fSJung-uk Kim YYDESTRUCT_CALL("error: discarding state", 1000*b53bb29fSJung-uk Kim yystos[*yystack.s_mark], yystack.l_mark, yystack.p_mark); 1001*b53bb29fSJung-uk Kim #else 1002*b53bb29fSJung-uk Kim YYDESTRUCT_CALL("error: discarding state", 1003*b53bb29fSJung-uk Kim yystos[*yystack.s_mark], yystack.l_mark); 1004*b53bb29fSJung-uk Kim #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 1005*b53bb29fSJung-uk Kim #endif /* defined(YYDESTRUCT_CALL) */ 1006*b53bb29fSJung-uk Kim --yystack.s_mark; 1007*b53bb29fSJung-uk Kim --yystack.l_mark; 1008*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1009*b53bb29fSJung-uk Kim --yystack.p_mark; 1010*b53bb29fSJung-uk Kim #endif 1011*b53bb29fSJung-uk Kim } 1012*b53bb29fSJung-uk Kim } 1013*b53bb29fSJung-uk Kim } 1014*b53bb29fSJung-uk Kim else 1015*b53bb29fSJung-uk Kim { 1016*b53bb29fSJung-uk Kim if (yychar == YYEOF) goto yyabort; 1017*b53bb29fSJung-uk Kim #if YYDEBUG 1018*b53bb29fSJung-uk Kim if (yydebug) 1019*b53bb29fSJung-uk Kim { 1020*b53bb29fSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 1021*b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, error recovery discarding token %d (%s)\n", 1022*b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, yystate, yychar, yys); 1023*b53bb29fSJung-uk Kim } 1024*b53bb29fSJung-uk Kim #endif 1025*b53bb29fSJung-uk Kim #if defined(YYDESTRUCT_CALL) 1026*b53bb29fSJung-uk Kim #if YYBTYACC 1027*b53bb29fSJung-uk Kim if (!yytrial) 1028*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 1029*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1030*b53bb29fSJung-uk Kim YYDESTRUCT_CALL("error: discarding token", yychar, &yylval, &yylloc); 1031*b53bb29fSJung-uk Kim #else 1032*b53bb29fSJung-uk Kim YYDESTRUCT_CALL("error: discarding token", yychar, &yylval); 1033*b53bb29fSJung-uk Kim #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 1034*b53bb29fSJung-uk Kim #endif /* defined(YYDESTRUCT_CALL) */ 1035*b53bb29fSJung-uk Kim yychar = YYEMPTY; 1036*b53bb29fSJung-uk Kim goto yyloop; 1037*b53bb29fSJung-uk Kim } 1038*b53bb29fSJung-uk Kim 1039*b53bb29fSJung-uk Kim yyreduce: 1040*b53bb29fSJung-uk Kim yym = yylen[yyn]; 1041*b53bb29fSJung-uk Kim #if YYDEBUG 1042*b53bb29fSJung-uk Kim if (yydebug) 1043*b53bb29fSJung-uk Kim { 1044*b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, reducing by rule %d (%s)", 1045*b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, yystate, yyn, yyrule[yyn]); 1046*b53bb29fSJung-uk Kim #ifdef YYSTYPE_TOSTRING 1047*b53bb29fSJung-uk Kim #if YYBTYACC 1048*b53bb29fSJung-uk Kim if (!yytrial) 1049*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 1050*b53bb29fSJung-uk Kim if (yym > 0) 1051*b53bb29fSJung-uk Kim { 1052*b53bb29fSJung-uk Kim int i; 1053*b53bb29fSJung-uk Kim fputc('<', stderr); 1054*b53bb29fSJung-uk Kim for (i = yym; i > 0; i--) 1055*b53bb29fSJung-uk Kim { 1056*b53bb29fSJung-uk Kim if (i != yym) fputs(", ", stderr); 1057*b53bb29fSJung-uk Kim fputs(YYSTYPE_TOSTRING(yystos[yystack.s_mark[1-i]], 1058*b53bb29fSJung-uk Kim yystack.l_mark[1-i]), stderr); 1059*b53bb29fSJung-uk Kim } 1060*b53bb29fSJung-uk Kim fputc('>', stderr); 1061*b53bb29fSJung-uk Kim } 1062*b53bb29fSJung-uk Kim #endif 1063*b53bb29fSJung-uk Kim fputc('\n', stderr); 1064*b53bb29fSJung-uk Kim } 1065*b53bb29fSJung-uk Kim #endif 1066*b53bb29fSJung-uk Kim if (yym > 0) 1067*b53bb29fSJung-uk Kim yyval = yystack.l_mark[1-yym]; 1068*b53bb29fSJung-uk Kim else 1069*b53bb29fSJung-uk Kim memset(&yyval, 0, sizeof yyval); 1070*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1071*b53bb29fSJung-uk Kim 1072*b53bb29fSJung-uk Kim /* Perform position reduction */ 1073*b53bb29fSJung-uk Kim memset(&yyloc, 0, sizeof(yyloc)); 1074*b53bb29fSJung-uk Kim #if YYBTYACC 1075*b53bb29fSJung-uk Kim if (!yytrial) 1076*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 1077*b53bb29fSJung-uk Kim { 1078*b53bb29fSJung-uk Kim YYLLOC_DEFAULT(yyloc, &yystack.p_mark[-yym], yym); 1079*b53bb29fSJung-uk Kim /* just in case YYERROR is invoked within the action, save 1080*b53bb29fSJung-uk Kim the start of the rhs as the error start position */ 1081*b53bb29fSJung-uk Kim yyerror_loc_range[1] = yystack.p_mark[1-yym]; 1082*b53bb29fSJung-uk Kim } 1083*b53bb29fSJung-uk Kim #endif 1084*b53bb29fSJung-uk Kim 1085*b53bb29fSJung-uk Kim switch (yyn) 1086*b53bb29fSJung-uk Kim { 1087*b53bb29fSJung-uk Kim case 3: 1088*b53bb29fSJung-uk Kim #line 28 "calc.y" 1089*b53bb29fSJung-uk Kim { yyerrok ; } 1090*b53bb29fSJung-uk Kim break; 1091*b53bb29fSJung-uk Kim case 4: 1092*b53bb29fSJung-uk Kim #line 32 "calc.y" 1093*b53bb29fSJung-uk Kim { printf("%d\n",yystack.l_mark[0]);} 1094*b53bb29fSJung-uk Kim break; 1095*b53bb29fSJung-uk Kim case 5: 1096*b53bb29fSJung-uk Kim #line 34 "calc.y" 1097*b53bb29fSJung-uk Kim { regs[yystack.l_mark[-2]] = yystack.l_mark[0]; } 1098*b53bb29fSJung-uk Kim break; 1099*b53bb29fSJung-uk Kim case 6: 1100*b53bb29fSJung-uk Kim #line 38 "calc.y" 1101*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-1]; } 1102*b53bb29fSJung-uk Kim break; 1103*b53bb29fSJung-uk Kim case 7: 1104*b53bb29fSJung-uk Kim #line 40 "calc.y" 1105*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] + yystack.l_mark[0]; } 1106*b53bb29fSJung-uk Kim break; 1107*b53bb29fSJung-uk Kim case 8: 1108*b53bb29fSJung-uk Kim #line 42 "calc.y" 1109*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] - yystack.l_mark[0]; } 1110*b53bb29fSJung-uk Kim break; 1111*b53bb29fSJung-uk Kim case 9: 1112*b53bb29fSJung-uk Kim #line 44 "calc.y" 1113*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] * yystack.l_mark[0]; } 1114*b53bb29fSJung-uk Kim break; 1115*b53bb29fSJung-uk Kim case 10: 1116*b53bb29fSJung-uk Kim #line 46 "calc.y" 1117*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] / yystack.l_mark[0]; } 1118*b53bb29fSJung-uk Kim break; 1119*b53bb29fSJung-uk Kim case 11: 1120*b53bb29fSJung-uk Kim #line 48 "calc.y" 1121*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] % yystack.l_mark[0]; } 1122*b53bb29fSJung-uk Kim break; 1123*b53bb29fSJung-uk Kim case 12: 1124*b53bb29fSJung-uk Kim #line 50 "calc.y" 1125*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] & yystack.l_mark[0]; } 1126*b53bb29fSJung-uk Kim break; 1127*b53bb29fSJung-uk Kim case 13: 1128*b53bb29fSJung-uk Kim #line 52 "calc.y" 1129*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] | yystack.l_mark[0]; } 1130*b53bb29fSJung-uk Kim break; 1131*b53bb29fSJung-uk Kim case 14: 1132*b53bb29fSJung-uk Kim #line 54 "calc.y" 1133*b53bb29fSJung-uk Kim { yyval = - yystack.l_mark[0]; } 1134*b53bb29fSJung-uk Kim break; 1135*b53bb29fSJung-uk Kim case 15: 1136*b53bb29fSJung-uk Kim #line 56 "calc.y" 1137*b53bb29fSJung-uk Kim { yyval = regs[yystack.l_mark[0]]; } 1138*b53bb29fSJung-uk Kim break; 1139*b53bb29fSJung-uk Kim case 17: 1140*b53bb29fSJung-uk Kim #line 61 "calc.y" 1141*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[0]; base = (yystack.l_mark[0]==0) ? 8 : 10; } 1142*b53bb29fSJung-uk Kim break; 1143*b53bb29fSJung-uk Kim case 18: 1144*b53bb29fSJung-uk Kim #line 63 "calc.y" 1145*b53bb29fSJung-uk Kim { yyval = base * yystack.l_mark[-1] + yystack.l_mark[0]; } 1146*b53bb29fSJung-uk Kim break; 1147*b53bb29fSJung-uk Kim #line 1148 "stdin2.calc.c" 1148*b53bb29fSJung-uk Kim default: 1149*b53bb29fSJung-uk Kim break; 1150*b53bb29fSJung-uk Kim } 1151*b53bb29fSJung-uk Kim yystack.s_mark -= yym; 1152*b53bb29fSJung-uk Kim yystate = *yystack.s_mark; 1153*b53bb29fSJung-uk Kim yystack.l_mark -= yym; 1154*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1155*b53bb29fSJung-uk Kim yystack.p_mark -= yym; 1156*b53bb29fSJung-uk Kim #endif 1157*b53bb29fSJung-uk Kim yym = yylhs[yyn]; 1158*b53bb29fSJung-uk Kim if (yystate == 0 && yym == 0) 1159*b53bb29fSJung-uk Kim { 1160*b53bb29fSJung-uk Kim #if YYDEBUG 1161*b53bb29fSJung-uk Kim if (yydebug) 1162*b53bb29fSJung-uk Kim { 1163*b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: after reduction, ", YYDEBUGSTR, yydepth); 1164*b53bb29fSJung-uk Kim #ifdef YYSTYPE_TOSTRING 1165*b53bb29fSJung-uk Kim #if YYBTYACC 1166*b53bb29fSJung-uk Kim if (!yytrial) 1167*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 1168*b53bb29fSJung-uk Kim fprintf(stderr, "result is <%s>, ", YYSTYPE_TOSTRING(yystos[YYFINAL], yyval)); 1169*b53bb29fSJung-uk Kim #endif 1170*b53bb29fSJung-uk Kim fprintf(stderr, "shifting from state 0 to final state %d\n", YYFINAL); 1171*b53bb29fSJung-uk Kim } 1172*b53bb29fSJung-uk Kim #endif 1173*b53bb29fSJung-uk Kim yystate = YYFINAL; 1174*b53bb29fSJung-uk Kim *++yystack.s_mark = YYFINAL; 1175*b53bb29fSJung-uk Kim *++yystack.l_mark = yyval; 1176*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1177*b53bb29fSJung-uk Kim *++yystack.p_mark = yyloc; 1178*b53bb29fSJung-uk Kim #endif 1179*b53bb29fSJung-uk Kim if (yychar < 0) 1180*b53bb29fSJung-uk Kim { 1181*b53bb29fSJung-uk Kim #if YYBTYACC 1182*b53bb29fSJung-uk Kim do { 1183*b53bb29fSJung-uk Kim if (yylvp < yylve) 1184*b53bb29fSJung-uk Kim { 1185*b53bb29fSJung-uk Kim /* we're currently re-reading tokens */ 1186*b53bb29fSJung-uk Kim yylval = *yylvp++; 1187*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1188*b53bb29fSJung-uk Kim yylloc = *yylpp++; 1189*b53bb29fSJung-uk Kim #endif 1190*b53bb29fSJung-uk Kim yychar = *yylexp++; 1191*b53bb29fSJung-uk Kim break; 1192*b53bb29fSJung-uk Kim } 1193*b53bb29fSJung-uk Kim if (yyps->save) 1194*b53bb29fSJung-uk Kim { 1195*b53bb29fSJung-uk Kim /* in trial mode; save scanner results for future parse attempts */ 1196*b53bb29fSJung-uk Kim if (yylvp == yylvlim) 1197*b53bb29fSJung-uk Kim { /* Enlarge lexical value queue */ 1198*b53bb29fSJung-uk Kim size_t p = (size_t) (yylvp - yylvals); 1199*b53bb29fSJung-uk Kim size_t s = (size_t) (yylvlim - yylvals); 1200*b53bb29fSJung-uk Kim 1201*b53bb29fSJung-uk Kim s += YYLVQUEUEGROWTH; 1202*b53bb29fSJung-uk Kim if ((yylexemes = (YYINT *)realloc(yylexemes, s * sizeof(YYINT))) == NULL) 1203*b53bb29fSJung-uk Kim goto yyenomem; 1204*b53bb29fSJung-uk Kim if ((yylvals = (YYSTYPE *)realloc(yylvals, s * sizeof(YYSTYPE))) == NULL) 1205*b53bb29fSJung-uk Kim goto yyenomem; 1206*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1207*b53bb29fSJung-uk Kim if ((yylpsns = (YYLTYPE *)realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL) 1208*b53bb29fSJung-uk Kim goto yyenomem; 1209*b53bb29fSJung-uk Kim #endif 1210*b53bb29fSJung-uk Kim yylvp = yylve = yylvals + p; 1211*b53bb29fSJung-uk Kim yylvlim = yylvals + s; 1212*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1213*b53bb29fSJung-uk Kim yylpp = yylpe = yylpsns + p; 1214*b53bb29fSJung-uk Kim yylplim = yylpsns + s; 1215*b53bb29fSJung-uk Kim #endif 1216*b53bb29fSJung-uk Kim yylexp = yylexemes + p; 1217*b53bb29fSJung-uk Kim } 1218*b53bb29fSJung-uk Kim *yylexp = (YYINT) YYLEX; 1219*b53bb29fSJung-uk Kim *yylvp++ = yylval; 1220*b53bb29fSJung-uk Kim yylve++; 1221*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1222*b53bb29fSJung-uk Kim *yylpp++ = yylloc; 1223*b53bb29fSJung-uk Kim yylpe++; 1224*b53bb29fSJung-uk Kim #endif 1225*b53bb29fSJung-uk Kim yychar = *yylexp++; 1226*b53bb29fSJung-uk Kim break; 1227*b53bb29fSJung-uk Kim } 1228*b53bb29fSJung-uk Kim /* normal operation, no conflict encountered */ 1229*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 1230*b53bb29fSJung-uk Kim yychar = YYLEX; 1231*b53bb29fSJung-uk Kim #if YYBTYACC 1232*b53bb29fSJung-uk Kim } while (0); 1233*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 1234*b53bb29fSJung-uk Kim if (yychar < 0) yychar = YYEOF; 1235*b53bb29fSJung-uk Kim #if YYDEBUG 1236*b53bb29fSJung-uk Kim if (yydebug) 1237*b53bb29fSJung-uk Kim { 1238*b53bb29fSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 1239*b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)\n", 1240*b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, YYFINAL, yychar, yys); 1241*b53bb29fSJung-uk Kim } 1242*b53bb29fSJung-uk Kim #endif 1243*b53bb29fSJung-uk Kim } 1244*b53bb29fSJung-uk Kim if (yychar == YYEOF) goto yyaccept; 1245*b53bb29fSJung-uk Kim goto yyloop; 1246*b53bb29fSJung-uk Kim } 1247*b53bb29fSJung-uk Kim if (((yyn = yygindex[yym]) != 0) && (yyn += yystate) >= 0 && 1248*b53bb29fSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yystate) 1249*b53bb29fSJung-uk Kim yystate = yytable[yyn]; 1250*b53bb29fSJung-uk Kim else 1251*b53bb29fSJung-uk Kim yystate = yydgoto[yym]; 1252*b53bb29fSJung-uk Kim #if YYDEBUG 1253*b53bb29fSJung-uk Kim if (yydebug) 1254*b53bb29fSJung-uk Kim { 1255*b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: after reduction, ", YYDEBUGSTR, yydepth); 1256*b53bb29fSJung-uk Kim #ifdef YYSTYPE_TOSTRING 1257*b53bb29fSJung-uk Kim #if YYBTYACC 1258*b53bb29fSJung-uk Kim if (!yytrial) 1259*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 1260*b53bb29fSJung-uk Kim fprintf(stderr, "result is <%s>, ", YYSTYPE_TOSTRING(yystos[yystate], yyval)); 1261*b53bb29fSJung-uk Kim #endif 1262*b53bb29fSJung-uk Kim fprintf(stderr, "shifting from state %d to state %d\n", *yystack.s_mark, yystate); 1263*b53bb29fSJung-uk Kim } 1264*b53bb29fSJung-uk Kim #endif 1265*b53bb29fSJung-uk Kim if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 1266*b53bb29fSJung-uk Kim *++yystack.s_mark = (YYINT) yystate; 1267*b53bb29fSJung-uk Kim *++yystack.l_mark = yyval; 1268*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1269*b53bb29fSJung-uk Kim *++yystack.p_mark = yyloc; 1270*b53bb29fSJung-uk Kim #endif 1271*b53bb29fSJung-uk Kim goto yyloop; 1272*b53bb29fSJung-uk Kim #if YYBTYACC 1273*b53bb29fSJung-uk Kim 1274*b53bb29fSJung-uk Kim /* Reduction declares that this path is valid. Set yypath and do a full parse */ 1275*b53bb29fSJung-uk Kim yyvalid: 1276*b53bb29fSJung-uk Kim if (yypath) YYABORT; 1277*b53bb29fSJung-uk Kim while (yyps->save) 1278*b53bb29fSJung-uk Kim { 1279*b53bb29fSJung-uk Kim YYParseState *save = yyps->save; 1280*b53bb29fSJung-uk Kim yyps->save = save->save; 1281*b53bb29fSJung-uk Kim save->save = yypath; 1282*b53bb29fSJung-uk Kim yypath = save; 1283*b53bb29fSJung-uk Kim } 1284*b53bb29fSJung-uk Kim #if YYDEBUG 1285*b53bb29fSJung-uk Kim if (yydebug) 1286*b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, CONFLICT trial successful, backtracking to state %d, %d tokens\n", 1287*b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, yystate, yypath->state, (int)(yylvp - yylvals - yypath->lexeme)); 1288*b53bb29fSJung-uk Kim #endif 1289*b53bb29fSJung-uk Kim if (yyerrctx) 1290*b53bb29fSJung-uk Kim { 1291*b53bb29fSJung-uk Kim yyFreeState(yyerrctx); 1292*b53bb29fSJung-uk Kim yyerrctx = NULL; 1293*b53bb29fSJung-uk Kim } 1294*b53bb29fSJung-uk Kim yylvp = yylvals + yypath->lexeme; 1295*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1296*b53bb29fSJung-uk Kim yylpp = yylpsns + yypath->lexeme; 1297*b53bb29fSJung-uk Kim #endif 1298*b53bb29fSJung-uk Kim yylexp = yylexemes + yypath->lexeme; 1299*b53bb29fSJung-uk Kim yychar = YYEMPTY; 1300*b53bb29fSJung-uk Kim yystack.s_mark = yystack.s_base + (yypath->yystack.s_mark - yypath->yystack.s_base); 1301*b53bb29fSJung-uk Kim memcpy (yystack.s_base, yypath->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT)); 1302*b53bb29fSJung-uk Kim yystack.l_mark = yystack.l_base + (yypath->yystack.l_mark - yypath->yystack.l_base); 1303*b53bb29fSJung-uk Kim memcpy (yystack.l_base, yypath->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE)); 1304*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1305*b53bb29fSJung-uk Kim yystack.p_mark = yystack.p_base + (yypath->yystack.p_mark - yypath->yystack.p_base); 1306*b53bb29fSJung-uk Kim memcpy (yystack.p_base, yypath->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE)); 1307*b53bb29fSJung-uk Kim #endif 1308*b53bb29fSJung-uk Kim yystate = yypath->state; 1309*b53bb29fSJung-uk Kim goto yyloop; 1310*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 1311*b53bb29fSJung-uk Kim 1312*b53bb29fSJung-uk Kim yyoverflow: 1313*b53bb29fSJung-uk Kim YYERROR_CALL("yacc stack overflow"); 1314*b53bb29fSJung-uk Kim #if YYBTYACC 1315*b53bb29fSJung-uk Kim goto yyabort_nomem; 1316*b53bb29fSJung-uk Kim yyenomem: 1317*b53bb29fSJung-uk Kim YYERROR_CALL("memory exhausted"); 1318*b53bb29fSJung-uk Kim yyabort_nomem: 1319*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 1320*b53bb29fSJung-uk Kim yyresult = 2; 1321*b53bb29fSJung-uk Kim goto yyreturn; 1322*b53bb29fSJung-uk Kim 1323*b53bb29fSJung-uk Kim yyabort: 1324*b53bb29fSJung-uk Kim yyresult = 1; 1325*b53bb29fSJung-uk Kim goto yyreturn; 1326*b53bb29fSJung-uk Kim 1327*b53bb29fSJung-uk Kim yyaccept: 1328*b53bb29fSJung-uk Kim #if YYBTYACC 1329*b53bb29fSJung-uk Kim if (yyps->save) goto yyvalid; 1330*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 1331*b53bb29fSJung-uk Kim yyresult = 0; 1332*b53bb29fSJung-uk Kim 1333*b53bb29fSJung-uk Kim yyreturn: 1334*b53bb29fSJung-uk Kim #if defined(YYDESTRUCT_CALL) 1335*b53bb29fSJung-uk Kim if (yychar != YYEOF && yychar != YYEMPTY) 1336*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1337*b53bb29fSJung-uk Kim YYDESTRUCT_CALL("cleanup: discarding token", yychar, &yylval, &yylloc); 1338*b53bb29fSJung-uk Kim #else 1339*b53bb29fSJung-uk Kim YYDESTRUCT_CALL("cleanup: discarding token", yychar, &yylval); 1340*b53bb29fSJung-uk Kim #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 1341*b53bb29fSJung-uk Kim 1342*b53bb29fSJung-uk Kim { 1343*b53bb29fSJung-uk Kim YYSTYPE *pv; 1344*b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) 1345*b53bb29fSJung-uk Kim YYLTYPE *pp; 1346*b53bb29fSJung-uk Kim 1347*b53bb29fSJung-uk Kim for (pv = yystack.l_base, pp = yystack.p_base; pv <= yystack.l_mark; ++pv, ++pp) 1348*b53bb29fSJung-uk Kim YYDESTRUCT_CALL("cleanup: discarding state", 1349*b53bb29fSJung-uk Kim yystos[*(yystack.s_base + (pv - yystack.l_base))], pv, pp); 1350*b53bb29fSJung-uk Kim #else 1351*b53bb29fSJung-uk Kim for (pv = yystack.l_base; pv <= yystack.l_mark; ++pv) 1352*b53bb29fSJung-uk Kim YYDESTRUCT_CALL("cleanup: discarding state", 1353*b53bb29fSJung-uk Kim yystos[*(yystack.s_base + (pv - yystack.l_base))], pv); 1354*b53bb29fSJung-uk Kim #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */ 1355*b53bb29fSJung-uk Kim } 1356*b53bb29fSJung-uk Kim #endif /* defined(YYDESTRUCT_CALL) */ 1357*b53bb29fSJung-uk Kim 1358*b53bb29fSJung-uk Kim #if YYBTYACC 1359*b53bb29fSJung-uk Kim if (yyerrctx) 1360*b53bb29fSJung-uk Kim { 1361*b53bb29fSJung-uk Kim yyFreeState(yyerrctx); 1362*b53bb29fSJung-uk Kim yyerrctx = NULL; 1363*b53bb29fSJung-uk Kim } 1364*b53bb29fSJung-uk Kim while (yyps) 1365*b53bb29fSJung-uk Kim { 1366*b53bb29fSJung-uk Kim YYParseState *save = yyps; 1367*b53bb29fSJung-uk Kim yyps = save->save; 1368*b53bb29fSJung-uk Kim save->save = NULL; 1369*b53bb29fSJung-uk Kim yyFreeState(save); 1370*b53bb29fSJung-uk Kim } 1371*b53bb29fSJung-uk Kim while (yypath) 1372*b53bb29fSJung-uk Kim { 1373*b53bb29fSJung-uk Kim YYParseState *save = yypath; 1374*b53bb29fSJung-uk Kim yypath = save->save; 1375*b53bb29fSJung-uk Kim save->save = NULL; 1376*b53bb29fSJung-uk Kim yyFreeState(save); 1377*b53bb29fSJung-uk Kim } 1378*b53bb29fSJung-uk Kim #endif /* YYBTYACC */ 1379*b53bb29fSJung-uk Kim yyfreestack(&yystack); 1380*b53bb29fSJung-uk Kim return (yyresult); 1381*b53bb29fSJung-uk Kim } 1382