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