xref: /freebsd/contrib/byacc/test/yacc/code_calc.code.c (revision c5b5d71ad3977f66e7a9c8f5193f10bfd6ac15d8)
10c8de5b0SBaptiste Daroussin /* original parser id follows */
20c8de5b0SBaptiste Daroussin /* yysccsid[] = "@(#)yaccpar	1.9 (Berkeley) 02/21/93" */
30c8de5b0SBaptiste Daroussin /* (use YYMAJOR/YYMINOR for ifdefs dependent on parser version) */
40c8de5b0SBaptiste Daroussin 
50c8de5b0SBaptiste Daroussin #define YYBYACC 1
60c8de5b0SBaptiste Daroussin #define YYMAJOR 1
70c8de5b0SBaptiste Daroussin #define YYMINOR 9
80c8de5b0SBaptiste Daroussin #define YYCHECK "yyyymmdd"
90c8de5b0SBaptiste Daroussin 
100c8de5b0SBaptiste Daroussin #define YYEMPTY        (-1)
110c8de5b0SBaptiste Daroussin #define yyclearin      (yychar = YYEMPTY)
120c8de5b0SBaptiste Daroussin #define yyerrok        (yyerrflag = 0)
130c8de5b0SBaptiste Daroussin #define YYRECOVERING() (yyerrflag != 0)
140c8de5b0SBaptiste Daroussin #define YYENOMEM       (-2)
150c8de5b0SBaptiste Daroussin #define YYEOF          0
160c8de5b0SBaptiste Daroussin 
170c8de5b0SBaptiste Daroussin #ifndef yyparse
180c8de5b0SBaptiste Daroussin #define yyparse    calc_parse
190c8de5b0SBaptiste Daroussin #endif /* yyparse */
200c8de5b0SBaptiste Daroussin 
210c8de5b0SBaptiste Daroussin #ifndef yylex
220c8de5b0SBaptiste Daroussin #define yylex      calc_lex
230c8de5b0SBaptiste Daroussin #endif /* yylex */
240c8de5b0SBaptiste Daroussin 
250c8de5b0SBaptiste Daroussin #ifndef yyerror
260c8de5b0SBaptiste Daroussin #define yyerror    calc_error
270c8de5b0SBaptiste Daroussin #endif /* yyerror */
280c8de5b0SBaptiste Daroussin 
290c8de5b0SBaptiste Daroussin #ifndef yychar
300c8de5b0SBaptiste Daroussin #define yychar     calc_char
310c8de5b0SBaptiste Daroussin #endif /* yychar */
320c8de5b0SBaptiste Daroussin 
330c8de5b0SBaptiste Daroussin #ifndef yyval
340c8de5b0SBaptiste Daroussin #define yyval      calc_val
350c8de5b0SBaptiste Daroussin #endif /* yyval */
360c8de5b0SBaptiste Daroussin 
370c8de5b0SBaptiste Daroussin #ifndef yylval
380c8de5b0SBaptiste Daroussin #define yylval     calc_lval
390c8de5b0SBaptiste Daroussin #endif /* yylval */
400c8de5b0SBaptiste Daroussin 
410c8de5b0SBaptiste Daroussin #ifndef yydebug
420c8de5b0SBaptiste Daroussin #define yydebug    calc_debug
430c8de5b0SBaptiste Daroussin #endif /* yydebug */
440c8de5b0SBaptiste Daroussin 
450c8de5b0SBaptiste Daroussin #ifndef yynerrs
460c8de5b0SBaptiste Daroussin #define yynerrs    calc_nerrs
470c8de5b0SBaptiste Daroussin #endif /* yynerrs */
480c8de5b0SBaptiste Daroussin 
490c8de5b0SBaptiste Daroussin #ifndef yyerrflag
500c8de5b0SBaptiste Daroussin #define yyerrflag  calc_errflag
510c8de5b0SBaptiste Daroussin #endif /* yyerrflag */
520c8de5b0SBaptiste Daroussin 
530c8de5b0SBaptiste Daroussin #ifndef yylhs
540c8de5b0SBaptiste Daroussin #define yylhs      calc_lhs
550c8de5b0SBaptiste Daroussin #endif /* yylhs */
560c8de5b0SBaptiste Daroussin 
570c8de5b0SBaptiste Daroussin #ifndef yylen
580c8de5b0SBaptiste Daroussin #define yylen      calc_len
590c8de5b0SBaptiste Daroussin #endif /* yylen */
600c8de5b0SBaptiste Daroussin 
610c8de5b0SBaptiste Daroussin #ifndef yydefred
620c8de5b0SBaptiste Daroussin #define yydefred   calc_defred
630c8de5b0SBaptiste Daroussin #endif /* yydefred */
640c8de5b0SBaptiste Daroussin 
650c8de5b0SBaptiste Daroussin #ifndef yydgoto
660c8de5b0SBaptiste Daroussin #define yydgoto    calc_dgoto
670c8de5b0SBaptiste Daroussin #endif /* yydgoto */
680c8de5b0SBaptiste Daroussin 
690c8de5b0SBaptiste Daroussin #ifndef yysindex
700c8de5b0SBaptiste Daroussin #define yysindex   calc_sindex
710c8de5b0SBaptiste Daroussin #endif /* yysindex */
720c8de5b0SBaptiste Daroussin 
730c8de5b0SBaptiste Daroussin #ifndef yyrindex
740c8de5b0SBaptiste Daroussin #define yyrindex   calc_rindex
750c8de5b0SBaptiste Daroussin #endif /* yyrindex */
760c8de5b0SBaptiste Daroussin 
770c8de5b0SBaptiste Daroussin #ifndef yygindex
780c8de5b0SBaptiste Daroussin #define yygindex   calc_gindex
790c8de5b0SBaptiste Daroussin #endif /* yygindex */
800c8de5b0SBaptiste Daroussin 
810c8de5b0SBaptiste Daroussin #ifndef yytable
820c8de5b0SBaptiste Daroussin #define yytable    calc_table
830c8de5b0SBaptiste Daroussin #endif /* yytable */
840c8de5b0SBaptiste Daroussin 
850c8de5b0SBaptiste Daroussin #ifndef yycheck
860c8de5b0SBaptiste Daroussin #define yycheck    calc_check
870c8de5b0SBaptiste Daroussin #endif /* yycheck */
880c8de5b0SBaptiste Daroussin 
890c8de5b0SBaptiste Daroussin #ifndef yyname
900c8de5b0SBaptiste Daroussin #define yyname     calc_name
910c8de5b0SBaptiste Daroussin #endif /* yyname */
920c8de5b0SBaptiste Daroussin 
930c8de5b0SBaptiste Daroussin #ifndef yyrule
940c8de5b0SBaptiste Daroussin #define yyrule     calc_rule
950c8de5b0SBaptiste Daroussin #endif /* yyrule */
960c8de5b0SBaptiste Daroussin #define YYPREFIX "calc_"
970c8de5b0SBaptiste Daroussin 
980c8de5b0SBaptiste Daroussin #define YYPURE 0
990c8de5b0SBaptiste Daroussin 
100*c5b5d71aSJung-uk Kim #line 4 "code_calc.y"
1010c8de5b0SBaptiste Daroussin # include <stdio.h>
1020c8de5b0SBaptiste Daroussin # include <ctype.h>
1030c8de5b0SBaptiste Daroussin 
1040c8de5b0SBaptiste Daroussin int regs[26];
1050c8de5b0SBaptiste Daroussin int base;
1060c8de5b0SBaptiste Daroussin 
1070c8de5b0SBaptiste Daroussin #ifdef YYBISON
1080c8de5b0SBaptiste Daroussin int yylex(void);
1090c8de5b0SBaptiste Daroussin static void yyerror(const char *s);
1100c8de5b0SBaptiste Daroussin #endif
1110c8de5b0SBaptiste Daroussin 
1120c8de5b0SBaptiste Daroussin #line 113 "code_calc.code.c"
1130c8de5b0SBaptiste Daroussin 
1140c8de5b0SBaptiste Daroussin #if ! defined(YYSTYPE) && ! defined(YYSTYPE_IS_DECLARED)
1150c8de5b0SBaptiste Daroussin /* Default: YYSTYPE is the semantic value type. */
1160c8de5b0SBaptiste Daroussin typedef int YYSTYPE;
1170c8de5b0SBaptiste Daroussin # define YYSTYPE_IS_DECLARED 1
1180c8de5b0SBaptiste Daroussin #endif
1190c8de5b0SBaptiste Daroussin 
1200c8de5b0SBaptiste Daroussin /* compatibility with bison */
1210c8de5b0SBaptiste Daroussin #ifdef YYPARSE_PARAM
1220c8de5b0SBaptiste Daroussin /* compatibility with FreeBSD */
1230c8de5b0SBaptiste Daroussin # ifdef YYPARSE_PARAM_TYPE
1240c8de5b0SBaptiste Daroussin #  define YYPARSE_DECL() yyparse(YYPARSE_PARAM_TYPE YYPARSE_PARAM)
1250c8de5b0SBaptiste Daroussin # else
1260c8de5b0SBaptiste Daroussin #  define YYPARSE_DECL() yyparse(void *YYPARSE_PARAM)
1270c8de5b0SBaptiste Daroussin # endif
1280c8de5b0SBaptiste Daroussin #else
1290c8de5b0SBaptiste Daroussin # define YYPARSE_DECL() yyparse(void)
1300c8de5b0SBaptiste Daroussin #endif
1310c8de5b0SBaptiste Daroussin 
1320c8de5b0SBaptiste Daroussin /* Parameters sent to lex. */
1330c8de5b0SBaptiste Daroussin #ifdef YYLEX_PARAM
1340c8de5b0SBaptiste Daroussin # define YYLEX_DECL() yylex(void *YYLEX_PARAM)
1350c8de5b0SBaptiste Daroussin # define YYLEX yylex(YYLEX_PARAM)
1360c8de5b0SBaptiste Daroussin #else
1370c8de5b0SBaptiste Daroussin # define YYLEX_DECL() yylex(void)
1380c8de5b0SBaptiste Daroussin # define YYLEX yylex()
1390c8de5b0SBaptiste Daroussin #endif
1400c8de5b0SBaptiste Daroussin 
1410c8de5b0SBaptiste Daroussin /* Parameters sent to yyerror. */
1420c8de5b0SBaptiste Daroussin #ifndef YYERROR_DECL
1430c8de5b0SBaptiste Daroussin #define YYERROR_DECL() yyerror(const char *s)
1440c8de5b0SBaptiste Daroussin #endif
1450c8de5b0SBaptiste Daroussin #ifndef YYERROR_CALL
1460c8de5b0SBaptiste Daroussin #define YYERROR_CALL(msg) yyerror(msg)
1470c8de5b0SBaptiste Daroussin #endif
1480c8de5b0SBaptiste Daroussin 
1490c8de5b0SBaptiste Daroussin #define DIGIT 257
1500c8de5b0SBaptiste Daroussin #define LETTER 258
1510c8de5b0SBaptiste Daroussin #define UMINUS 259
1520c8de5b0SBaptiste Daroussin #define YYERRCODE 256
153*c5b5d71aSJung-uk Kim #undef yytname
154*c5b5d71aSJung-uk Kim #define yytname yyname
1550c8de5b0SBaptiste Daroussin #define YYTABLESIZE 220
1560c8de5b0SBaptiste Daroussin #define YYFINAL 1
1570c8de5b0SBaptiste Daroussin #ifndef YYDEBUG
1580c8de5b0SBaptiste Daroussin #define YYDEBUG 0
1590c8de5b0SBaptiste Daroussin #endif
1600c8de5b0SBaptiste Daroussin #define YYMAXTOKEN 259
1610c8de5b0SBaptiste Daroussin #define YYUNDFTOKEN 265
1620c8de5b0SBaptiste Daroussin #define YYTRANSLATE(a) ((a) > YYMAXTOKEN ? YYUNDFTOKEN : (a))
1630c8de5b0SBaptiste Daroussin 
1640c8de5b0SBaptiste Daroussin extern int YYPARSE_DECL();
165ea2af5c8SJung-uk Kim typedef int YYINT;
1660c8de5b0SBaptiste Daroussin extern YYINT yylhs[];
1670c8de5b0SBaptiste Daroussin extern YYINT yylen[];
1680c8de5b0SBaptiste Daroussin extern YYINT yydefred[];
1690c8de5b0SBaptiste Daroussin extern YYINT yydgoto[];
1700c8de5b0SBaptiste Daroussin extern YYINT yysindex[];
1710c8de5b0SBaptiste Daroussin extern YYINT yyrindex[];
1720c8de5b0SBaptiste Daroussin extern YYINT yygindex[];
1730c8de5b0SBaptiste Daroussin extern YYINT yytable[];
1740c8de5b0SBaptiste Daroussin extern YYINT yycheck[];
1750c8de5b0SBaptiste Daroussin 
176*c5b5d71aSJung-uk Kim #if YYDEBUG || defined(yytname)
1770c8de5b0SBaptiste Daroussin extern char *yyname[];
178*c5b5d71aSJung-uk Kim #endif
179*c5b5d71aSJung-uk Kim #if YYDEBUG
1800c8de5b0SBaptiste Daroussin extern char *yyrule[];
1810c8de5b0SBaptiste Daroussin #endif
1820c8de5b0SBaptiste Daroussin 
1830c8de5b0SBaptiste Daroussin int      yydebug;
1840c8de5b0SBaptiste Daroussin int      yynerrs;
1850c8de5b0SBaptiste Daroussin 
1860c8de5b0SBaptiste Daroussin int      yyerrflag;
1870c8de5b0SBaptiste Daroussin int      yychar;
1880c8de5b0SBaptiste Daroussin YYSTYPE  yyval;
1890c8de5b0SBaptiste Daroussin YYSTYPE  yylval;
1900c8de5b0SBaptiste Daroussin 
1910c8de5b0SBaptiste Daroussin /* define the initial stack-sizes */
1920c8de5b0SBaptiste Daroussin #ifdef YYSTACKSIZE
1930c8de5b0SBaptiste Daroussin #undef YYMAXDEPTH
1940c8de5b0SBaptiste Daroussin #define YYMAXDEPTH  YYSTACKSIZE
1950c8de5b0SBaptiste Daroussin #else
1960c8de5b0SBaptiste Daroussin #ifdef YYMAXDEPTH
1970c8de5b0SBaptiste Daroussin #define YYSTACKSIZE YYMAXDEPTH
1980c8de5b0SBaptiste Daroussin #else
1990c8de5b0SBaptiste Daroussin #define YYSTACKSIZE 10000
2000c8de5b0SBaptiste Daroussin #define YYMAXDEPTH  10000
2010c8de5b0SBaptiste Daroussin #endif
2020c8de5b0SBaptiste Daroussin #endif
2030c8de5b0SBaptiste Daroussin 
2040c8de5b0SBaptiste Daroussin #define YYINITSTACKSIZE 200
2050c8de5b0SBaptiste Daroussin 
2060c8de5b0SBaptiste Daroussin typedef struct {
2070c8de5b0SBaptiste Daroussin     unsigned stacksize;
2080c8de5b0SBaptiste Daroussin     YYINT    *s_base;
2090c8de5b0SBaptiste Daroussin     YYINT    *s_mark;
2100c8de5b0SBaptiste Daroussin     YYINT    *s_last;
2110c8de5b0SBaptiste Daroussin     YYSTYPE  *l_base;
2120c8de5b0SBaptiste Daroussin     YYSTYPE  *l_mark;
2130c8de5b0SBaptiste Daroussin } YYSTACKDATA;
2140c8de5b0SBaptiste Daroussin /* variables for the parser stack */
2150c8de5b0SBaptiste Daroussin static YYSTACKDATA yystack;
216*c5b5d71aSJung-uk Kim #line 70 "code_calc.y"
2170c8de5b0SBaptiste Daroussin  /* start of programs */
2180c8de5b0SBaptiste Daroussin 
2190c8de5b0SBaptiste Daroussin #ifdef YYBYACC
2200c8de5b0SBaptiste Daroussin extern int YYLEX_DECL();
2210c8de5b0SBaptiste Daroussin #endif
2220c8de5b0SBaptiste Daroussin 
2230c8de5b0SBaptiste Daroussin int
2240c8de5b0SBaptiste Daroussin main (void)
2250c8de5b0SBaptiste Daroussin {
2260c8de5b0SBaptiste Daroussin     while(!feof(stdin)) {
2270c8de5b0SBaptiste Daroussin 	yyparse();
2280c8de5b0SBaptiste Daroussin     }
2290c8de5b0SBaptiste Daroussin     return 0;
2300c8de5b0SBaptiste Daroussin }
2310c8de5b0SBaptiste Daroussin 
2320c8de5b0SBaptiste Daroussin static void
2330c8de5b0SBaptiste Daroussin yyerror(const char *s)
2340c8de5b0SBaptiste Daroussin {
2350c8de5b0SBaptiste Daroussin     fprintf(stderr, "%s\n", s);
2360c8de5b0SBaptiste Daroussin }
2370c8de5b0SBaptiste Daroussin 
2380c8de5b0SBaptiste Daroussin int
2390c8de5b0SBaptiste Daroussin yylex(void)
2400c8de5b0SBaptiste Daroussin {
2410c8de5b0SBaptiste Daroussin 	/* lexical analysis routine */
2420c8de5b0SBaptiste Daroussin 	/* returns LETTER for a lower case letter, yylval = 0 through 25 */
2430c8de5b0SBaptiste Daroussin 	/* return DIGIT for a digit, yylval = 0 through 9 */
2440c8de5b0SBaptiste Daroussin 	/* all other characters are returned immediately */
2450c8de5b0SBaptiste Daroussin 
2460c8de5b0SBaptiste Daroussin     int c;
2470c8de5b0SBaptiste Daroussin 
2480c8de5b0SBaptiste Daroussin     while( (c=getchar()) == ' ' )   { /* skip blanks */ }
2490c8de5b0SBaptiste Daroussin 
2500c8de5b0SBaptiste Daroussin     /* c is now nonblank */
2510c8de5b0SBaptiste Daroussin 
2520c8de5b0SBaptiste Daroussin     if( islower( c )) {
2530c8de5b0SBaptiste Daroussin 	yylval = c - 'a';
2540c8de5b0SBaptiste Daroussin 	return ( LETTER );
2550c8de5b0SBaptiste Daroussin     }
2560c8de5b0SBaptiste Daroussin     if( isdigit( c )) {
2570c8de5b0SBaptiste Daroussin 	yylval = c - '0';
2580c8de5b0SBaptiste Daroussin 	return ( DIGIT );
2590c8de5b0SBaptiste Daroussin     }
2600c8de5b0SBaptiste Daroussin     return( c );
2610c8de5b0SBaptiste Daroussin }
262*c5b5d71aSJung-uk Kim #line 263 "code_calc.code.c"
2630c8de5b0SBaptiste Daroussin 
2640c8de5b0SBaptiste Daroussin #if YYDEBUG
2650c8de5b0SBaptiste Daroussin #include <stdio.h>	/* needed for printf */
2660c8de5b0SBaptiste Daroussin #endif
2670c8de5b0SBaptiste Daroussin 
2680c8de5b0SBaptiste Daroussin #include <stdlib.h>	/* needed for malloc, etc */
2690c8de5b0SBaptiste Daroussin #include <string.h>	/* needed for memset */
2700c8de5b0SBaptiste Daroussin 
2710c8de5b0SBaptiste Daroussin /* allocate initial stack or double stack size, up to YYMAXDEPTH */
2720c8de5b0SBaptiste Daroussin static int yygrowstack(YYSTACKDATA *data)
2730c8de5b0SBaptiste Daroussin {
2740c8de5b0SBaptiste Daroussin     int i;
2750c8de5b0SBaptiste Daroussin     unsigned newsize;
2760c8de5b0SBaptiste Daroussin     YYINT *newss;
2770c8de5b0SBaptiste Daroussin     YYSTYPE *newvs;
2780c8de5b0SBaptiste Daroussin 
2790c8de5b0SBaptiste Daroussin     if ((newsize = data->stacksize) == 0)
2800c8de5b0SBaptiste Daroussin         newsize = YYINITSTACKSIZE;
2810c8de5b0SBaptiste Daroussin     else if (newsize >= YYMAXDEPTH)
2820c8de5b0SBaptiste Daroussin         return YYENOMEM;
2830c8de5b0SBaptiste Daroussin     else if ((newsize *= 2) > YYMAXDEPTH)
2840c8de5b0SBaptiste Daroussin         newsize = YYMAXDEPTH;
2850c8de5b0SBaptiste Daroussin 
2860c8de5b0SBaptiste Daroussin     i = (int) (data->s_mark - data->s_base);
2870c8de5b0SBaptiste Daroussin     newss = (YYINT *)realloc(data->s_base, newsize * sizeof(*newss));
2880c8de5b0SBaptiste Daroussin     if (newss == 0)
2890c8de5b0SBaptiste Daroussin         return YYENOMEM;
2900c8de5b0SBaptiste Daroussin 
2910c8de5b0SBaptiste Daroussin     data->s_base = newss;
2920c8de5b0SBaptiste Daroussin     data->s_mark = newss + i;
2930c8de5b0SBaptiste Daroussin 
2940c8de5b0SBaptiste Daroussin     newvs = (YYSTYPE *)realloc(data->l_base, newsize * sizeof(*newvs));
2950c8de5b0SBaptiste Daroussin     if (newvs == 0)
2960c8de5b0SBaptiste Daroussin         return YYENOMEM;
2970c8de5b0SBaptiste Daroussin 
2980c8de5b0SBaptiste Daroussin     data->l_base = newvs;
2990c8de5b0SBaptiste Daroussin     data->l_mark = newvs + i;
3000c8de5b0SBaptiste Daroussin 
3010c8de5b0SBaptiste Daroussin     data->stacksize = newsize;
3020c8de5b0SBaptiste Daroussin     data->s_last = data->s_base + newsize - 1;
3030c8de5b0SBaptiste Daroussin     return 0;
3040c8de5b0SBaptiste Daroussin }
3050c8de5b0SBaptiste Daroussin 
3060c8de5b0SBaptiste Daroussin #if YYPURE || defined(YY_NO_LEAKS)
3070c8de5b0SBaptiste Daroussin static void yyfreestack(YYSTACKDATA *data)
3080c8de5b0SBaptiste Daroussin {
3090c8de5b0SBaptiste Daroussin     free(data->s_base);
3100c8de5b0SBaptiste Daroussin     free(data->l_base);
3110c8de5b0SBaptiste Daroussin     memset(data, 0, sizeof(*data));
3120c8de5b0SBaptiste Daroussin }
3130c8de5b0SBaptiste Daroussin #else
3140c8de5b0SBaptiste Daroussin #define yyfreestack(data) /* nothing */
3150c8de5b0SBaptiste Daroussin #endif
3160c8de5b0SBaptiste Daroussin 
3170c8de5b0SBaptiste Daroussin #define YYABORT  goto yyabort
3180c8de5b0SBaptiste Daroussin #define YYREJECT goto yyabort
3190c8de5b0SBaptiste Daroussin #define YYACCEPT goto yyaccept
3200c8de5b0SBaptiste Daroussin #define YYERROR  goto yyerrlab
3210c8de5b0SBaptiste Daroussin 
3220c8de5b0SBaptiste Daroussin int
3230c8de5b0SBaptiste Daroussin YYPARSE_DECL()
3240c8de5b0SBaptiste Daroussin {
3250c8de5b0SBaptiste Daroussin     int yym, yyn, yystate;
3260c8de5b0SBaptiste Daroussin #if YYDEBUG
3270c8de5b0SBaptiste Daroussin     const char *yys;
3280c8de5b0SBaptiste Daroussin 
3290c8de5b0SBaptiste Daroussin     if ((yys = getenv("YYDEBUG")) != 0)
3300c8de5b0SBaptiste Daroussin     {
3310c8de5b0SBaptiste Daroussin         yyn = *yys;
3320c8de5b0SBaptiste Daroussin         if (yyn >= '0' && yyn <= '9')
3330c8de5b0SBaptiste Daroussin             yydebug = yyn - '0';
3340c8de5b0SBaptiste Daroussin     }
3350c8de5b0SBaptiste Daroussin #endif
3360c8de5b0SBaptiste Daroussin 
337*c5b5d71aSJung-uk Kim     yym = 0;
338*c5b5d71aSJung-uk Kim     yyn = 0;
3390c8de5b0SBaptiste Daroussin     yynerrs = 0;
3400c8de5b0SBaptiste Daroussin     yyerrflag = 0;
3410c8de5b0SBaptiste Daroussin     yychar = YYEMPTY;
3420c8de5b0SBaptiste Daroussin     yystate = 0;
3430c8de5b0SBaptiste Daroussin 
3440c8de5b0SBaptiste Daroussin #if YYPURE
3450c8de5b0SBaptiste Daroussin     memset(&yystack, 0, sizeof(yystack));
3460c8de5b0SBaptiste Daroussin #endif
3470c8de5b0SBaptiste Daroussin 
3480c8de5b0SBaptiste Daroussin     if (yystack.s_base == NULL && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
3490c8de5b0SBaptiste Daroussin     yystack.s_mark = yystack.s_base;
3500c8de5b0SBaptiste Daroussin     yystack.l_mark = yystack.l_base;
3510c8de5b0SBaptiste Daroussin     yystate = 0;
3520c8de5b0SBaptiste Daroussin     *yystack.s_mark = 0;
3530c8de5b0SBaptiste Daroussin 
3540c8de5b0SBaptiste Daroussin yyloop:
3550c8de5b0SBaptiste Daroussin     if ((yyn = yydefred[yystate]) != 0) goto yyreduce;
3560c8de5b0SBaptiste Daroussin     if (yychar < 0)
3570c8de5b0SBaptiste Daroussin     {
358*c5b5d71aSJung-uk Kim         yychar = YYLEX;
359*c5b5d71aSJung-uk Kim         if (yychar < 0) yychar = YYEOF;
3600c8de5b0SBaptiste Daroussin #if YYDEBUG
3610c8de5b0SBaptiste Daroussin         if (yydebug)
3620c8de5b0SBaptiste Daroussin         {
363*c5b5d71aSJung-uk Kim             if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
3640c8de5b0SBaptiste Daroussin             printf("%sdebug: state %d, reading %d (%s)\n",
3650c8de5b0SBaptiste Daroussin                     YYPREFIX, yystate, yychar, yys);
3660c8de5b0SBaptiste Daroussin         }
3670c8de5b0SBaptiste Daroussin #endif
3680c8de5b0SBaptiste Daroussin     }
369*c5b5d71aSJung-uk Kim     if (((yyn = yysindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
370*c5b5d71aSJung-uk Kim             yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
3710c8de5b0SBaptiste Daroussin     {
3720c8de5b0SBaptiste Daroussin #if YYDEBUG
3730c8de5b0SBaptiste Daroussin         if (yydebug)
3740c8de5b0SBaptiste Daroussin             printf("%sdebug: state %d, shifting to state %d\n",
3750c8de5b0SBaptiste Daroussin                     YYPREFIX, yystate, yytable[yyn]);
3760c8de5b0SBaptiste Daroussin #endif
377*c5b5d71aSJung-uk Kim         if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
3780c8de5b0SBaptiste Daroussin         yystate = yytable[yyn];
3790c8de5b0SBaptiste Daroussin         *++yystack.s_mark = yytable[yyn];
3800c8de5b0SBaptiste Daroussin         *++yystack.l_mark = yylval;
3810c8de5b0SBaptiste Daroussin         yychar = YYEMPTY;
3820c8de5b0SBaptiste Daroussin         if (yyerrflag > 0)  --yyerrflag;
3830c8de5b0SBaptiste Daroussin         goto yyloop;
3840c8de5b0SBaptiste Daroussin     }
385*c5b5d71aSJung-uk Kim     if (((yyn = yyrindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
386*c5b5d71aSJung-uk Kim             yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
3870c8de5b0SBaptiste Daroussin     {
3880c8de5b0SBaptiste Daroussin         yyn = yytable[yyn];
3890c8de5b0SBaptiste Daroussin         goto yyreduce;
3900c8de5b0SBaptiste Daroussin     }
391*c5b5d71aSJung-uk Kim     if (yyerrflag != 0) goto yyinrecovery;
3920c8de5b0SBaptiste Daroussin 
3930c8de5b0SBaptiste Daroussin     YYERROR_CALL("syntax error");
3940c8de5b0SBaptiste Daroussin 
395*c5b5d71aSJung-uk Kim     goto yyerrlab; /* redundant goto avoids 'unused label' warning */
3960c8de5b0SBaptiste Daroussin yyerrlab:
3970c8de5b0SBaptiste Daroussin     ++yynerrs;
3980c8de5b0SBaptiste Daroussin 
3990c8de5b0SBaptiste Daroussin yyinrecovery:
4000c8de5b0SBaptiste Daroussin     if (yyerrflag < 3)
4010c8de5b0SBaptiste Daroussin     {
4020c8de5b0SBaptiste Daroussin         yyerrflag = 3;
4030c8de5b0SBaptiste Daroussin         for (;;)
4040c8de5b0SBaptiste Daroussin         {
405*c5b5d71aSJung-uk Kim             if (((yyn = yysindex[*yystack.s_mark]) != 0) && (yyn += YYERRCODE) >= 0 &&
406*c5b5d71aSJung-uk Kim                     yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) YYERRCODE)
4070c8de5b0SBaptiste Daroussin             {
4080c8de5b0SBaptiste Daroussin #if YYDEBUG
4090c8de5b0SBaptiste Daroussin                 if (yydebug)
4100c8de5b0SBaptiste Daroussin                     printf("%sdebug: state %d, error recovery shifting\
4110c8de5b0SBaptiste Daroussin  to state %d\n", YYPREFIX, *yystack.s_mark, yytable[yyn]);
4120c8de5b0SBaptiste Daroussin #endif
413*c5b5d71aSJung-uk Kim                 if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
4140c8de5b0SBaptiste Daroussin                 yystate = yytable[yyn];
4150c8de5b0SBaptiste Daroussin                 *++yystack.s_mark = yytable[yyn];
4160c8de5b0SBaptiste Daroussin                 *++yystack.l_mark = yylval;
4170c8de5b0SBaptiste Daroussin                 goto yyloop;
4180c8de5b0SBaptiste Daroussin             }
4190c8de5b0SBaptiste Daroussin             else
4200c8de5b0SBaptiste Daroussin             {
4210c8de5b0SBaptiste Daroussin #if YYDEBUG
4220c8de5b0SBaptiste Daroussin                 if (yydebug)
4230c8de5b0SBaptiste Daroussin                     printf("%sdebug: error recovery discarding state %d\n",
4240c8de5b0SBaptiste Daroussin                             YYPREFIX, *yystack.s_mark);
4250c8de5b0SBaptiste Daroussin #endif
4260c8de5b0SBaptiste Daroussin                 if (yystack.s_mark <= yystack.s_base) goto yyabort;
4270c8de5b0SBaptiste Daroussin                 --yystack.s_mark;
4280c8de5b0SBaptiste Daroussin                 --yystack.l_mark;
4290c8de5b0SBaptiste Daroussin             }
4300c8de5b0SBaptiste Daroussin         }
4310c8de5b0SBaptiste Daroussin     }
4320c8de5b0SBaptiste Daroussin     else
4330c8de5b0SBaptiste Daroussin     {
4340c8de5b0SBaptiste Daroussin         if (yychar == YYEOF) goto yyabort;
4350c8de5b0SBaptiste Daroussin #if YYDEBUG
4360c8de5b0SBaptiste Daroussin         if (yydebug)
4370c8de5b0SBaptiste Daroussin         {
438*c5b5d71aSJung-uk Kim             if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
4390c8de5b0SBaptiste Daroussin             printf("%sdebug: state %d, error recovery discards token %d (%s)\n",
4400c8de5b0SBaptiste Daroussin                     YYPREFIX, yystate, yychar, yys);
4410c8de5b0SBaptiste Daroussin         }
4420c8de5b0SBaptiste Daroussin #endif
4430c8de5b0SBaptiste Daroussin         yychar = YYEMPTY;
4440c8de5b0SBaptiste Daroussin         goto yyloop;
4450c8de5b0SBaptiste Daroussin     }
4460c8de5b0SBaptiste Daroussin 
4470c8de5b0SBaptiste Daroussin yyreduce:
4480c8de5b0SBaptiste Daroussin #if YYDEBUG
4490c8de5b0SBaptiste Daroussin     if (yydebug)
4500c8de5b0SBaptiste Daroussin         printf("%sdebug: state %d, reducing by rule %d (%s)\n",
4510c8de5b0SBaptiste Daroussin                 YYPREFIX, yystate, yyn, yyrule[yyn]);
4520c8de5b0SBaptiste Daroussin #endif
4530c8de5b0SBaptiste Daroussin     yym = yylen[yyn];
454*c5b5d71aSJung-uk Kim     if (yym > 0)
4550c8de5b0SBaptiste Daroussin         yyval = yystack.l_mark[1-yym];
4560c8de5b0SBaptiste Daroussin     else
4570c8de5b0SBaptiste Daroussin         memset(&yyval, 0, sizeof yyval);
458*c5b5d71aSJung-uk Kim 
4590c8de5b0SBaptiste Daroussin     switch (yyn)
4600c8de5b0SBaptiste Daroussin     {
4610c8de5b0SBaptiste Daroussin case 3:
462*c5b5d71aSJung-uk Kim #line 32 "code_calc.y"
4630c8de5b0SBaptiste Daroussin 	{  yyerrok ; }
4640c8de5b0SBaptiste Daroussin break;
4650c8de5b0SBaptiste Daroussin case 4:
466*c5b5d71aSJung-uk Kim #line 36 "code_calc.y"
4670c8de5b0SBaptiste Daroussin 	{  printf("%d\n",yystack.l_mark[0]);}
4680c8de5b0SBaptiste Daroussin break;
4690c8de5b0SBaptiste Daroussin case 5:
470*c5b5d71aSJung-uk Kim #line 38 "code_calc.y"
4710c8de5b0SBaptiste Daroussin 	{  regs[yystack.l_mark[-2]] = yystack.l_mark[0]; }
4720c8de5b0SBaptiste Daroussin break;
4730c8de5b0SBaptiste Daroussin case 6:
474*c5b5d71aSJung-uk Kim #line 42 "code_calc.y"
4750c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[-1]; }
4760c8de5b0SBaptiste Daroussin break;
4770c8de5b0SBaptiste Daroussin case 7:
478*c5b5d71aSJung-uk Kim #line 44 "code_calc.y"
4790c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[-2] + yystack.l_mark[0]; }
4800c8de5b0SBaptiste Daroussin break;
4810c8de5b0SBaptiste Daroussin case 8:
482*c5b5d71aSJung-uk Kim #line 46 "code_calc.y"
4830c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[-2] - yystack.l_mark[0]; }
4840c8de5b0SBaptiste Daroussin break;
4850c8de5b0SBaptiste Daroussin case 9:
486*c5b5d71aSJung-uk Kim #line 48 "code_calc.y"
4870c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[-2] * yystack.l_mark[0]; }
4880c8de5b0SBaptiste Daroussin break;
4890c8de5b0SBaptiste Daroussin case 10:
490*c5b5d71aSJung-uk Kim #line 50 "code_calc.y"
4910c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[-2] / yystack.l_mark[0]; }
4920c8de5b0SBaptiste Daroussin break;
4930c8de5b0SBaptiste Daroussin case 11:
494*c5b5d71aSJung-uk Kim #line 52 "code_calc.y"
4950c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[-2] % yystack.l_mark[0]; }
4960c8de5b0SBaptiste Daroussin break;
4970c8de5b0SBaptiste Daroussin case 12:
498*c5b5d71aSJung-uk Kim #line 54 "code_calc.y"
4990c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[-2] & yystack.l_mark[0]; }
5000c8de5b0SBaptiste Daroussin break;
5010c8de5b0SBaptiste Daroussin case 13:
502*c5b5d71aSJung-uk Kim #line 56 "code_calc.y"
5030c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[-2] | yystack.l_mark[0]; }
5040c8de5b0SBaptiste Daroussin break;
5050c8de5b0SBaptiste Daroussin case 14:
506*c5b5d71aSJung-uk Kim #line 58 "code_calc.y"
5070c8de5b0SBaptiste Daroussin 	{  yyval = - yystack.l_mark[0]; }
5080c8de5b0SBaptiste Daroussin break;
5090c8de5b0SBaptiste Daroussin case 15:
510*c5b5d71aSJung-uk Kim #line 60 "code_calc.y"
5110c8de5b0SBaptiste Daroussin 	{  yyval = regs[yystack.l_mark[0]]; }
5120c8de5b0SBaptiste Daroussin break;
5130c8de5b0SBaptiste Daroussin case 17:
514*c5b5d71aSJung-uk Kim #line 65 "code_calc.y"
5150c8de5b0SBaptiste Daroussin 	{  yyval = yystack.l_mark[0]; base = (yystack.l_mark[0]==0) ? 8 : 10; }
5160c8de5b0SBaptiste Daroussin break;
5170c8de5b0SBaptiste Daroussin case 18:
518*c5b5d71aSJung-uk Kim #line 67 "code_calc.y"
5190c8de5b0SBaptiste Daroussin 	{  yyval = base * yystack.l_mark[-1] + yystack.l_mark[0]; }
5200c8de5b0SBaptiste Daroussin break;
521*c5b5d71aSJung-uk Kim #line 522 "code_calc.code.c"
5220c8de5b0SBaptiste Daroussin     }
5230c8de5b0SBaptiste Daroussin     yystack.s_mark -= yym;
5240c8de5b0SBaptiste Daroussin     yystate = *yystack.s_mark;
5250c8de5b0SBaptiste Daroussin     yystack.l_mark -= yym;
5260c8de5b0SBaptiste Daroussin     yym = yylhs[yyn];
5270c8de5b0SBaptiste Daroussin     if (yystate == 0 && yym == 0)
5280c8de5b0SBaptiste Daroussin     {
5290c8de5b0SBaptiste Daroussin #if YYDEBUG
5300c8de5b0SBaptiste Daroussin         if (yydebug)
5310c8de5b0SBaptiste Daroussin             printf("%sdebug: after reduction, shifting from state 0 to\
5320c8de5b0SBaptiste Daroussin  state %d\n", YYPREFIX, YYFINAL);
5330c8de5b0SBaptiste Daroussin #endif
5340c8de5b0SBaptiste Daroussin         yystate = YYFINAL;
5350c8de5b0SBaptiste Daroussin         *++yystack.s_mark = YYFINAL;
5360c8de5b0SBaptiste Daroussin         *++yystack.l_mark = yyval;
5370c8de5b0SBaptiste Daroussin         if (yychar < 0)
5380c8de5b0SBaptiste Daroussin         {
539*c5b5d71aSJung-uk Kim             yychar = YYLEX;
540*c5b5d71aSJung-uk Kim             if (yychar < 0) yychar = YYEOF;
5410c8de5b0SBaptiste Daroussin #if YYDEBUG
5420c8de5b0SBaptiste Daroussin             if (yydebug)
5430c8de5b0SBaptiste Daroussin             {
544*c5b5d71aSJung-uk Kim                 if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
5450c8de5b0SBaptiste Daroussin                 printf("%sdebug: state %d, reading %d (%s)\n",
5460c8de5b0SBaptiste Daroussin                         YYPREFIX, YYFINAL, yychar, yys);
5470c8de5b0SBaptiste Daroussin             }
5480c8de5b0SBaptiste Daroussin #endif
5490c8de5b0SBaptiste Daroussin         }
5500c8de5b0SBaptiste Daroussin         if (yychar == YYEOF) goto yyaccept;
5510c8de5b0SBaptiste Daroussin         goto yyloop;
5520c8de5b0SBaptiste Daroussin     }
553*c5b5d71aSJung-uk Kim     if (((yyn = yygindex[yym]) != 0) && (yyn += yystate) >= 0 &&
554*c5b5d71aSJung-uk Kim             yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yystate)
5550c8de5b0SBaptiste Daroussin         yystate = yytable[yyn];
5560c8de5b0SBaptiste Daroussin     else
5570c8de5b0SBaptiste Daroussin         yystate = yydgoto[yym];
5580c8de5b0SBaptiste Daroussin #if YYDEBUG
5590c8de5b0SBaptiste Daroussin     if (yydebug)
5600c8de5b0SBaptiste Daroussin         printf("%sdebug: after reduction, shifting from state %d \
5610c8de5b0SBaptiste Daroussin to state %d\n", YYPREFIX, *yystack.s_mark, yystate);
5620c8de5b0SBaptiste Daroussin #endif
563*c5b5d71aSJung-uk Kim     if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
5640c8de5b0SBaptiste Daroussin     *++yystack.s_mark = (YYINT) yystate;
5650c8de5b0SBaptiste Daroussin     *++yystack.l_mark = yyval;
5660c8de5b0SBaptiste Daroussin     goto yyloop;
5670c8de5b0SBaptiste Daroussin 
5680c8de5b0SBaptiste Daroussin yyoverflow:
5690c8de5b0SBaptiste Daroussin     YYERROR_CALL("yacc stack overflow");
5700c8de5b0SBaptiste Daroussin 
5710c8de5b0SBaptiste Daroussin yyabort:
5720c8de5b0SBaptiste Daroussin     yyfreestack(&yystack);
5730c8de5b0SBaptiste Daroussin     return (1);
5740c8de5b0SBaptiste Daroussin 
5750c8de5b0SBaptiste Daroussin yyaccept:
5760c8de5b0SBaptiste Daroussin     yyfreestack(&yystack);
5770c8de5b0SBaptiste Daroussin     return (0);
5780c8de5b0SBaptiste Daroussin }
579