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 17*b53bb29fSJung-uk Kim /* %code "top" block start */ 18*b53bb29fSJung-uk Kim #line 5 "calc_code_all.y" 19*b53bb29fSJung-uk Kim /* CODE-TOP */ 20*b53bb29fSJung-uk Kim /* %code "top" block end */ 21*b53bb29fSJung-uk Kim #line 22 "calc_code_all.tab.c" 22*b53bb29fSJung-uk Kim 23*b53bb29fSJung-uk Kim #ifndef yyparse 24*b53bb29fSJung-uk Kim #define yyparse calc_code_all_parse 25*b53bb29fSJung-uk Kim #endif /* yyparse */ 26*b53bb29fSJung-uk Kim 27*b53bb29fSJung-uk Kim #ifndef yylex 28*b53bb29fSJung-uk Kim #define yylex calc_code_all_lex 29*b53bb29fSJung-uk Kim #endif /* yylex */ 30*b53bb29fSJung-uk Kim 31*b53bb29fSJung-uk Kim #ifndef yyerror 32*b53bb29fSJung-uk Kim #define yyerror calc_code_all_error 33*b53bb29fSJung-uk Kim #endif /* yyerror */ 34*b53bb29fSJung-uk Kim 35*b53bb29fSJung-uk Kim #ifndef yychar 36*b53bb29fSJung-uk Kim #define yychar calc_code_all_char 37*b53bb29fSJung-uk Kim #endif /* yychar */ 38*b53bb29fSJung-uk Kim 39*b53bb29fSJung-uk Kim #ifndef yyval 40*b53bb29fSJung-uk Kim #define yyval calc_code_all_val 41*b53bb29fSJung-uk Kim #endif /* yyval */ 42*b53bb29fSJung-uk Kim 43*b53bb29fSJung-uk Kim #ifndef yylval 44*b53bb29fSJung-uk Kim #define yylval calc_code_all_lval 45*b53bb29fSJung-uk Kim #endif /* yylval */ 46*b53bb29fSJung-uk Kim 47*b53bb29fSJung-uk Kim #ifndef yydebug 48*b53bb29fSJung-uk Kim #define yydebug calc_code_all_debug 49*b53bb29fSJung-uk Kim #endif /* yydebug */ 50*b53bb29fSJung-uk Kim 51*b53bb29fSJung-uk Kim #ifndef yynerrs 52*b53bb29fSJung-uk Kim #define yynerrs calc_code_all_nerrs 53*b53bb29fSJung-uk Kim #endif /* yynerrs */ 54*b53bb29fSJung-uk Kim 55*b53bb29fSJung-uk Kim #ifndef yyerrflag 56*b53bb29fSJung-uk Kim #define yyerrflag calc_code_all_errflag 57*b53bb29fSJung-uk Kim #endif /* yyerrflag */ 58*b53bb29fSJung-uk Kim 59*b53bb29fSJung-uk Kim #ifndef yylhs 60*b53bb29fSJung-uk Kim #define yylhs calc_code_all_lhs 61*b53bb29fSJung-uk Kim #endif /* yylhs */ 62*b53bb29fSJung-uk Kim 63*b53bb29fSJung-uk Kim #ifndef yylen 64*b53bb29fSJung-uk Kim #define yylen calc_code_all_len 65*b53bb29fSJung-uk Kim #endif /* yylen */ 66*b53bb29fSJung-uk Kim 67*b53bb29fSJung-uk Kim #ifndef yydefred 68*b53bb29fSJung-uk Kim #define yydefred calc_code_all_defred 69*b53bb29fSJung-uk Kim #endif /* yydefred */ 70*b53bb29fSJung-uk Kim 71*b53bb29fSJung-uk Kim #ifndef yydgoto 72*b53bb29fSJung-uk Kim #define yydgoto calc_code_all_dgoto 73*b53bb29fSJung-uk Kim #endif /* yydgoto */ 74*b53bb29fSJung-uk Kim 75*b53bb29fSJung-uk Kim #ifndef yysindex 76*b53bb29fSJung-uk Kim #define yysindex calc_code_all_sindex 77*b53bb29fSJung-uk Kim #endif /* yysindex */ 78*b53bb29fSJung-uk Kim 79*b53bb29fSJung-uk Kim #ifndef yyrindex 80*b53bb29fSJung-uk Kim #define yyrindex calc_code_all_rindex 81*b53bb29fSJung-uk Kim #endif /* yyrindex */ 82*b53bb29fSJung-uk Kim 83*b53bb29fSJung-uk Kim #ifndef yygindex 84*b53bb29fSJung-uk Kim #define yygindex calc_code_all_gindex 85*b53bb29fSJung-uk Kim #endif /* yygindex */ 86*b53bb29fSJung-uk Kim 87*b53bb29fSJung-uk Kim #ifndef yytable 88*b53bb29fSJung-uk Kim #define yytable calc_code_all_table 89*b53bb29fSJung-uk Kim #endif /* yytable */ 90*b53bb29fSJung-uk Kim 91*b53bb29fSJung-uk Kim #ifndef yycheck 92*b53bb29fSJung-uk Kim #define yycheck calc_code_all_check 93*b53bb29fSJung-uk Kim #endif /* yycheck */ 94*b53bb29fSJung-uk Kim 95*b53bb29fSJung-uk Kim #ifndef yyname 96*b53bb29fSJung-uk Kim #define yyname calc_code_all_name 97*b53bb29fSJung-uk Kim #endif /* yyname */ 98*b53bb29fSJung-uk Kim 99*b53bb29fSJung-uk Kim #ifndef yyrule 100*b53bb29fSJung-uk Kim #define yyrule calc_code_all_rule 101*b53bb29fSJung-uk Kim #endif /* yyrule */ 102*b53bb29fSJung-uk Kim #define YYPREFIX "calc_code_all_" 103*b53bb29fSJung-uk Kim 104*b53bb29fSJung-uk Kim #define YYPURE 0 105*b53bb29fSJung-uk Kim 106*b53bb29fSJung-uk Kim #line 9 "calc_code_all.y" 107*b53bb29fSJung-uk Kim # include <stdio.h> 108*b53bb29fSJung-uk Kim # include <ctype.h> 109*b53bb29fSJung-uk Kim 110*b53bb29fSJung-uk Kim int regs[26]; 111*b53bb29fSJung-uk Kim int base; 112*b53bb29fSJung-uk Kim 113*b53bb29fSJung-uk Kim extern int yylex(void); 114*b53bb29fSJung-uk Kim static void yyerror(const char *s); 115*b53bb29fSJung-uk Kim 116*b53bb29fSJung-uk Kim #line 117 "calc_code_all.tab.c" 117*b53bb29fSJung-uk Kim 118*b53bb29fSJung-uk Kim #if ! defined(YYSTYPE) && ! defined(YYSTYPE_IS_DECLARED) 119*b53bb29fSJung-uk Kim /* Default: YYSTYPE is the semantic value type. */ 120*b53bb29fSJung-uk Kim typedef int YYSTYPE; 121*b53bb29fSJung-uk Kim # define YYSTYPE_IS_DECLARED 1 122*b53bb29fSJung-uk Kim #endif 123*b53bb29fSJung-uk Kim 124*b53bb29fSJung-uk Kim /* compatibility with bison */ 125*b53bb29fSJung-uk Kim #ifdef YYPARSE_PARAM 126*b53bb29fSJung-uk Kim /* compatibility with FreeBSD */ 127*b53bb29fSJung-uk Kim # ifdef YYPARSE_PARAM_TYPE 128*b53bb29fSJung-uk Kim # define YYPARSE_DECL() yyparse(YYPARSE_PARAM_TYPE YYPARSE_PARAM) 129*b53bb29fSJung-uk Kim # else 130*b53bb29fSJung-uk Kim # define YYPARSE_DECL() yyparse(void *YYPARSE_PARAM) 131*b53bb29fSJung-uk Kim # endif 132*b53bb29fSJung-uk Kim #else 133*b53bb29fSJung-uk Kim # define YYPARSE_DECL() yyparse(void) 134*b53bb29fSJung-uk Kim #endif 135*b53bb29fSJung-uk Kim 136*b53bb29fSJung-uk Kim /* Parameters sent to lex. */ 137*b53bb29fSJung-uk Kim #ifdef YYLEX_PARAM 138*b53bb29fSJung-uk Kim # define YYLEX_DECL() yylex(void *YYLEX_PARAM) 139*b53bb29fSJung-uk Kim # define YYLEX yylex(YYLEX_PARAM) 140*b53bb29fSJung-uk Kim #else 141*b53bb29fSJung-uk Kim # define YYLEX_DECL() yylex(void) 142*b53bb29fSJung-uk Kim # define YYLEX yylex() 143*b53bb29fSJung-uk Kim #endif 144*b53bb29fSJung-uk Kim 145*b53bb29fSJung-uk Kim /* Parameters sent to yyerror. */ 146*b53bb29fSJung-uk Kim #ifndef YYERROR_DECL 147*b53bb29fSJung-uk Kim #define YYERROR_DECL() yyerror(const char *s) 148*b53bb29fSJung-uk Kim #endif 149*b53bb29fSJung-uk Kim #ifndef YYERROR_CALL 150*b53bb29fSJung-uk Kim #define YYERROR_CALL(msg) yyerror(msg) 151*b53bb29fSJung-uk Kim #endif 152*b53bb29fSJung-uk Kim 153*b53bb29fSJung-uk Kim extern int YYPARSE_DECL(); 154*b53bb29fSJung-uk Kim 155*b53bb29fSJung-uk Kim #define DIGIT 257 156*b53bb29fSJung-uk Kim #define LETTER 258 157*b53bb29fSJung-uk Kim #define UMINUS 259 158*b53bb29fSJung-uk Kim #define YYERRCODE 256 159*b53bb29fSJung-uk Kim typedef int YYINT; 160*b53bb29fSJung-uk Kim static const YYINT calc_code_all_lhs[] = { -1, 161*b53bb29fSJung-uk Kim 0, 0, 0, 1, 1, 2, 2, 2, 2, 2, 162*b53bb29fSJung-uk Kim 2, 2, 2, 2, 2, 2, 3, 3, 163*b53bb29fSJung-uk Kim }; 164*b53bb29fSJung-uk Kim static const YYINT calc_code_all_len[] = { 2, 165*b53bb29fSJung-uk Kim 0, 3, 3, 1, 3, 3, 3, 3, 3, 3, 166*b53bb29fSJung-uk Kim 3, 3, 3, 2, 1, 1, 1, 2, 167*b53bb29fSJung-uk Kim }; 168*b53bb29fSJung-uk Kim static const YYINT calc_code_all_defred[] = { 1, 169*b53bb29fSJung-uk Kim 0, 0, 17, 0, 0, 0, 0, 0, 0, 3, 170*b53bb29fSJung-uk Kim 0, 15, 14, 0, 2, 0, 0, 0, 0, 0, 171*b53bb29fSJung-uk Kim 0, 0, 18, 0, 6, 0, 0, 0, 0, 9, 172*b53bb29fSJung-uk Kim 10, 11, 173*b53bb29fSJung-uk Kim }; 174*b53bb29fSJung-uk Kim static const YYINT calc_code_all_dgoto[] = { 1, 175*b53bb29fSJung-uk Kim 7, 8, 9, 176*b53bb29fSJung-uk Kim }; 177*b53bb29fSJung-uk Kim static const YYINT calc_code_all_sindex[] = { 0, 178*b53bb29fSJung-uk Kim -40, -7, 0, -55, -38, -38, 1, -29, -247, 0, 179*b53bb29fSJung-uk Kim -38, 0, 0, 22, 0, -38, -38, -38, -38, -38, 180*b53bb29fSJung-uk Kim -38, -38, 0, -29, 0, 51, 60, -20, -20, 0, 181*b53bb29fSJung-uk Kim 0, 0, 182*b53bb29fSJung-uk Kim }; 183*b53bb29fSJung-uk Kim static const YYINT calc_code_all_rindex[] = { 0, 184*b53bb29fSJung-uk Kim 0, 0, 0, 2, 0, 0, 0, 9, -9, 0, 185*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 186*b53bb29fSJung-uk Kim 0, 0, 0, 10, 0, -6, 14, 5, 13, 0, 187*b53bb29fSJung-uk Kim 0, 0, 188*b53bb29fSJung-uk Kim }; 189*b53bb29fSJung-uk Kim static const YYINT calc_code_all_gindex[] = { 0, 190*b53bb29fSJung-uk Kim 0, 65, 0, 191*b53bb29fSJung-uk Kim }; 192*b53bb29fSJung-uk Kim #define YYTABLESIZE 220 193*b53bb29fSJung-uk Kim static const YYINT calc_code_all_table[] = { 6, 194*b53bb29fSJung-uk Kim 16, 6, 10, 13, 5, 11, 5, 22, 17, 23, 195*b53bb29fSJung-uk Kim 15, 15, 20, 18, 7, 19, 22, 21, 4, 5, 196*b53bb29fSJung-uk Kim 0, 20, 8, 12, 0, 0, 21, 16, 16, 0, 197*b53bb29fSJung-uk Kim 0, 16, 16, 16, 13, 16, 0, 16, 15, 15, 198*b53bb29fSJung-uk Kim 0, 0, 7, 15, 15, 7, 15, 7, 15, 7, 199*b53bb29fSJung-uk Kim 8, 12, 0, 8, 12, 8, 0, 8, 22, 17, 200*b53bb29fSJung-uk Kim 0, 0, 25, 20, 18, 0, 19, 0, 21, 13, 201*b53bb29fSJung-uk Kim 14, 0, 0, 0, 0, 24, 0, 0, 0, 0, 202*b53bb29fSJung-uk Kim 26, 27, 28, 29, 30, 31, 32, 22, 17, 0, 203*b53bb29fSJung-uk Kim 0, 0, 20, 18, 16, 19, 22, 21, 0, 0, 204*b53bb29fSJung-uk Kim 0, 20, 18, 0, 19, 0, 21, 0, 0, 0, 205*b53bb29fSJung-uk Kim 0, 0, 0, 0, 16, 0, 0, 13, 0, 0, 206*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 15, 0, 0, 7, 0, 207*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 8, 12, 0, 0, 208*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 16, 0, 0, 0, 0, 209*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 210*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 211*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 212*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 213*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 214*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 215*b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 2, 3, 4, 3, 12, 216*b53bb29fSJung-uk Kim }; 217*b53bb29fSJung-uk Kim static const YYINT calc_code_all_check[] = { 40, 218*b53bb29fSJung-uk Kim 10, 40, 10, 10, 45, 61, 45, 37, 38, 257, 219*b53bb29fSJung-uk Kim 10, 10, 42, 43, 10, 45, 37, 47, 10, 10, 220*b53bb29fSJung-uk Kim -1, 42, 10, 10, -1, -1, 47, 37, 38, -1, 221*b53bb29fSJung-uk Kim -1, 41, 42, 43, 41, 45, -1, 47, 37, 38, 222*b53bb29fSJung-uk Kim -1, -1, 38, 42, 43, 41, 45, 43, 47, 45, 223*b53bb29fSJung-uk Kim 38, 38, -1, 41, 41, 43, -1, 45, 37, 38, 224*b53bb29fSJung-uk Kim -1, -1, 41, 42, 43, -1, 45, -1, 47, 5, 225*b53bb29fSJung-uk Kim 6, -1, -1, -1, -1, 11, -1, -1, -1, -1, 226*b53bb29fSJung-uk Kim 16, 17, 18, 19, 20, 21, 22, 37, 38, -1, 227*b53bb29fSJung-uk Kim -1, -1, 42, 43, 124, 45, 37, 47, -1, -1, 228*b53bb29fSJung-uk Kim -1, 42, 43, -1, 45, -1, 47, -1, -1, -1, 229*b53bb29fSJung-uk Kim -1, -1, -1, -1, 124, -1, -1, 124, -1, -1, 230*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, 124, -1, -1, 124, -1, 231*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, 124, 124, -1, -1, 232*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, 124, -1, -1, -1, -1, 233*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 234*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 235*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 236*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 237*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 238*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 239*b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, 256, 257, 258, 257, 258, 240*b53bb29fSJung-uk Kim }; 241*b53bb29fSJung-uk Kim #define YYFINAL 1 242*b53bb29fSJung-uk Kim #ifndef YYDEBUG 243*b53bb29fSJung-uk Kim #define YYDEBUG 0 244*b53bb29fSJung-uk Kim #endif 245*b53bb29fSJung-uk Kim #define YYMAXTOKEN 259 246*b53bb29fSJung-uk Kim #define YYUNDFTOKEN 265 247*b53bb29fSJung-uk Kim #define YYTRANSLATE(a) ((a) > YYMAXTOKEN ? YYUNDFTOKEN : (a)) 248*b53bb29fSJung-uk Kim #if YYDEBUG 249*b53bb29fSJung-uk Kim static const char *const calc_code_all_name[] = { 250*b53bb29fSJung-uk Kim 251*b53bb29fSJung-uk Kim "end-of-file",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, 252*b53bb29fSJung-uk Kim 0,0,0,0,0,0,"'%'","'&'",0,"'('","')'","'*'","'+'",0,"'-'",0,"'/'",0,0,0,0,0,0,0, 253*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, 254*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, 255*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, 256*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, 257*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, 258*b53bb29fSJung-uk Kim 0,0,0,0,0,0,"DIGIT","LETTER","UMINUS",0,0,0,0,0,"illegal-symbol", 259*b53bb29fSJung-uk Kim }; 260*b53bb29fSJung-uk Kim static const char *const calc_code_all_rule[] = { 261*b53bb29fSJung-uk Kim "$accept : list", 262*b53bb29fSJung-uk Kim "list :", 263*b53bb29fSJung-uk Kim "list : list stat '\\n'", 264*b53bb29fSJung-uk Kim "list : list error '\\n'", 265*b53bb29fSJung-uk Kim "stat : expr", 266*b53bb29fSJung-uk Kim "stat : LETTER '=' expr", 267*b53bb29fSJung-uk Kim "expr : '(' expr ')'", 268*b53bb29fSJung-uk Kim "expr : expr '+' expr", 269*b53bb29fSJung-uk Kim "expr : expr '-' expr", 270*b53bb29fSJung-uk Kim "expr : expr '*' expr", 271*b53bb29fSJung-uk Kim "expr : expr '/' expr", 272*b53bb29fSJung-uk Kim "expr : expr '%' expr", 273*b53bb29fSJung-uk Kim "expr : expr '&' expr", 274*b53bb29fSJung-uk Kim "expr : expr '|' expr", 275*b53bb29fSJung-uk Kim "expr : '-' expr", 276*b53bb29fSJung-uk Kim "expr : LETTER", 277*b53bb29fSJung-uk Kim "expr : number", 278*b53bb29fSJung-uk Kim "number : DIGIT", 279*b53bb29fSJung-uk Kim "number : number DIGIT", 280*b53bb29fSJung-uk Kim 281*b53bb29fSJung-uk Kim }; 282*b53bb29fSJung-uk Kim #endif 283*b53bb29fSJung-uk Kim 284*b53bb29fSJung-uk Kim #if YYDEBUG 285*b53bb29fSJung-uk Kim int yydebug; 286*b53bb29fSJung-uk Kim #endif 287*b53bb29fSJung-uk Kim 288*b53bb29fSJung-uk Kim int yyerrflag; 289*b53bb29fSJung-uk Kim int yychar; 290*b53bb29fSJung-uk Kim YYSTYPE yyval; 291*b53bb29fSJung-uk Kim YYSTYPE yylval; 292*b53bb29fSJung-uk Kim int yynerrs; 293*b53bb29fSJung-uk Kim 294*b53bb29fSJung-uk Kim /* %code "requires" block start */ 295*b53bb29fSJung-uk Kim #line 3 "calc_code_all.y" 296*b53bb29fSJung-uk Kim /* CODE-REQUIRES */ 297*b53bb29fSJung-uk Kim /* %code "requires" block end */ 298*b53bb29fSJung-uk Kim #line 299 "calc_code_all.tab.c" 299*b53bb29fSJung-uk Kim 300*b53bb29fSJung-uk Kim /* define the initial stack-sizes */ 301*b53bb29fSJung-uk Kim #ifdef YYSTACKSIZE 302*b53bb29fSJung-uk Kim #undef YYMAXDEPTH 303*b53bb29fSJung-uk Kim #define YYMAXDEPTH YYSTACKSIZE 304*b53bb29fSJung-uk Kim #else 305*b53bb29fSJung-uk Kim #ifdef YYMAXDEPTH 306*b53bb29fSJung-uk Kim #define YYSTACKSIZE YYMAXDEPTH 307*b53bb29fSJung-uk Kim #else 308*b53bb29fSJung-uk Kim #define YYSTACKSIZE 10000 309*b53bb29fSJung-uk Kim #define YYMAXDEPTH 10000 310*b53bb29fSJung-uk Kim #endif 311*b53bb29fSJung-uk Kim #endif 312*b53bb29fSJung-uk Kim 313*b53bb29fSJung-uk Kim #define YYINITSTACKSIZE 200 314*b53bb29fSJung-uk Kim 315*b53bb29fSJung-uk Kim typedef struct { 316*b53bb29fSJung-uk Kim unsigned stacksize; 317*b53bb29fSJung-uk Kim YYINT *s_base; 318*b53bb29fSJung-uk Kim YYINT *s_mark; 319*b53bb29fSJung-uk Kim YYINT *s_last; 320*b53bb29fSJung-uk Kim YYSTYPE *l_base; 321*b53bb29fSJung-uk Kim YYSTYPE *l_mark; 322*b53bb29fSJung-uk Kim } YYSTACKDATA; 323*b53bb29fSJung-uk Kim /* variables for the parser stack */ 324*b53bb29fSJung-uk Kim static YYSTACKDATA yystack; 325*b53bb29fSJung-uk Kim 326*b53bb29fSJung-uk Kim /* %code "provides" block start */ 327*b53bb29fSJung-uk Kim #line 4 "calc_code_all.y" 328*b53bb29fSJung-uk Kim /* CODE-PROVIDES */ 329*b53bb29fSJung-uk Kim #line 6 "calc_code_all.y" 330*b53bb29fSJung-uk Kim /* CODE-PROVIDES2 */ 331*b53bb29fSJung-uk Kim /* %code "provides" block end */ 332*b53bb29fSJung-uk Kim #line 333 "calc_code_all.tab.c" 333*b53bb29fSJung-uk Kim 334*b53bb29fSJung-uk Kim /* %code "" block start */ 335*b53bb29fSJung-uk Kim #line 1 "calc_code_all.y" 336*b53bb29fSJung-uk Kim /* CODE-DEFAULT2 */ 337*b53bb29fSJung-uk Kim #line 2 "calc_code_all.y" 338*b53bb29fSJung-uk Kim /* CODE-DEFAULT */ 339*b53bb29fSJung-uk Kim /* %code "" block end */ 340*b53bb29fSJung-uk Kim #line 341 "calc_code_all.tab.c" 341*b53bb29fSJung-uk Kim #line 73 "calc_code_all.y" 342*b53bb29fSJung-uk Kim /* start of programs */ 343*b53bb29fSJung-uk Kim 344*b53bb29fSJung-uk Kim int 345*b53bb29fSJung-uk Kim main (void) 346*b53bb29fSJung-uk Kim { 347*b53bb29fSJung-uk Kim while(!feof(stdin)) { 348*b53bb29fSJung-uk Kim yyparse(); 349*b53bb29fSJung-uk Kim } 350*b53bb29fSJung-uk Kim return 0; 351*b53bb29fSJung-uk Kim } 352*b53bb29fSJung-uk Kim 353*b53bb29fSJung-uk Kim static void 354*b53bb29fSJung-uk Kim yyerror(const char *s) 355*b53bb29fSJung-uk Kim { 356*b53bb29fSJung-uk Kim fprintf(stderr, "%s\n", s); 357*b53bb29fSJung-uk Kim } 358*b53bb29fSJung-uk Kim 359*b53bb29fSJung-uk Kim int 360*b53bb29fSJung-uk Kim yylex(void) 361*b53bb29fSJung-uk Kim { 362*b53bb29fSJung-uk Kim /* lexical analysis routine */ 363*b53bb29fSJung-uk Kim /* returns LETTER for a lower case letter, yylval = 0 through 25 */ 364*b53bb29fSJung-uk Kim /* return DIGIT for a digit, yylval = 0 through 9 */ 365*b53bb29fSJung-uk Kim /* all other characters are returned immediately */ 366*b53bb29fSJung-uk Kim 367*b53bb29fSJung-uk Kim int c; 368*b53bb29fSJung-uk Kim 369*b53bb29fSJung-uk Kim while( (c=getchar()) == ' ' ) { /* skip blanks */ } 370*b53bb29fSJung-uk Kim 371*b53bb29fSJung-uk Kim /* c is now nonblank */ 372*b53bb29fSJung-uk Kim 373*b53bb29fSJung-uk Kim if( islower( c )) { 374*b53bb29fSJung-uk Kim yylval = c - 'a'; 375*b53bb29fSJung-uk Kim return ( LETTER ); 376*b53bb29fSJung-uk Kim } 377*b53bb29fSJung-uk Kim if( isdigit( c )) { 378*b53bb29fSJung-uk Kim yylval = c - '0'; 379*b53bb29fSJung-uk Kim return ( DIGIT ); 380*b53bb29fSJung-uk Kim } 381*b53bb29fSJung-uk Kim return( c ); 382*b53bb29fSJung-uk Kim } 383*b53bb29fSJung-uk Kim #line 384 "calc_code_all.tab.c" 384*b53bb29fSJung-uk Kim 385*b53bb29fSJung-uk Kim #if YYDEBUG 386*b53bb29fSJung-uk Kim #include <stdio.h> /* needed for printf */ 387*b53bb29fSJung-uk Kim #endif 388*b53bb29fSJung-uk Kim 389*b53bb29fSJung-uk Kim #include <stdlib.h> /* needed for malloc, etc */ 390*b53bb29fSJung-uk Kim #include <string.h> /* needed for memset */ 391*b53bb29fSJung-uk Kim 392*b53bb29fSJung-uk Kim /* allocate initial stack or double stack size, up to YYMAXDEPTH */ 393*b53bb29fSJung-uk Kim static int yygrowstack(YYSTACKDATA *data) 394*b53bb29fSJung-uk Kim { 395*b53bb29fSJung-uk Kim int i; 396*b53bb29fSJung-uk Kim unsigned newsize; 397*b53bb29fSJung-uk Kim YYINT *newss; 398*b53bb29fSJung-uk Kim YYSTYPE *newvs; 399*b53bb29fSJung-uk Kim 400*b53bb29fSJung-uk Kim if ((newsize = data->stacksize) == 0) 401*b53bb29fSJung-uk Kim newsize = YYINITSTACKSIZE; 402*b53bb29fSJung-uk Kim else if (newsize >= YYMAXDEPTH) 403*b53bb29fSJung-uk Kim return YYENOMEM; 404*b53bb29fSJung-uk Kim else if ((newsize *= 2) > YYMAXDEPTH) 405*b53bb29fSJung-uk Kim newsize = YYMAXDEPTH; 406*b53bb29fSJung-uk Kim 407*b53bb29fSJung-uk Kim i = (int) (data->s_mark - data->s_base); 408*b53bb29fSJung-uk Kim newss = (YYINT *)realloc(data->s_base, newsize * sizeof(*newss)); 409*b53bb29fSJung-uk Kim if (newss == 0) 410*b53bb29fSJung-uk Kim return YYENOMEM; 411*b53bb29fSJung-uk Kim 412*b53bb29fSJung-uk Kim data->s_base = newss; 413*b53bb29fSJung-uk Kim data->s_mark = newss + i; 414*b53bb29fSJung-uk Kim 415*b53bb29fSJung-uk Kim newvs = (YYSTYPE *)realloc(data->l_base, newsize * sizeof(*newvs)); 416*b53bb29fSJung-uk Kim if (newvs == 0) 417*b53bb29fSJung-uk Kim return YYENOMEM; 418*b53bb29fSJung-uk Kim 419*b53bb29fSJung-uk Kim data->l_base = newvs; 420*b53bb29fSJung-uk Kim data->l_mark = newvs + i; 421*b53bb29fSJung-uk Kim 422*b53bb29fSJung-uk Kim data->stacksize = newsize; 423*b53bb29fSJung-uk Kim data->s_last = data->s_base + newsize - 1; 424*b53bb29fSJung-uk Kim return 0; 425*b53bb29fSJung-uk Kim } 426*b53bb29fSJung-uk Kim 427*b53bb29fSJung-uk Kim #if YYPURE || defined(YY_NO_LEAKS) 428*b53bb29fSJung-uk Kim static void yyfreestack(YYSTACKDATA *data) 429*b53bb29fSJung-uk Kim { 430*b53bb29fSJung-uk Kim free(data->s_base); 431*b53bb29fSJung-uk Kim free(data->l_base); 432*b53bb29fSJung-uk Kim memset(data, 0, sizeof(*data)); 433*b53bb29fSJung-uk Kim } 434*b53bb29fSJung-uk Kim #else 435*b53bb29fSJung-uk Kim #define yyfreestack(data) /* nothing */ 436*b53bb29fSJung-uk Kim #endif 437*b53bb29fSJung-uk Kim 438*b53bb29fSJung-uk Kim #define YYABORT goto yyabort 439*b53bb29fSJung-uk Kim #define YYREJECT goto yyabort 440*b53bb29fSJung-uk Kim #define YYACCEPT goto yyaccept 441*b53bb29fSJung-uk Kim #define YYERROR goto yyerrlab 442*b53bb29fSJung-uk Kim 443*b53bb29fSJung-uk Kim int 444*b53bb29fSJung-uk Kim YYPARSE_DECL() 445*b53bb29fSJung-uk Kim { 446*b53bb29fSJung-uk Kim int yym, yyn, yystate; 447*b53bb29fSJung-uk Kim #if YYDEBUG 448*b53bb29fSJung-uk Kim const char *yys; 449*b53bb29fSJung-uk Kim 450*b53bb29fSJung-uk Kim if ((yys = getenv("YYDEBUG")) != 0) 451*b53bb29fSJung-uk Kim { 452*b53bb29fSJung-uk Kim yyn = *yys; 453*b53bb29fSJung-uk Kim if (yyn >= '0' && yyn <= '9') 454*b53bb29fSJung-uk Kim yydebug = yyn - '0'; 455*b53bb29fSJung-uk Kim } 456*b53bb29fSJung-uk Kim #endif 457*b53bb29fSJung-uk Kim 458*b53bb29fSJung-uk Kim yym = 0; 459*b53bb29fSJung-uk Kim yyn = 0; 460*b53bb29fSJung-uk Kim yynerrs = 0; 461*b53bb29fSJung-uk Kim yyerrflag = 0; 462*b53bb29fSJung-uk Kim yychar = YYEMPTY; 463*b53bb29fSJung-uk Kim yystate = 0; 464*b53bb29fSJung-uk Kim 465*b53bb29fSJung-uk Kim #if YYPURE 466*b53bb29fSJung-uk Kim memset(&yystack, 0, sizeof(yystack)); 467*b53bb29fSJung-uk Kim #endif 468*b53bb29fSJung-uk Kim 469*b53bb29fSJung-uk Kim if (yystack.s_base == NULL && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 470*b53bb29fSJung-uk Kim yystack.s_mark = yystack.s_base; 471*b53bb29fSJung-uk Kim yystack.l_mark = yystack.l_base; 472*b53bb29fSJung-uk Kim yystate = 0; 473*b53bb29fSJung-uk Kim *yystack.s_mark = 0; 474*b53bb29fSJung-uk Kim 475*b53bb29fSJung-uk Kim yyloop: 476*b53bb29fSJung-uk Kim if ((yyn = yydefred[yystate]) != 0) goto yyreduce; 477*b53bb29fSJung-uk Kim if (yychar < 0) 478*b53bb29fSJung-uk Kim { 479*b53bb29fSJung-uk Kim yychar = YYLEX; 480*b53bb29fSJung-uk Kim if (yychar < 0) yychar = YYEOF; 481*b53bb29fSJung-uk Kim #if YYDEBUG 482*b53bb29fSJung-uk Kim if (yydebug) 483*b53bb29fSJung-uk Kim { 484*b53bb29fSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 485*b53bb29fSJung-uk Kim printf("%sdebug: state %d, reading %d (%s)\n", 486*b53bb29fSJung-uk Kim YYPREFIX, yystate, yychar, yys); 487*b53bb29fSJung-uk Kim } 488*b53bb29fSJung-uk Kim #endif 489*b53bb29fSJung-uk Kim } 490*b53bb29fSJung-uk Kim if (((yyn = yysindex[yystate]) != 0) && (yyn += yychar) >= 0 && 491*b53bb29fSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 492*b53bb29fSJung-uk Kim { 493*b53bb29fSJung-uk Kim #if YYDEBUG 494*b53bb29fSJung-uk Kim if (yydebug) 495*b53bb29fSJung-uk Kim printf("%sdebug: state %d, shifting to state %d\n", 496*b53bb29fSJung-uk Kim YYPREFIX, yystate, yytable[yyn]); 497*b53bb29fSJung-uk Kim #endif 498*b53bb29fSJung-uk Kim if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 499*b53bb29fSJung-uk Kim yystate = yytable[yyn]; 500*b53bb29fSJung-uk Kim *++yystack.s_mark = yytable[yyn]; 501*b53bb29fSJung-uk Kim *++yystack.l_mark = yylval; 502*b53bb29fSJung-uk Kim yychar = YYEMPTY; 503*b53bb29fSJung-uk Kim if (yyerrflag > 0) --yyerrflag; 504*b53bb29fSJung-uk Kim goto yyloop; 505*b53bb29fSJung-uk Kim } 506*b53bb29fSJung-uk Kim if (((yyn = yyrindex[yystate]) != 0) && (yyn += yychar) >= 0 && 507*b53bb29fSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar) 508*b53bb29fSJung-uk Kim { 509*b53bb29fSJung-uk Kim yyn = yytable[yyn]; 510*b53bb29fSJung-uk Kim goto yyreduce; 511*b53bb29fSJung-uk Kim } 512*b53bb29fSJung-uk Kim if (yyerrflag != 0) goto yyinrecovery; 513*b53bb29fSJung-uk Kim 514*b53bb29fSJung-uk Kim YYERROR_CALL("syntax error"); 515*b53bb29fSJung-uk Kim 516*b53bb29fSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */ 517*b53bb29fSJung-uk Kim yyerrlab: 518*b53bb29fSJung-uk Kim ++yynerrs; 519*b53bb29fSJung-uk Kim 520*b53bb29fSJung-uk Kim yyinrecovery: 521*b53bb29fSJung-uk Kim if (yyerrflag < 3) 522*b53bb29fSJung-uk Kim { 523*b53bb29fSJung-uk Kim yyerrflag = 3; 524*b53bb29fSJung-uk Kim for (;;) 525*b53bb29fSJung-uk Kim { 526*b53bb29fSJung-uk Kim if (((yyn = yysindex[*yystack.s_mark]) != 0) && (yyn += YYERRCODE) >= 0 && 527*b53bb29fSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) YYERRCODE) 528*b53bb29fSJung-uk Kim { 529*b53bb29fSJung-uk Kim #if YYDEBUG 530*b53bb29fSJung-uk Kim if (yydebug) 531*b53bb29fSJung-uk Kim printf("%sdebug: state %d, error recovery shifting\ 532*b53bb29fSJung-uk Kim to state %d\n", YYPREFIX, *yystack.s_mark, yytable[yyn]); 533*b53bb29fSJung-uk Kim #endif 534*b53bb29fSJung-uk Kim if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 535*b53bb29fSJung-uk Kim yystate = yytable[yyn]; 536*b53bb29fSJung-uk Kim *++yystack.s_mark = yytable[yyn]; 537*b53bb29fSJung-uk Kim *++yystack.l_mark = yylval; 538*b53bb29fSJung-uk Kim goto yyloop; 539*b53bb29fSJung-uk Kim } 540*b53bb29fSJung-uk Kim else 541*b53bb29fSJung-uk Kim { 542*b53bb29fSJung-uk Kim #if YYDEBUG 543*b53bb29fSJung-uk Kim if (yydebug) 544*b53bb29fSJung-uk Kim printf("%sdebug: error recovery discarding state %d\n", 545*b53bb29fSJung-uk Kim YYPREFIX, *yystack.s_mark); 546*b53bb29fSJung-uk Kim #endif 547*b53bb29fSJung-uk Kim if (yystack.s_mark <= yystack.s_base) goto yyabort; 548*b53bb29fSJung-uk Kim --yystack.s_mark; 549*b53bb29fSJung-uk Kim --yystack.l_mark; 550*b53bb29fSJung-uk Kim } 551*b53bb29fSJung-uk Kim } 552*b53bb29fSJung-uk Kim } 553*b53bb29fSJung-uk Kim else 554*b53bb29fSJung-uk Kim { 555*b53bb29fSJung-uk Kim if (yychar == YYEOF) goto yyabort; 556*b53bb29fSJung-uk Kim #if YYDEBUG 557*b53bb29fSJung-uk Kim if (yydebug) 558*b53bb29fSJung-uk Kim { 559*b53bb29fSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 560*b53bb29fSJung-uk Kim printf("%sdebug: state %d, error recovery discards token %d (%s)\n", 561*b53bb29fSJung-uk Kim YYPREFIX, yystate, yychar, yys); 562*b53bb29fSJung-uk Kim } 563*b53bb29fSJung-uk Kim #endif 564*b53bb29fSJung-uk Kim yychar = YYEMPTY; 565*b53bb29fSJung-uk Kim goto yyloop; 566*b53bb29fSJung-uk Kim } 567*b53bb29fSJung-uk Kim 568*b53bb29fSJung-uk Kim yyreduce: 569*b53bb29fSJung-uk Kim #if YYDEBUG 570*b53bb29fSJung-uk Kim if (yydebug) 571*b53bb29fSJung-uk Kim printf("%sdebug: state %d, reducing by rule %d (%s)\n", 572*b53bb29fSJung-uk Kim YYPREFIX, yystate, yyn, yyrule[yyn]); 573*b53bb29fSJung-uk Kim #endif 574*b53bb29fSJung-uk Kim yym = yylen[yyn]; 575*b53bb29fSJung-uk Kim if (yym > 0) 576*b53bb29fSJung-uk Kim yyval = yystack.l_mark[1-yym]; 577*b53bb29fSJung-uk Kim else 578*b53bb29fSJung-uk Kim memset(&yyval, 0, sizeof yyval); 579*b53bb29fSJung-uk Kim 580*b53bb29fSJung-uk Kim switch (yyn) 581*b53bb29fSJung-uk Kim { 582*b53bb29fSJung-uk Kim case 3: 583*b53bb29fSJung-uk Kim #line 35 "calc_code_all.y" 584*b53bb29fSJung-uk Kim { yyerrok ; } 585*b53bb29fSJung-uk Kim break; 586*b53bb29fSJung-uk Kim case 4: 587*b53bb29fSJung-uk Kim #line 39 "calc_code_all.y" 588*b53bb29fSJung-uk Kim { printf("%d\n",yystack.l_mark[0]);} 589*b53bb29fSJung-uk Kim break; 590*b53bb29fSJung-uk Kim case 5: 591*b53bb29fSJung-uk Kim #line 41 "calc_code_all.y" 592*b53bb29fSJung-uk Kim { regs[yystack.l_mark[-2]] = yystack.l_mark[0]; } 593*b53bb29fSJung-uk Kim break; 594*b53bb29fSJung-uk Kim case 6: 595*b53bb29fSJung-uk Kim #line 45 "calc_code_all.y" 596*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-1]; } 597*b53bb29fSJung-uk Kim break; 598*b53bb29fSJung-uk Kim case 7: 599*b53bb29fSJung-uk Kim #line 47 "calc_code_all.y" 600*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] + yystack.l_mark[0]; } 601*b53bb29fSJung-uk Kim break; 602*b53bb29fSJung-uk Kim case 8: 603*b53bb29fSJung-uk Kim #line 49 "calc_code_all.y" 604*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] - yystack.l_mark[0]; } 605*b53bb29fSJung-uk Kim break; 606*b53bb29fSJung-uk Kim case 9: 607*b53bb29fSJung-uk Kim #line 51 "calc_code_all.y" 608*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] * yystack.l_mark[0]; } 609*b53bb29fSJung-uk Kim break; 610*b53bb29fSJung-uk Kim case 10: 611*b53bb29fSJung-uk Kim #line 53 "calc_code_all.y" 612*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] / yystack.l_mark[0]; } 613*b53bb29fSJung-uk Kim break; 614*b53bb29fSJung-uk Kim case 11: 615*b53bb29fSJung-uk Kim #line 55 "calc_code_all.y" 616*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] % yystack.l_mark[0]; } 617*b53bb29fSJung-uk Kim break; 618*b53bb29fSJung-uk Kim case 12: 619*b53bb29fSJung-uk Kim #line 57 "calc_code_all.y" 620*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] & yystack.l_mark[0]; } 621*b53bb29fSJung-uk Kim break; 622*b53bb29fSJung-uk Kim case 13: 623*b53bb29fSJung-uk Kim #line 59 "calc_code_all.y" 624*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] | yystack.l_mark[0]; } 625*b53bb29fSJung-uk Kim break; 626*b53bb29fSJung-uk Kim case 14: 627*b53bb29fSJung-uk Kim #line 61 "calc_code_all.y" 628*b53bb29fSJung-uk Kim { yyval = - yystack.l_mark[0]; } 629*b53bb29fSJung-uk Kim break; 630*b53bb29fSJung-uk Kim case 15: 631*b53bb29fSJung-uk Kim #line 63 "calc_code_all.y" 632*b53bb29fSJung-uk Kim { yyval = regs[yystack.l_mark[0]]; } 633*b53bb29fSJung-uk Kim break; 634*b53bb29fSJung-uk Kim case 17: 635*b53bb29fSJung-uk Kim #line 68 "calc_code_all.y" 636*b53bb29fSJung-uk Kim { yyval = yystack.l_mark[0]; base = (yystack.l_mark[0]==0) ? 8 : 10; } 637*b53bb29fSJung-uk Kim break; 638*b53bb29fSJung-uk Kim case 18: 639*b53bb29fSJung-uk Kim #line 70 "calc_code_all.y" 640*b53bb29fSJung-uk Kim { yyval = base * yystack.l_mark[-1] + yystack.l_mark[0]; } 641*b53bb29fSJung-uk Kim break; 642*b53bb29fSJung-uk Kim #line 643 "calc_code_all.tab.c" 643*b53bb29fSJung-uk Kim } 644*b53bb29fSJung-uk Kim yystack.s_mark -= yym; 645*b53bb29fSJung-uk Kim yystate = *yystack.s_mark; 646*b53bb29fSJung-uk Kim yystack.l_mark -= yym; 647*b53bb29fSJung-uk Kim yym = yylhs[yyn]; 648*b53bb29fSJung-uk Kim if (yystate == 0 && yym == 0) 649*b53bb29fSJung-uk Kim { 650*b53bb29fSJung-uk Kim #if YYDEBUG 651*b53bb29fSJung-uk Kim if (yydebug) 652*b53bb29fSJung-uk Kim printf("%sdebug: after reduction, shifting from state 0 to\ 653*b53bb29fSJung-uk Kim state %d\n", YYPREFIX, YYFINAL); 654*b53bb29fSJung-uk Kim #endif 655*b53bb29fSJung-uk Kim yystate = YYFINAL; 656*b53bb29fSJung-uk Kim *++yystack.s_mark = YYFINAL; 657*b53bb29fSJung-uk Kim *++yystack.l_mark = yyval; 658*b53bb29fSJung-uk Kim if (yychar < 0) 659*b53bb29fSJung-uk Kim { 660*b53bb29fSJung-uk Kim yychar = YYLEX; 661*b53bb29fSJung-uk Kim if (yychar < 0) yychar = YYEOF; 662*b53bb29fSJung-uk Kim #if YYDEBUG 663*b53bb29fSJung-uk Kim if (yydebug) 664*b53bb29fSJung-uk Kim { 665*b53bb29fSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN]; 666*b53bb29fSJung-uk Kim printf("%sdebug: state %d, reading %d (%s)\n", 667*b53bb29fSJung-uk Kim YYPREFIX, YYFINAL, yychar, yys); 668*b53bb29fSJung-uk Kim } 669*b53bb29fSJung-uk Kim #endif 670*b53bb29fSJung-uk Kim } 671*b53bb29fSJung-uk Kim if (yychar == YYEOF) goto yyaccept; 672*b53bb29fSJung-uk Kim goto yyloop; 673*b53bb29fSJung-uk Kim } 674*b53bb29fSJung-uk Kim if (((yyn = yygindex[yym]) != 0) && (yyn += yystate) >= 0 && 675*b53bb29fSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yystate) 676*b53bb29fSJung-uk Kim yystate = yytable[yyn]; 677*b53bb29fSJung-uk Kim else 678*b53bb29fSJung-uk Kim yystate = yydgoto[yym]; 679*b53bb29fSJung-uk Kim #if YYDEBUG 680*b53bb29fSJung-uk Kim if (yydebug) 681*b53bb29fSJung-uk Kim printf("%sdebug: after reduction, shifting from state %d \ 682*b53bb29fSJung-uk Kim to state %d\n", YYPREFIX, *yystack.s_mark, yystate); 683*b53bb29fSJung-uk Kim #endif 684*b53bb29fSJung-uk Kim if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow; 685*b53bb29fSJung-uk Kim *++yystack.s_mark = (YYINT) yystate; 686*b53bb29fSJung-uk Kim *++yystack.l_mark = yyval; 687*b53bb29fSJung-uk Kim goto yyloop; 688*b53bb29fSJung-uk Kim 689*b53bb29fSJung-uk Kim yyoverflow: 690*b53bb29fSJung-uk Kim YYERROR_CALL("yacc stack overflow"); 691*b53bb29fSJung-uk Kim 692*b53bb29fSJung-uk Kim yyabort: 693*b53bb29fSJung-uk Kim yyfreestack(&yystack); 694*b53bb29fSJung-uk Kim return (1); 695*b53bb29fSJung-uk Kim 696*b53bb29fSJung-uk Kim yyaccept: 697*b53bb29fSJung-uk Kim yyfreestack(&yystack); 698*b53bb29fSJung-uk Kim return (0); 699*b53bb29fSJung-uk Kim } 700