xref: /freebsd/contrib/byacc/test/yacc/defines1.calc.c (revision b53bb29fed3e69c2561e93c1aee32b92ffe9117f)
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