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