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 #undef YYBTYACC
17b53bb29fSJung-uk Kim #define YYBTYACC 0
18b53bb29fSJung-uk Kim #define YYDEBUGSTR YYPREFIX "debug"
19b53bb29fSJung-uk Kim #define YYPREFIX "yy"
20b53bb29fSJung-uk Kim
21b53bb29fSJung-uk Kim #define YYPURE 0
22b53bb29fSJung-uk Kim
23b53bb29fSJung-uk Kim #line 2 "calc.y"
24b53bb29fSJung-uk Kim # include <stdio.h>
25b53bb29fSJung-uk Kim # include <ctype.h>
26b53bb29fSJung-uk Kim
27b53bb29fSJung-uk Kim int regs[26];
28b53bb29fSJung-uk Kim int base;
29b53bb29fSJung-uk Kim
30b53bb29fSJung-uk Kim extern int yylex(void);
31b53bb29fSJung-uk Kim static void yyerror(const char *s);
32b53bb29fSJung-uk Kim
33b53bb29fSJung-uk Kim #line 34 "stdin2.calc.c"
34b53bb29fSJung-uk Kim
35b53bb29fSJung-uk Kim #if ! defined(YYSTYPE) && ! defined(YYSTYPE_IS_DECLARED)
36b53bb29fSJung-uk Kim /* Default: YYSTYPE is the semantic value type. */
37b53bb29fSJung-uk Kim typedef int YYSTYPE;
38b53bb29fSJung-uk Kim # define YYSTYPE_IS_DECLARED 1
39b53bb29fSJung-uk Kim #endif
40b53bb29fSJung-uk Kim
41b53bb29fSJung-uk Kim /* compatibility with bison */
42b53bb29fSJung-uk Kim #ifdef YYPARSE_PARAM
43b53bb29fSJung-uk Kim /* compatibility with FreeBSD */
44b53bb29fSJung-uk Kim # ifdef YYPARSE_PARAM_TYPE
45b53bb29fSJung-uk Kim # define YYPARSE_DECL() yyparse(YYPARSE_PARAM_TYPE YYPARSE_PARAM)
46b53bb29fSJung-uk Kim # else
47b53bb29fSJung-uk Kim # define YYPARSE_DECL() yyparse(void *YYPARSE_PARAM)
48b53bb29fSJung-uk Kim # endif
49b53bb29fSJung-uk Kim #else
50b53bb29fSJung-uk Kim # define YYPARSE_DECL() yyparse(void)
51b53bb29fSJung-uk Kim #endif
52b53bb29fSJung-uk Kim
53b53bb29fSJung-uk Kim /* Parameters sent to lex. */
54b53bb29fSJung-uk Kim #ifdef YYLEX_PARAM
55b53bb29fSJung-uk Kim # define YYLEX_DECL() yylex(void *YYLEX_PARAM)
56b53bb29fSJung-uk Kim # define YYLEX yylex(YYLEX_PARAM)
57b53bb29fSJung-uk Kim #else
58b53bb29fSJung-uk Kim # define YYLEX_DECL() yylex(void)
59b53bb29fSJung-uk Kim # define YYLEX yylex()
60b53bb29fSJung-uk Kim #endif
61b53bb29fSJung-uk Kim
62b53bb29fSJung-uk Kim #if !(defined(yylex) || defined(YYSTATE))
63b53bb29fSJung-uk Kim int YYLEX_DECL();
64b53bb29fSJung-uk Kim #endif
65b53bb29fSJung-uk Kim
66b53bb29fSJung-uk Kim /* Parameters sent to yyerror. */
67b53bb29fSJung-uk Kim #ifndef YYERROR_DECL
68b53bb29fSJung-uk Kim #define YYERROR_DECL() yyerror(const char *s)
69b53bb29fSJung-uk Kim #endif
70b53bb29fSJung-uk Kim #ifndef YYERROR_CALL
71b53bb29fSJung-uk Kim #define YYERROR_CALL(msg) yyerror(msg)
72b53bb29fSJung-uk Kim #endif
73b53bb29fSJung-uk Kim
74b53bb29fSJung-uk Kim extern int YYPARSE_DECL();
75b53bb29fSJung-uk Kim
76b53bb29fSJung-uk Kim #define DIGIT 257
77b53bb29fSJung-uk Kim #define LETTER 258
78b53bb29fSJung-uk Kim #define UMINUS 259
79b53bb29fSJung-uk Kim #define YYERRCODE 256
80b53bb29fSJung-uk Kim typedef int YYINT;
81b53bb29fSJung-uk Kim static const YYINT yylhs[] = { -1,
82b53bb29fSJung-uk Kim 0, 0, 0, 1, 1, 2, 2, 2, 2, 2,
83b53bb29fSJung-uk Kim 2, 2, 2, 2, 2, 2, 3, 3,
84b53bb29fSJung-uk Kim };
85b53bb29fSJung-uk Kim static const YYINT yylen[] = { 2,
86b53bb29fSJung-uk Kim 0, 3, 3, 1, 3, 3, 3, 3, 3, 3,
87b53bb29fSJung-uk Kim 3, 3, 3, 2, 1, 1, 1, 2,
88b53bb29fSJung-uk Kim };
89b53bb29fSJung-uk Kim static const YYINT yydefred[] = { 1,
90b53bb29fSJung-uk Kim 0, 0, 17, 0, 0, 0, 0, 0, 0, 3,
91b53bb29fSJung-uk Kim 0, 15, 14, 0, 2, 0, 0, 0, 0, 0,
92b53bb29fSJung-uk Kim 0, 0, 18, 0, 6, 0, 0, 0, 0, 9,
93b53bb29fSJung-uk Kim 10, 11,
94b53bb29fSJung-uk Kim };
95b53bb29fSJung-uk Kim #if defined(YYDESTRUCT_CALL) || defined(YYSTYPE_TOSTRING)
96b53bb29fSJung-uk Kim static const YYINT yystos[] = { 0,
97b53bb29fSJung-uk Kim 261, 256, 257, 258, 45, 40, 262, 263, 264, 10,
98b53bb29fSJung-uk Kim 61, 258, 263, 263, 10, 124, 38, 43, 45, 42,
99b53bb29fSJung-uk Kim 47, 37, 257, 263, 41, 263, 263, 263, 263, 263,
100b53bb29fSJung-uk Kim 263, 263,
101b53bb29fSJung-uk Kim };
102b53bb29fSJung-uk Kim #endif /* YYDESTRUCT_CALL || YYSTYPE_TOSTRING */
103b53bb29fSJung-uk Kim static const YYINT yydgoto[] = { 1,
104b53bb29fSJung-uk Kim 7, 8, 9,
105b53bb29fSJung-uk Kim };
106b53bb29fSJung-uk Kim static const YYINT yysindex[] = { 0,
107b53bb29fSJung-uk Kim -40, -7, 0, -55, -38, -38, 1, -29, -247, 0,
108b53bb29fSJung-uk Kim -38, 0, 0, 22, 0, -38, -38, -38, -38, -38,
109b53bb29fSJung-uk Kim -38, -38, 0, -29, 0, 51, 60, -20, -20, 0,
110b53bb29fSJung-uk Kim 0, 0,
111b53bb29fSJung-uk Kim };
112b53bb29fSJung-uk Kim static const YYINT yyrindex[] = { 0,
113b53bb29fSJung-uk Kim 0, 0, 0, 2, 0, 0, 0, 9, -9, 0,
114b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
115b53bb29fSJung-uk Kim 0, 0, 0, 10, 0, -6, 14, 5, 13, 0,
116b53bb29fSJung-uk Kim 0, 0,
117b53bb29fSJung-uk Kim };
118b53bb29fSJung-uk Kim #if YYBTYACC
119b53bb29fSJung-uk Kim static const YYINT yycindex[] = { 0,
120b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
121b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
122b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
123b53bb29fSJung-uk Kim 0, 0,
124b53bb29fSJung-uk Kim };
125b53bb29fSJung-uk Kim #endif
126b53bb29fSJung-uk Kim static const YYINT yygindex[] = { 0,
127b53bb29fSJung-uk Kim 0, 65, 0,
128b53bb29fSJung-uk Kim };
129b53bb29fSJung-uk Kim #define YYTABLESIZE 220
130b53bb29fSJung-uk Kim static const YYINT yytable[] = { 6,
131b53bb29fSJung-uk Kim 16, 6, 10, 13, 5, 11, 5, 22, 17, 23,
132b53bb29fSJung-uk Kim 15, 15, 20, 18, 7, 19, 22, 21, 4, 5,
133b53bb29fSJung-uk Kim 0, 20, 8, 12, 0, 0, 21, 16, 16, 0,
134b53bb29fSJung-uk Kim 0, 16, 16, 16, 13, 16, 0, 16, 15, 15,
135b53bb29fSJung-uk Kim 0, 0, 7, 15, 15, 7, 15, 7, 15, 7,
136b53bb29fSJung-uk Kim 8, 12, 0, 8, 12, 8, 0, 8, 22, 17,
137b53bb29fSJung-uk Kim 0, 0, 25, 20, 18, 0, 19, 0, 21, 13,
138b53bb29fSJung-uk Kim 14, 0, 0, 0, 0, 24, 0, 0, 0, 0,
139b53bb29fSJung-uk Kim 26, 27, 28, 29, 30, 31, 32, 22, 17, 0,
140b53bb29fSJung-uk Kim 0, 0, 20, 18, 16, 19, 22, 21, 0, 0,
141b53bb29fSJung-uk Kim 0, 20, 18, 0, 19, 0, 21, 0, 0, 0,
142b53bb29fSJung-uk Kim 0, 0, 0, 0, 16, 0, 0, 13, 0, 0,
143b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 15, 0, 0, 7, 0,
144b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 8, 12, 0, 0,
145b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 16, 0, 0, 0, 0,
146b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
147b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
148b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
149b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
150b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
151b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
152b53bb29fSJung-uk Kim 0, 0, 0, 0, 0, 2, 3, 4, 3, 12,
153b53bb29fSJung-uk Kim };
154b53bb29fSJung-uk Kim static const YYINT yycheck[] = { 40,
155b53bb29fSJung-uk Kim 10, 40, 10, 10, 45, 61, 45, 37, 38, 257,
156b53bb29fSJung-uk Kim 10, 10, 42, 43, 10, 45, 37, 47, 10, 10,
157b53bb29fSJung-uk Kim -1, 42, 10, 10, -1, -1, 47, 37, 38, -1,
158b53bb29fSJung-uk Kim -1, 41, 42, 43, 41, 45, -1, 47, 37, 38,
159b53bb29fSJung-uk Kim -1, -1, 38, 42, 43, 41, 45, 43, 47, 45,
160b53bb29fSJung-uk Kim 38, 38, -1, 41, 41, 43, -1, 45, 37, 38,
161b53bb29fSJung-uk Kim -1, -1, 41, 42, 43, -1, 45, -1, 47, 5,
162b53bb29fSJung-uk Kim 6, -1, -1, -1, -1, 11, -1, -1, -1, -1,
163b53bb29fSJung-uk Kim 16, 17, 18, 19, 20, 21, 22, 37, 38, -1,
164b53bb29fSJung-uk Kim -1, -1, 42, 43, 124, 45, 37, 47, -1, -1,
165b53bb29fSJung-uk Kim -1, 42, 43, -1, 45, -1, 47, -1, -1, -1,
166b53bb29fSJung-uk Kim -1, -1, -1, -1, 124, -1, -1, 124, -1, -1,
167b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, 124, -1, -1, 124, -1,
168b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, 124, 124, -1, -1,
169b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, 124, -1, -1, -1, -1,
170b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
171b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
172b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
173b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
174b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
175b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
176b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, 256, 257, 258, 257, 258,
177b53bb29fSJung-uk Kim };
178b53bb29fSJung-uk Kim #if YYBTYACC
179b53bb29fSJung-uk Kim static const YYINT yyctable[] = { -1,
180b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
181b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
182b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
183b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
184b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
185b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
186b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
187b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
188b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
189b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
190b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
191b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
192b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
193b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
194b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
195b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
196b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
197b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
198b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
199b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
200b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
201b53bb29fSJung-uk Kim -1, -1, -1, -1, -1, -1, -1, -1, -1,
202b53bb29fSJung-uk Kim };
203b53bb29fSJung-uk Kim #endif
204b53bb29fSJung-uk Kim #define YYFINAL 1
205b53bb29fSJung-uk Kim #ifndef YYDEBUG
206b53bb29fSJung-uk Kim #define YYDEBUG 0
207b53bb29fSJung-uk Kim #endif
208b53bb29fSJung-uk Kim #define YYMAXTOKEN 259
209b53bb29fSJung-uk Kim #define YYUNDFTOKEN 265
210b53bb29fSJung-uk Kim #define YYTRANSLATE(a) ((a) > YYMAXTOKEN ? YYUNDFTOKEN : (a))
211b53bb29fSJung-uk Kim #if YYDEBUG
212b53bb29fSJung-uk Kim static const char *const yyname[] = {
213b53bb29fSJung-uk Kim
214b53bb29fSJung-uk Kim "$end",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,0,0,0,
215b53bb29fSJung-uk Kim 0,0,0,"'%'","'&'",0,"'('","')'","'*'","'+'",0,"'-'",0,"'/'",0,0,0,0,0,0,0,0,0,0,
216b53bb29fSJung-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,
217b53bb29fSJung-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,
218b53bb29fSJung-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,
219b53bb29fSJung-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,
220b53bb29fSJung-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,
221b53bb29fSJung-uk Kim 0,0,"error","DIGIT","LETTER","UMINUS","$accept","list","stat","expr","number",
222b53bb29fSJung-uk Kim "illegal-symbol",
223b53bb29fSJung-uk Kim };
224b53bb29fSJung-uk Kim static const char *const yyrule[] = {
225b53bb29fSJung-uk Kim "$accept : list",
226b53bb29fSJung-uk Kim "list :",
227b53bb29fSJung-uk Kim "list : list stat '\\n'",
228b53bb29fSJung-uk Kim "list : list error '\\n'",
229b53bb29fSJung-uk Kim "stat : expr",
230b53bb29fSJung-uk Kim "stat : LETTER '=' expr",
231b53bb29fSJung-uk Kim "expr : '(' expr ')'",
232b53bb29fSJung-uk Kim "expr : expr '+' expr",
233b53bb29fSJung-uk Kim "expr : expr '-' expr",
234b53bb29fSJung-uk Kim "expr : expr '*' expr",
235b53bb29fSJung-uk Kim "expr : expr '/' expr",
236b53bb29fSJung-uk Kim "expr : expr '%' expr",
237b53bb29fSJung-uk Kim "expr : expr '&' expr",
238b53bb29fSJung-uk Kim "expr : expr '|' expr",
239b53bb29fSJung-uk Kim "expr : '-' expr",
240b53bb29fSJung-uk Kim "expr : LETTER",
241b53bb29fSJung-uk Kim "expr : number",
242b53bb29fSJung-uk Kim "number : DIGIT",
243b53bb29fSJung-uk Kim "number : number DIGIT",
244b53bb29fSJung-uk Kim
245b53bb29fSJung-uk Kim };
246b53bb29fSJung-uk Kim #endif
247b53bb29fSJung-uk Kim
248b53bb29fSJung-uk Kim #if YYDEBUG
249b53bb29fSJung-uk Kim int yydebug;
250b53bb29fSJung-uk Kim #endif
251b53bb29fSJung-uk Kim
252b53bb29fSJung-uk Kim int yyerrflag;
253b53bb29fSJung-uk Kim int yychar;
254b53bb29fSJung-uk Kim YYSTYPE yyval;
255b53bb29fSJung-uk Kim YYSTYPE yylval;
256b53bb29fSJung-uk Kim int yynerrs;
257b53bb29fSJung-uk Kim
258b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
259b53bb29fSJung-uk Kim YYLTYPE yyloc; /* position returned by actions */
260b53bb29fSJung-uk Kim YYLTYPE yylloc; /* position from the lexer */
261b53bb29fSJung-uk Kim #endif
262b53bb29fSJung-uk Kim
263b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
264b53bb29fSJung-uk Kim #ifndef YYLLOC_DEFAULT
265b53bb29fSJung-uk Kim #define YYLLOC_DEFAULT(loc, rhs, n) \
266b53bb29fSJung-uk Kim do \
267b53bb29fSJung-uk Kim { \
268b53bb29fSJung-uk Kim if (n == 0) \
269b53bb29fSJung-uk Kim { \
270b53bb29fSJung-uk Kim (loc).first_line = YYRHSLOC(rhs, 0).last_line; \
271b53bb29fSJung-uk Kim (loc).first_column = YYRHSLOC(rhs, 0).last_column; \
272b53bb29fSJung-uk Kim (loc).last_line = YYRHSLOC(rhs, 0).last_line; \
273b53bb29fSJung-uk Kim (loc).last_column = YYRHSLOC(rhs, 0).last_column; \
274b53bb29fSJung-uk Kim } \
275b53bb29fSJung-uk Kim else \
276b53bb29fSJung-uk Kim { \
277b53bb29fSJung-uk Kim (loc).first_line = YYRHSLOC(rhs, 1).first_line; \
278b53bb29fSJung-uk Kim (loc).first_column = YYRHSLOC(rhs, 1).first_column; \
279b53bb29fSJung-uk Kim (loc).last_line = YYRHSLOC(rhs, n).last_line; \
280b53bb29fSJung-uk Kim (loc).last_column = YYRHSLOC(rhs, n).last_column; \
281b53bb29fSJung-uk Kim } \
282b53bb29fSJung-uk Kim } while (0)
283b53bb29fSJung-uk Kim #endif /* YYLLOC_DEFAULT */
284b53bb29fSJung-uk Kim #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
285b53bb29fSJung-uk Kim #if YYBTYACC
286b53bb29fSJung-uk Kim
287b53bb29fSJung-uk Kim #ifndef YYLVQUEUEGROWTH
288b53bb29fSJung-uk Kim #define YYLVQUEUEGROWTH 32
289b53bb29fSJung-uk Kim #endif
290b53bb29fSJung-uk Kim #endif /* YYBTYACC */
291b53bb29fSJung-uk Kim
292b53bb29fSJung-uk Kim /* define the initial stack-sizes */
293b53bb29fSJung-uk Kim #ifdef YYSTACKSIZE
294b53bb29fSJung-uk Kim #undef YYMAXDEPTH
295b53bb29fSJung-uk Kim #define YYMAXDEPTH YYSTACKSIZE
296b53bb29fSJung-uk Kim #else
297b53bb29fSJung-uk Kim #ifdef YYMAXDEPTH
298b53bb29fSJung-uk Kim #define YYSTACKSIZE YYMAXDEPTH
299b53bb29fSJung-uk Kim #else
300b53bb29fSJung-uk Kim #define YYSTACKSIZE 10000
301b53bb29fSJung-uk Kim #define YYMAXDEPTH 10000
302b53bb29fSJung-uk Kim #endif
303b53bb29fSJung-uk Kim #endif
304b53bb29fSJung-uk Kim
305b53bb29fSJung-uk Kim #ifndef YYINITSTACKSIZE
306b53bb29fSJung-uk Kim #define YYINITSTACKSIZE 200
307b53bb29fSJung-uk Kim #endif
308b53bb29fSJung-uk Kim
309b53bb29fSJung-uk Kim typedef struct {
310b53bb29fSJung-uk Kim unsigned stacksize;
311b53bb29fSJung-uk Kim YYINT *s_base;
312b53bb29fSJung-uk Kim YYINT *s_mark;
313b53bb29fSJung-uk Kim YYINT *s_last;
314b53bb29fSJung-uk Kim YYSTYPE *l_base;
315b53bb29fSJung-uk Kim YYSTYPE *l_mark;
316b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
317b53bb29fSJung-uk Kim YYLTYPE *p_base;
318b53bb29fSJung-uk Kim YYLTYPE *p_mark;
319b53bb29fSJung-uk Kim #endif
320b53bb29fSJung-uk Kim } YYSTACKDATA;
321b53bb29fSJung-uk Kim #if YYBTYACC
322b53bb29fSJung-uk Kim
323b53bb29fSJung-uk Kim struct YYParseState_s
324b53bb29fSJung-uk Kim {
325b53bb29fSJung-uk Kim struct YYParseState_s *save; /* Previously saved parser state */
326b53bb29fSJung-uk Kim YYSTACKDATA yystack; /* saved parser stack */
327b53bb29fSJung-uk Kim int state; /* saved parser state */
328b53bb29fSJung-uk Kim int errflag; /* saved error recovery status */
329b53bb29fSJung-uk Kim int lexeme; /* saved index of the conflict lexeme in the lexical queue */
330b53bb29fSJung-uk Kim YYINT ctry; /* saved index in yyctable[] for this conflict */
331b53bb29fSJung-uk Kim };
332b53bb29fSJung-uk Kim typedef struct YYParseState_s YYParseState;
333b53bb29fSJung-uk Kim #endif /* YYBTYACC */
334b53bb29fSJung-uk Kim /* variables for the parser stack */
335b53bb29fSJung-uk Kim static YYSTACKDATA yystack;
336b53bb29fSJung-uk Kim #if YYBTYACC
337b53bb29fSJung-uk Kim
338b53bb29fSJung-uk Kim /* Current parser state */
339b53bb29fSJung-uk Kim static YYParseState *yyps = 0;
340b53bb29fSJung-uk Kim
341b53bb29fSJung-uk Kim /* yypath != NULL: do the full parse, starting at *yypath parser state. */
342b53bb29fSJung-uk Kim static YYParseState *yypath = 0;
343b53bb29fSJung-uk Kim
344b53bb29fSJung-uk Kim /* Base of the lexical value queue */
345b53bb29fSJung-uk Kim static YYSTYPE *yylvals = 0;
346b53bb29fSJung-uk Kim
347b53bb29fSJung-uk Kim /* Current position at lexical value queue */
348b53bb29fSJung-uk Kim static YYSTYPE *yylvp = 0;
349b53bb29fSJung-uk Kim
350b53bb29fSJung-uk Kim /* End position of lexical value queue */
351b53bb29fSJung-uk Kim static YYSTYPE *yylve = 0;
352b53bb29fSJung-uk Kim
353b53bb29fSJung-uk Kim /* The last allocated position at the lexical value queue */
354b53bb29fSJung-uk Kim static YYSTYPE *yylvlim = 0;
355b53bb29fSJung-uk Kim
356b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
357b53bb29fSJung-uk Kim /* Base of the lexical position queue */
358b53bb29fSJung-uk Kim static YYLTYPE *yylpsns = 0;
359b53bb29fSJung-uk Kim
360b53bb29fSJung-uk Kim /* Current position at lexical position queue */
361b53bb29fSJung-uk Kim static YYLTYPE *yylpp = 0;
362b53bb29fSJung-uk Kim
363b53bb29fSJung-uk Kim /* End position of lexical position queue */
364b53bb29fSJung-uk Kim static YYLTYPE *yylpe = 0;
365b53bb29fSJung-uk Kim
366b53bb29fSJung-uk Kim /* The last allocated position at the lexical position queue */
367b53bb29fSJung-uk Kim static YYLTYPE *yylplim = 0;
368b53bb29fSJung-uk Kim #endif
369b53bb29fSJung-uk Kim
370b53bb29fSJung-uk Kim /* Current position at lexical token queue */
371b53bb29fSJung-uk Kim static YYINT *yylexp = 0;
372b53bb29fSJung-uk Kim
373b53bb29fSJung-uk Kim static YYINT *yylexemes = 0;
374b53bb29fSJung-uk Kim #endif /* YYBTYACC */
375b53bb29fSJung-uk Kim #line 66 "calc.y"
376b53bb29fSJung-uk Kim /* start of programs */
377b53bb29fSJung-uk Kim
378b53bb29fSJung-uk Kim int
main(void)379b53bb29fSJung-uk Kim main (void)
380b53bb29fSJung-uk Kim {
381b53bb29fSJung-uk Kim while(!feof(stdin)) {
382b53bb29fSJung-uk Kim yyparse();
383b53bb29fSJung-uk Kim }
384b53bb29fSJung-uk Kim return 0;
385b53bb29fSJung-uk Kim }
386b53bb29fSJung-uk Kim
387b53bb29fSJung-uk Kim static void
yyerror(const char * s)388b53bb29fSJung-uk Kim yyerror(const char *s)
389b53bb29fSJung-uk Kim {
390b53bb29fSJung-uk Kim fprintf(stderr, "%s\n", s);
391b53bb29fSJung-uk Kim }
392b53bb29fSJung-uk Kim
393b53bb29fSJung-uk Kim int
yylex(void)394b53bb29fSJung-uk Kim yylex(void)
395b53bb29fSJung-uk Kim {
396b53bb29fSJung-uk Kim /* lexical analysis routine */
397b53bb29fSJung-uk Kim /* returns LETTER for a lower case letter, yylval = 0 through 25 */
398b53bb29fSJung-uk Kim /* return DIGIT for a digit, yylval = 0 through 9 */
399b53bb29fSJung-uk Kim /* all other characters are returned immediately */
400b53bb29fSJung-uk Kim
401b53bb29fSJung-uk Kim int c;
402b53bb29fSJung-uk Kim
403b53bb29fSJung-uk Kim while( (c=getchar()) == ' ' ) { /* skip blanks */ }
404b53bb29fSJung-uk Kim
405b53bb29fSJung-uk Kim /* c is now nonblank */
406b53bb29fSJung-uk Kim
407b53bb29fSJung-uk Kim if( islower( c )) {
408b53bb29fSJung-uk Kim yylval = c - 'a';
409b53bb29fSJung-uk Kim return ( LETTER );
410b53bb29fSJung-uk Kim }
411b53bb29fSJung-uk Kim if( isdigit( c )) {
412b53bb29fSJung-uk Kim yylval = c - '0';
413b53bb29fSJung-uk Kim return ( DIGIT );
414b53bb29fSJung-uk Kim }
415b53bb29fSJung-uk Kim return( c );
416b53bb29fSJung-uk Kim }
417b53bb29fSJung-uk Kim #line 418 "stdin2.calc.c"
418b53bb29fSJung-uk Kim
419b53bb29fSJung-uk Kim /* For use in generated program */
420b53bb29fSJung-uk Kim #define yydepth (int)(yystack.s_mark - yystack.s_base)
421b53bb29fSJung-uk Kim #if YYBTYACC
422b53bb29fSJung-uk Kim #define yytrial (yyps->save)
423b53bb29fSJung-uk Kim #endif /* YYBTYACC */
424b53bb29fSJung-uk Kim
425b53bb29fSJung-uk Kim #if YYDEBUG
426b53bb29fSJung-uk Kim #include <stdio.h> /* needed for printf */
427b53bb29fSJung-uk Kim #endif
428b53bb29fSJung-uk Kim
429b53bb29fSJung-uk Kim #include <stdlib.h> /* needed for malloc, etc */
430b53bb29fSJung-uk Kim #include <string.h> /* needed for memset */
431b53bb29fSJung-uk Kim
432b53bb29fSJung-uk Kim /* allocate initial stack or double stack size, up to YYMAXDEPTH */
yygrowstack(YYSTACKDATA * data)433b53bb29fSJung-uk Kim static int yygrowstack(YYSTACKDATA *data)
434b53bb29fSJung-uk Kim {
435b53bb29fSJung-uk Kim int i;
436b53bb29fSJung-uk Kim unsigned newsize;
437b53bb29fSJung-uk Kim YYINT *newss;
438b53bb29fSJung-uk Kim YYSTYPE *newvs;
439b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
440b53bb29fSJung-uk Kim YYLTYPE *newps;
441b53bb29fSJung-uk Kim #endif
442b53bb29fSJung-uk Kim
443b53bb29fSJung-uk Kim if ((newsize = data->stacksize) == 0)
444b53bb29fSJung-uk Kim newsize = YYINITSTACKSIZE;
445b53bb29fSJung-uk Kim else if (newsize >= YYMAXDEPTH)
446b53bb29fSJung-uk Kim return YYENOMEM;
447b53bb29fSJung-uk Kim else if ((newsize *= 2) > YYMAXDEPTH)
448b53bb29fSJung-uk Kim newsize = YYMAXDEPTH;
449b53bb29fSJung-uk Kim
450b53bb29fSJung-uk Kim i = (int) (data->s_mark - data->s_base);
451b53bb29fSJung-uk Kim newss = (YYINT *)realloc(data->s_base, newsize * sizeof(*newss));
452bf80e08eSJung-uk Kim if (newss == NULL)
453b53bb29fSJung-uk Kim return YYENOMEM;
454b53bb29fSJung-uk Kim
455b53bb29fSJung-uk Kim data->s_base = newss;
456b53bb29fSJung-uk Kim data->s_mark = newss + i;
457b53bb29fSJung-uk Kim
458b53bb29fSJung-uk Kim newvs = (YYSTYPE *)realloc(data->l_base, newsize * sizeof(*newvs));
459bf80e08eSJung-uk Kim if (newvs == NULL)
460b53bb29fSJung-uk Kim return YYENOMEM;
461b53bb29fSJung-uk Kim
462b53bb29fSJung-uk Kim data->l_base = newvs;
463b53bb29fSJung-uk Kim data->l_mark = newvs + i;
464b53bb29fSJung-uk Kim
465b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
466b53bb29fSJung-uk Kim newps = (YYLTYPE *)realloc(data->p_base, newsize * sizeof(*newps));
467bf80e08eSJung-uk Kim if (newps == NULL)
468b53bb29fSJung-uk Kim return YYENOMEM;
469b53bb29fSJung-uk Kim
470b53bb29fSJung-uk Kim data->p_base = newps;
471b53bb29fSJung-uk Kim data->p_mark = newps + i;
472b53bb29fSJung-uk Kim #endif
473b53bb29fSJung-uk Kim
474b53bb29fSJung-uk Kim data->stacksize = newsize;
475b53bb29fSJung-uk Kim data->s_last = data->s_base + newsize - 1;
476b53bb29fSJung-uk Kim
477b53bb29fSJung-uk Kim #if YYDEBUG
478b53bb29fSJung-uk Kim if (yydebug)
479b53bb29fSJung-uk Kim fprintf(stderr, "%sdebug: stack size increased to %d\n", YYPREFIX, newsize);
480b53bb29fSJung-uk Kim #endif
481b53bb29fSJung-uk Kim return 0;
482b53bb29fSJung-uk Kim }
483b53bb29fSJung-uk Kim
484b53bb29fSJung-uk Kim #if YYPURE || defined(YY_NO_LEAKS)
yyfreestack(YYSTACKDATA * data)485b53bb29fSJung-uk Kim static void yyfreestack(YYSTACKDATA *data)
486b53bb29fSJung-uk Kim {
487b53bb29fSJung-uk Kim free(data->s_base);
488b53bb29fSJung-uk Kim free(data->l_base);
489b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
490b53bb29fSJung-uk Kim free(data->p_base);
491b53bb29fSJung-uk Kim #endif
492b53bb29fSJung-uk Kim memset(data, 0, sizeof(*data));
493b53bb29fSJung-uk Kim }
494b53bb29fSJung-uk Kim #else
495b53bb29fSJung-uk Kim #define yyfreestack(data) /* nothing */
496b53bb29fSJung-uk Kim #endif /* YYPURE || defined(YY_NO_LEAKS) */
497b53bb29fSJung-uk Kim #if YYBTYACC
498b53bb29fSJung-uk Kim
499b53bb29fSJung-uk Kim static YYParseState *
yyNewState(unsigned size)500b53bb29fSJung-uk Kim yyNewState(unsigned size)
501b53bb29fSJung-uk Kim {
502b53bb29fSJung-uk Kim YYParseState *p = (YYParseState *) malloc(sizeof(YYParseState));
503b53bb29fSJung-uk Kim if (p == NULL) return NULL;
504b53bb29fSJung-uk Kim
505b53bb29fSJung-uk Kim p->yystack.stacksize = size;
506b53bb29fSJung-uk Kim if (size == 0)
507b53bb29fSJung-uk Kim {
508b53bb29fSJung-uk Kim p->yystack.s_base = NULL;
509b53bb29fSJung-uk Kim p->yystack.l_base = NULL;
510b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
511b53bb29fSJung-uk Kim p->yystack.p_base = NULL;
512b53bb29fSJung-uk Kim #endif
513b53bb29fSJung-uk Kim return p;
514b53bb29fSJung-uk Kim }
515b53bb29fSJung-uk Kim p->yystack.s_base = (YYINT *) malloc(size * sizeof(YYINT));
516b53bb29fSJung-uk Kim if (p->yystack.s_base == NULL) return NULL;
517b53bb29fSJung-uk Kim p->yystack.l_base = (YYSTYPE *) malloc(size * sizeof(YYSTYPE));
518b53bb29fSJung-uk Kim if (p->yystack.l_base == NULL) return NULL;
519b53bb29fSJung-uk Kim memset(p->yystack.l_base, 0, size * sizeof(YYSTYPE));
520b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
521b53bb29fSJung-uk Kim p->yystack.p_base = (YYLTYPE *) malloc(size * sizeof(YYLTYPE));
522b53bb29fSJung-uk Kim if (p->yystack.p_base == NULL) return NULL;
523b53bb29fSJung-uk Kim memset(p->yystack.p_base, 0, size * sizeof(YYLTYPE));
524b53bb29fSJung-uk Kim #endif
525b53bb29fSJung-uk Kim
526b53bb29fSJung-uk Kim return p;
527b53bb29fSJung-uk Kim }
528b53bb29fSJung-uk Kim
529b53bb29fSJung-uk Kim static void
yyFreeState(YYParseState * p)530b53bb29fSJung-uk Kim yyFreeState(YYParseState *p)
531b53bb29fSJung-uk Kim {
532b53bb29fSJung-uk Kim yyfreestack(&p->yystack);
533b53bb29fSJung-uk Kim free(p);
534b53bb29fSJung-uk Kim }
535b53bb29fSJung-uk Kim #endif /* YYBTYACC */
536b53bb29fSJung-uk Kim
537b53bb29fSJung-uk Kim #define YYABORT goto yyabort
538b53bb29fSJung-uk Kim #define YYREJECT goto yyabort
539b53bb29fSJung-uk Kim #define YYACCEPT goto yyaccept
540b53bb29fSJung-uk Kim #define YYERROR goto yyerrlab
541b53bb29fSJung-uk Kim #if YYBTYACC
542b53bb29fSJung-uk Kim #define YYVALID do { if (yyps->save) goto yyvalid; } while(0)
543b53bb29fSJung-uk Kim #define YYVALID_NESTED do { if (yyps->save && \
544b53bb29fSJung-uk Kim yyps->save->save == 0) goto yyvalid; } while(0)
545b53bb29fSJung-uk Kim #endif /* YYBTYACC */
546b53bb29fSJung-uk Kim
547b53bb29fSJung-uk Kim int
YYPARSE_DECL()548b53bb29fSJung-uk Kim YYPARSE_DECL()
549b53bb29fSJung-uk Kim {
550b53bb29fSJung-uk Kim int yym, yyn, yystate, yyresult;
551b53bb29fSJung-uk Kim #if YYBTYACC
552b53bb29fSJung-uk Kim int yynewerrflag;
553b53bb29fSJung-uk Kim YYParseState *yyerrctx = NULL;
554b53bb29fSJung-uk Kim #endif /* YYBTYACC */
555b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
556b53bb29fSJung-uk Kim YYLTYPE yyerror_loc_range[3]; /* position of error start/end (0 unused) */
557b53bb29fSJung-uk Kim #endif
558b53bb29fSJung-uk Kim #if YYDEBUG
559b53bb29fSJung-uk Kim const char *yys;
560b53bb29fSJung-uk Kim
561bf80e08eSJung-uk Kim if ((yys = getenv("YYDEBUG")) != NULL)
562b53bb29fSJung-uk Kim {
563b53bb29fSJung-uk Kim yyn = *yys;
564b53bb29fSJung-uk Kim if (yyn >= '0' && yyn <= '9')
565b53bb29fSJung-uk Kim yydebug = yyn - '0';
566b53bb29fSJung-uk Kim }
567b53bb29fSJung-uk Kim if (yydebug)
568b53bb29fSJung-uk Kim fprintf(stderr, "%sdebug[<# of symbols on state stack>]\n", YYPREFIX);
569b53bb29fSJung-uk Kim #endif
570b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
571b53bb29fSJung-uk Kim memset(yyerror_loc_range, 0, sizeof(yyerror_loc_range));
572b53bb29fSJung-uk Kim #endif
573b53bb29fSJung-uk Kim
574b53bb29fSJung-uk Kim #if YYBTYACC
575b53bb29fSJung-uk Kim yyps = yyNewState(0); if (yyps == 0) goto yyenomem;
576b53bb29fSJung-uk Kim yyps->save = 0;
577b53bb29fSJung-uk Kim #endif /* YYBTYACC */
578b53bb29fSJung-uk Kim yym = 0;
579*8e022d3cSDag-Erling Smørgrav /* yyn is set below */
580b53bb29fSJung-uk Kim yynerrs = 0;
581b53bb29fSJung-uk Kim yyerrflag = 0;
582b53bb29fSJung-uk Kim yychar = YYEMPTY;
583b53bb29fSJung-uk Kim yystate = 0;
584b53bb29fSJung-uk Kim
585b53bb29fSJung-uk Kim #if YYPURE
586b53bb29fSJung-uk Kim memset(&yystack, 0, sizeof(yystack));
587b53bb29fSJung-uk Kim #endif
588b53bb29fSJung-uk Kim
589b53bb29fSJung-uk Kim if (yystack.s_base == NULL && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
590b53bb29fSJung-uk Kim yystack.s_mark = yystack.s_base;
591b53bb29fSJung-uk Kim yystack.l_mark = yystack.l_base;
592b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
593b53bb29fSJung-uk Kim yystack.p_mark = yystack.p_base;
594b53bb29fSJung-uk Kim #endif
595b53bb29fSJung-uk Kim yystate = 0;
596b53bb29fSJung-uk Kim *yystack.s_mark = 0;
597b53bb29fSJung-uk Kim
598b53bb29fSJung-uk Kim yyloop:
599b53bb29fSJung-uk Kim if ((yyn = yydefred[yystate]) != 0) goto yyreduce;
600b53bb29fSJung-uk Kim if (yychar < 0)
601b53bb29fSJung-uk Kim {
602b53bb29fSJung-uk Kim #if YYBTYACC
603b53bb29fSJung-uk Kim do {
604b53bb29fSJung-uk Kim if (yylvp < yylve)
605b53bb29fSJung-uk Kim {
606b53bb29fSJung-uk Kim /* we're currently re-reading tokens */
607b53bb29fSJung-uk Kim yylval = *yylvp++;
608b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
609b53bb29fSJung-uk Kim yylloc = *yylpp++;
610b53bb29fSJung-uk Kim #endif
611b53bb29fSJung-uk Kim yychar = *yylexp++;
612b53bb29fSJung-uk Kim break;
613b53bb29fSJung-uk Kim }
614b53bb29fSJung-uk Kim if (yyps->save)
615b53bb29fSJung-uk Kim {
616b53bb29fSJung-uk Kim /* in trial mode; save scanner results for future parse attempts */
617b53bb29fSJung-uk Kim if (yylvp == yylvlim)
618b53bb29fSJung-uk Kim { /* Enlarge lexical value queue */
619b53bb29fSJung-uk Kim size_t p = (size_t) (yylvp - yylvals);
620b53bb29fSJung-uk Kim size_t s = (size_t) (yylvlim - yylvals);
621b53bb29fSJung-uk Kim
622b53bb29fSJung-uk Kim s += YYLVQUEUEGROWTH;
623b53bb29fSJung-uk Kim if ((yylexemes = (YYINT *)realloc(yylexemes, s * sizeof(YYINT))) == NULL) goto yyenomem;
624b53bb29fSJung-uk Kim if ((yylvals = (YYSTYPE *)realloc(yylvals, s * sizeof(YYSTYPE))) == NULL) goto yyenomem;
625b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
626b53bb29fSJung-uk Kim if ((yylpsns = (YYLTYPE *)realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL) goto yyenomem;
627b53bb29fSJung-uk Kim #endif
628b53bb29fSJung-uk Kim yylvp = yylve = yylvals + p;
629b53bb29fSJung-uk Kim yylvlim = yylvals + s;
630b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
631b53bb29fSJung-uk Kim yylpp = yylpe = yylpsns + p;
632b53bb29fSJung-uk Kim yylplim = yylpsns + s;
633b53bb29fSJung-uk Kim #endif
634b53bb29fSJung-uk Kim yylexp = yylexemes + p;
635b53bb29fSJung-uk Kim }
636b53bb29fSJung-uk Kim *yylexp = (YYINT) YYLEX;
637b53bb29fSJung-uk Kim *yylvp++ = yylval;
638b53bb29fSJung-uk Kim yylve++;
639b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
640b53bb29fSJung-uk Kim *yylpp++ = yylloc;
641b53bb29fSJung-uk Kim yylpe++;
642b53bb29fSJung-uk Kim #endif
643b53bb29fSJung-uk Kim yychar = *yylexp++;
644b53bb29fSJung-uk Kim break;
645b53bb29fSJung-uk Kim }
646b53bb29fSJung-uk Kim /* normal operation, no conflict encountered */
647b53bb29fSJung-uk Kim #endif /* YYBTYACC */
648b53bb29fSJung-uk Kim yychar = YYLEX;
649b53bb29fSJung-uk Kim #if YYBTYACC
650b53bb29fSJung-uk Kim } while (0);
651b53bb29fSJung-uk Kim #endif /* YYBTYACC */
652b53bb29fSJung-uk Kim if (yychar < 0) yychar = YYEOF;
653b53bb29fSJung-uk Kim #if YYDEBUG
654b53bb29fSJung-uk Kim if (yydebug)
655b53bb29fSJung-uk Kim {
656b53bb29fSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
657b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)",
658b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, yystate, yychar, yys);
659b53bb29fSJung-uk Kim #ifdef YYSTYPE_TOSTRING
660b53bb29fSJung-uk Kim #if YYBTYACC
661b53bb29fSJung-uk Kim if (!yytrial)
662b53bb29fSJung-uk Kim #endif /* YYBTYACC */
663b53bb29fSJung-uk Kim fprintf(stderr, " <%s>", YYSTYPE_TOSTRING(yychar, yylval));
664b53bb29fSJung-uk Kim #endif
665b53bb29fSJung-uk Kim fputc('\n', stderr);
666b53bb29fSJung-uk Kim }
667b53bb29fSJung-uk Kim #endif
668b53bb29fSJung-uk Kim }
669b53bb29fSJung-uk Kim #if YYBTYACC
670b53bb29fSJung-uk Kim
671b53bb29fSJung-uk Kim /* Do we have a conflict? */
672b53bb29fSJung-uk Kim if (((yyn = yycindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
673b53bb29fSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
674b53bb29fSJung-uk Kim {
675b53bb29fSJung-uk Kim YYINT ctry;
676b53bb29fSJung-uk Kim
677b53bb29fSJung-uk Kim if (yypath)
678b53bb29fSJung-uk Kim {
679b53bb29fSJung-uk Kim YYParseState *save;
680b53bb29fSJung-uk Kim #if YYDEBUG
681b53bb29fSJung-uk Kim if (yydebug)
682b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: CONFLICT in state %d: following successful trial parse\n",
683b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, yystate);
684b53bb29fSJung-uk Kim #endif
685b53bb29fSJung-uk Kim /* Switch to the next conflict context */
686b53bb29fSJung-uk Kim save = yypath;
687b53bb29fSJung-uk Kim yypath = save->save;
688b53bb29fSJung-uk Kim save->save = NULL;
689b53bb29fSJung-uk Kim ctry = save->ctry;
690b53bb29fSJung-uk Kim if (save->state != yystate) YYABORT;
691b53bb29fSJung-uk Kim yyFreeState(save);
692b53bb29fSJung-uk Kim
693b53bb29fSJung-uk Kim }
694b53bb29fSJung-uk Kim else
695b53bb29fSJung-uk Kim {
696b53bb29fSJung-uk Kim
697b53bb29fSJung-uk Kim /* Unresolved conflict - start/continue trial parse */
698b53bb29fSJung-uk Kim YYParseState *save;
699b53bb29fSJung-uk Kim #if YYDEBUG
700b53bb29fSJung-uk Kim if (yydebug)
701b53bb29fSJung-uk Kim {
702b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: CONFLICT in state %d. ", YYDEBUGSTR, yydepth, yystate);
703b53bb29fSJung-uk Kim if (yyps->save)
704b53bb29fSJung-uk Kim fputs("ALREADY in conflict, continuing trial parse.\n", stderr);
705b53bb29fSJung-uk Kim else
706b53bb29fSJung-uk Kim fputs("Starting trial parse.\n", stderr);
707b53bb29fSJung-uk Kim }
708b53bb29fSJung-uk Kim #endif
709b53bb29fSJung-uk Kim save = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1));
710b53bb29fSJung-uk Kim if (save == NULL) goto yyenomem;
711b53bb29fSJung-uk Kim save->save = yyps->save;
712b53bb29fSJung-uk Kim save->state = yystate;
713b53bb29fSJung-uk Kim save->errflag = yyerrflag;
714b53bb29fSJung-uk Kim save->yystack.s_mark = save->yystack.s_base + (yystack.s_mark - yystack.s_base);
715b53bb29fSJung-uk Kim memcpy (save->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
716b53bb29fSJung-uk Kim save->yystack.l_mark = save->yystack.l_base + (yystack.l_mark - yystack.l_base);
717b53bb29fSJung-uk Kim memcpy (save->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
718b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
719b53bb29fSJung-uk Kim save->yystack.p_mark = save->yystack.p_base + (yystack.p_mark - yystack.p_base);
720b53bb29fSJung-uk Kim memcpy (save->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
721b53bb29fSJung-uk Kim #endif
722b53bb29fSJung-uk Kim ctry = yytable[yyn];
723b53bb29fSJung-uk Kim if (yyctable[ctry] == -1)
724b53bb29fSJung-uk Kim {
725b53bb29fSJung-uk Kim #if YYDEBUG
726b53bb29fSJung-uk Kim if (yydebug && yychar >= YYEOF)
727b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: backtracking 1 token\n", YYDEBUGSTR, yydepth);
728b53bb29fSJung-uk Kim #endif
729b53bb29fSJung-uk Kim ctry++;
730b53bb29fSJung-uk Kim }
731b53bb29fSJung-uk Kim save->ctry = ctry;
732b53bb29fSJung-uk Kim if (yyps->save == NULL)
733b53bb29fSJung-uk Kim {
734b53bb29fSJung-uk Kim /* If this is a first conflict in the stack, start saving lexemes */
735b53bb29fSJung-uk Kim if (!yylexemes)
736b53bb29fSJung-uk Kim {
737b53bb29fSJung-uk Kim yylexemes = (YYINT *) malloc((YYLVQUEUEGROWTH) * sizeof(YYINT));
738b53bb29fSJung-uk Kim if (yylexemes == NULL) goto yyenomem;
739b53bb29fSJung-uk Kim yylvals = (YYSTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYSTYPE));
740b53bb29fSJung-uk Kim if (yylvals == NULL) goto yyenomem;
741b53bb29fSJung-uk Kim yylvlim = yylvals + YYLVQUEUEGROWTH;
742b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
743b53bb29fSJung-uk Kim yylpsns = (YYLTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYLTYPE));
744b53bb29fSJung-uk Kim if (yylpsns == NULL) goto yyenomem;
745b53bb29fSJung-uk Kim yylplim = yylpsns + YYLVQUEUEGROWTH;
746b53bb29fSJung-uk Kim #endif
747b53bb29fSJung-uk Kim }
748b53bb29fSJung-uk Kim if (yylvp == yylve)
749b53bb29fSJung-uk Kim {
750b53bb29fSJung-uk Kim yylvp = yylve = yylvals;
751b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
752b53bb29fSJung-uk Kim yylpp = yylpe = yylpsns;
753b53bb29fSJung-uk Kim #endif
754b53bb29fSJung-uk Kim yylexp = yylexemes;
755b53bb29fSJung-uk Kim if (yychar >= YYEOF)
756b53bb29fSJung-uk Kim {
757b53bb29fSJung-uk Kim *yylve++ = yylval;
758b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
759b53bb29fSJung-uk Kim *yylpe++ = yylloc;
760b53bb29fSJung-uk Kim #endif
761b53bb29fSJung-uk Kim *yylexp = (YYINT) yychar;
762b53bb29fSJung-uk Kim yychar = YYEMPTY;
763b53bb29fSJung-uk Kim }
764b53bb29fSJung-uk Kim }
765b53bb29fSJung-uk Kim }
766b53bb29fSJung-uk Kim if (yychar >= YYEOF)
767b53bb29fSJung-uk Kim {
768b53bb29fSJung-uk Kim yylvp--;
769b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
770b53bb29fSJung-uk Kim yylpp--;
771b53bb29fSJung-uk Kim #endif
772b53bb29fSJung-uk Kim yylexp--;
773b53bb29fSJung-uk Kim yychar = YYEMPTY;
774b53bb29fSJung-uk Kim }
775b53bb29fSJung-uk Kim save->lexeme = (int) (yylvp - yylvals);
776b53bb29fSJung-uk Kim yyps->save = save;
777b53bb29fSJung-uk Kim }
778b53bb29fSJung-uk Kim if (yytable[yyn] == ctry)
779b53bb29fSJung-uk Kim {
780b53bb29fSJung-uk Kim #if YYDEBUG
781b53bb29fSJung-uk Kim if (yydebug)
782b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n",
783b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, yystate, yyctable[ctry]);
784b53bb29fSJung-uk Kim #endif
785b53bb29fSJung-uk Kim if (yychar < 0)
786b53bb29fSJung-uk Kim {
787b53bb29fSJung-uk Kim yylvp++;
788b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
789b53bb29fSJung-uk Kim yylpp++;
790b53bb29fSJung-uk Kim #endif
791b53bb29fSJung-uk Kim yylexp++;
792b53bb29fSJung-uk Kim }
793b53bb29fSJung-uk Kim if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM)
794b53bb29fSJung-uk Kim goto yyoverflow;
795b53bb29fSJung-uk Kim yystate = yyctable[ctry];
796b53bb29fSJung-uk Kim *++yystack.s_mark = (YYINT) yystate;
797b53bb29fSJung-uk Kim *++yystack.l_mark = yylval;
798b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
799b53bb29fSJung-uk Kim *++yystack.p_mark = yylloc;
800b53bb29fSJung-uk Kim #endif
801b53bb29fSJung-uk Kim yychar = YYEMPTY;
802b53bb29fSJung-uk Kim if (yyerrflag > 0) --yyerrflag;
803b53bb29fSJung-uk Kim goto yyloop;
804b53bb29fSJung-uk Kim }
805b53bb29fSJung-uk Kim else
806b53bb29fSJung-uk Kim {
807b53bb29fSJung-uk Kim yyn = yyctable[ctry];
808b53bb29fSJung-uk Kim goto yyreduce;
809b53bb29fSJung-uk Kim }
810b53bb29fSJung-uk Kim } /* End of code dealing with conflicts */
811b53bb29fSJung-uk Kim #endif /* YYBTYACC */
812b53bb29fSJung-uk Kim if (((yyn = yysindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
813b53bb29fSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
814b53bb29fSJung-uk Kim {
815b53bb29fSJung-uk Kim #if YYDEBUG
816b53bb29fSJung-uk Kim if (yydebug)
817b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n",
818b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, yystate, yytable[yyn]);
819b53bb29fSJung-uk Kim #endif
820b53bb29fSJung-uk Kim if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
821b53bb29fSJung-uk Kim yystate = yytable[yyn];
822b53bb29fSJung-uk Kim *++yystack.s_mark = yytable[yyn];
823b53bb29fSJung-uk Kim *++yystack.l_mark = yylval;
824b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
825b53bb29fSJung-uk Kim *++yystack.p_mark = yylloc;
826b53bb29fSJung-uk Kim #endif
827b53bb29fSJung-uk Kim yychar = YYEMPTY;
828b53bb29fSJung-uk Kim if (yyerrflag > 0) --yyerrflag;
829b53bb29fSJung-uk Kim goto yyloop;
830b53bb29fSJung-uk Kim }
831b53bb29fSJung-uk Kim if (((yyn = yyrindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
832b53bb29fSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
833b53bb29fSJung-uk Kim {
834b53bb29fSJung-uk Kim yyn = yytable[yyn];
835b53bb29fSJung-uk Kim goto yyreduce;
836b53bb29fSJung-uk Kim }
837b53bb29fSJung-uk Kim if (yyerrflag != 0) goto yyinrecovery;
838b53bb29fSJung-uk Kim #if YYBTYACC
839b53bb29fSJung-uk Kim
840b53bb29fSJung-uk Kim yynewerrflag = 1;
841b53bb29fSJung-uk Kim goto yyerrhandler;
842b53bb29fSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */
843b53bb29fSJung-uk Kim
844b53bb29fSJung-uk Kim yyerrlab:
845b53bb29fSJung-uk Kim /* explicit YYERROR from an action -- pop the rhs of the rule reduced
846b53bb29fSJung-uk Kim * before looking for error recovery */
847b53bb29fSJung-uk Kim yystack.s_mark -= yym;
848b53bb29fSJung-uk Kim yystate = *yystack.s_mark;
849b53bb29fSJung-uk Kim yystack.l_mark -= yym;
850b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
851b53bb29fSJung-uk Kim yystack.p_mark -= yym;
852b53bb29fSJung-uk Kim #endif
853b53bb29fSJung-uk Kim
854b53bb29fSJung-uk Kim yynewerrflag = 0;
855b53bb29fSJung-uk Kim yyerrhandler:
856b53bb29fSJung-uk Kim while (yyps->save)
857b53bb29fSJung-uk Kim {
858b53bb29fSJung-uk Kim int ctry;
859b53bb29fSJung-uk Kim YYParseState *save = yyps->save;
860b53bb29fSJung-uk Kim #if YYDEBUG
861b53bb29fSJung-uk Kim if (yydebug)
862b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: ERROR in state %d, CONFLICT BACKTRACKING to state %d, %d tokens\n",
863b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, yystate, yyps->save->state,
864b53bb29fSJung-uk Kim (int)(yylvp - yylvals - yyps->save->lexeme));
865b53bb29fSJung-uk Kim #endif
866b53bb29fSJung-uk Kim /* Memorize most forward-looking error state in case it's really an error. */
867b53bb29fSJung-uk Kim if (yyerrctx == NULL || yyerrctx->lexeme < yylvp - yylvals)
868b53bb29fSJung-uk Kim {
869b53bb29fSJung-uk Kim /* Free old saved error context state */
870b53bb29fSJung-uk Kim if (yyerrctx) yyFreeState(yyerrctx);
871b53bb29fSJung-uk Kim /* Create and fill out new saved error context state */
872b53bb29fSJung-uk Kim yyerrctx = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1));
873b53bb29fSJung-uk Kim if (yyerrctx == NULL) goto yyenomem;
874b53bb29fSJung-uk Kim yyerrctx->save = yyps->save;
875b53bb29fSJung-uk Kim yyerrctx->state = yystate;
876b53bb29fSJung-uk Kim yyerrctx->errflag = yyerrflag;
877b53bb29fSJung-uk Kim yyerrctx->yystack.s_mark = yyerrctx->yystack.s_base + (yystack.s_mark - yystack.s_base);
878b53bb29fSJung-uk Kim memcpy (yyerrctx->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
879b53bb29fSJung-uk Kim yyerrctx->yystack.l_mark = yyerrctx->yystack.l_base + (yystack.l_mark - yystack.l_base);
880b53bb29fSJung-uk Kim memcpy (yyerrctx->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
881b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
882b53bb29fSJung-uk Kim yyerrctx->yystack.p_mark = yyerrctx->yystack.p_base + (yystack.p_mark - yystack.p_base);
883b53bb29fSJung-uk Kim memcpy (yyerrctx->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
884b53bb29fSJung-uk Kim #endif
885b53bb29fSJung-uk Kim yyerrctx->lexeme = (int) (yylvp - yylvals);
886b53bb29fSJung-uk Kim }
887b53bb29fSJung-uk Kim yylvp = yylvals + save->lexeme;
888b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
889b53bb29fSJung-uk Kim yylpp = yylpsns + save->lexeme;
890b53bb29fSJung-uk Kim #endif
891b53bb29fSJung-uk Kim yylexp = yylexemes + save->lexeme;
892b53bb29fSJung-uk Kim yychar = YYEMPTY;
893b53bb29fSJung-uk Kim yystack.s_mark = yystack.s_base + (save->yystack.s_mark - save->yystack.s_base);
894b53bb29fSJung-uk Kim memcpy (yystack.s_base, save->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
895b53bb29fSJung-uk Kim yystack.l_mark = yystack.l_base + (save->yystack.l_mark - save->yystack.l_base);
896b53bb29fSJung-uk Kim memcpy (yystack.l_base, save->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
897b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
898b53bb29fSJung-uk Kim yystack.p_mark = yystack.p_base + (save->yystack.p_mark - save->yystack.p_base);
899b53bb29fSJung-uk Kim memcpy (yystack.p_base, save->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
900b53bb29fSJung-uk Kim #endif
901b53bb29fSJung-uk Kim ctry = ++save->ctry;
902b53bb29fSJung-uk Kim yystate = save->state;
903b53bb29fSJung-uk Kim /* We tried shift, try reduce now */
904b53bb29fSJung-uk Kim if ((yyn = yyctable[ctry]) >= 0) goto yyreduce;
905b53bb29fSJung-uk Kim yyps->save = save->save;
906b53bb29fSJung-uk Kim save->save = NULL;
907b53bb29fSJung-uk Kim yyFreeState(save);
908b53bb29fSJung-uk Kim
909b53bb29fSJung-uk Kim /* Nothing left on the stack -- error */
910b53bb29fSJung-uk Kim if (!yyps->save)
911b53bb29fSJung-uk Kim {
912b53bb29fSJung-uk Kim #if YYDEBUG
913b53bb29fSJung-uk Kim if (yydebug)
914b53bb29fSJung-uk Kim fprintf(stderr, "%sdebug[%d,trial]: trial parse FAILED, entering ERROR mode\n",
915b53bb29fSJung-uk Kim YYPREFIX, yydepth);
916b53bb29fSJung-uk Kim #endif
917b53bb29fSJung-uk Kim /* Restore state as it was in the most forward-advanced error */
918b53bb29fSJung-uk Kim yylvp = yylvals + yyerrctx->lexeme;
919b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
920b53bb29fSJung-uk Kim yylpp = yylpsns + yyerrctx->lexeme;
921b53bb29fSJung-uk Kim #endif
922b53bb29fSJung-uk Kim yylexp = yylexemes + yyerrctx->lexeme;
923b53bb29fSJung-uk Kim yychar = yylexp[-1];
924b53bb29fSJung-uk Kim yylval = yylvp[-1];
925b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
926b53bb29fSJung-uk Kim yylloc = yylpp[-1];
927b53bb29fSJung-uk Kim #endif
928b53bb29fSJung-uk Kim yystack.s_mark = yystack.s_base + (yyerrctx->yystack.s_mark - yyerrctx->yystack.s_base);
929b53bb29fSJung-uk Kim memcpy (yystack.s_base, yyerrctx->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
930b53bb29fSJung-uk Kim yystack.l_mark = yystack.l_base + (yyerrctx->yystack.l_mark - yyerrctx->yystack.l_base);
931b53bb29fSJung-uk Kim memcpy (yystack.l_base, yyerrctx->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
932b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
933b53bb29fSJung-uk Kim yystack.p_mark = yystack.p_base + (yyerrctx->yystack.p_mark - yyerrctx->yystack.p_base);
934b53bb29fSJung-uk Kim memcpy (yystack.p_base, yyerrctx->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
935b53bb29fSJung-uk Kim #endif
936b53bb29fSJung-uk Kim yystate = yyerrctx->state;
937b53bb29fSJung-uk Kim yyFreeState(yyerrctx);
938b53bb29fSJung-uk Kim yyerrctx = NULL;
939b53bb29fSJung-uk Kim }
940b53bb29fSJung-uk Kim yynewerrflag = 1;
941b53bb29fSJung-uk Kim }
942b53bb29fSJung-uk Kim if (yynewerrflag == 0) goto yyinrecovery;
943b53bb29fSJung-uk Kim #endif /* YYBTYACC */
944b53bb29fSJung-uk Kim
945b53bb29fSJung-uk Kim YYERROR_CALL("syntax error");
946b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
947b53bb29fSJung-uk Kim yyerror_loc_range[1] = yylloc; /* lookahead position is error start position */
948b53bb29fSJung-uk Kim #endif
949b53bb29fSJung-uk Kim
950b53bb29fSJung-uk Kim #if !YYBTYACC
951b53bb29fSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */
952b53bb29fSJung-uk Kim yyerrlab:
953b53bb29fSJung-uk Kim #endif
954b53bb29fSJung-uk Kim ++yynerrs;
955b53bb29fSJung-uk Kim
956b53bb29fSJung-uk Kim yyinrecovery:
957b53bb29fSJung-uk Kim if (yyerrflag < 3)
958b53bb29fSJung-uk Kim {
959b53bb29fSJung-uk Kim yyerrflag = 3;
960b53bb29fSJung-uk Kim for (;;)
961b53bb29fSJung-uk Kim {
962b53bb29fSJung-uk Kim if (((yyn = yysindex[*yystack.s_mark]) != 0) && (yyn += YYERRCODE) >= 0 &&
963b53bb29fSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) YYERRCODE)
964b53bb29fSJung-uk Kim {
965b53bb29fSJung-uk Kim #if YYDEBUG
966b53bb29fSJung-uk Kim if (yydebug)
967b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, error recovery shifting to state %d\n",
968b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, *yystack.s_mark, yytable[yyn]);
969b53bb29fSJung-uk Kim #endif
970b53bb29fSJung-uk Kim if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
971b53bb29fSJung-uk Kim yystate = yytable[yyn];
972b53bb29fSJung-uk Kim *++yystack.s_mark = yytable[yyn];
973b53bb29fSJung-uk Kim *++yystack.l_mark = yylval;
974b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
975b53bb29fSJung-uk Kim /* lookahead position is error end position */
976b53bb29fSJung-uk Kim yyerror_loc_range[2] = yylloc;
977b53bb29fSJung-uk Kim YYLLOC_DEFAULT(yyloc, yyerror_loc_range, 2); /* position of error span */
978b53bb29fSJung-uk Kim *++yystack.p_mark = yyloc;
979b53bb29fSJung-uk Kim #endif
980b53bb29fSJung-uk Kim goto yyloop;
981b53bb29fSJung-uk Kim }
982b53bb29fSJung-uk Kim else
983b53bb29fSJung-uk Kim {
984b53bb29fSJung-uk Kim #if YYDEBUG
985b53bb29fSJung-uk Kim if (yydebug)
986b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: error recovery discarding state %d\n",
987b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, *yystack.s_mark);
988b53bb29fSJung-uk Kim #endif
989b53bb29fSJung-uk Kim if (yystack.s_mark <= yystack.s_base) goto yyabort;
990b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
991b53bb29fSJung-uk Kim /* the current TOS position is the error start position */
992b53bb29fSJung-uk Kim yyerror_loc_range[1] = *yystack.p_mark;
993b53bb29fSJung-uk Kim #endif
994b53bb29fSJung-uk Kim #if defined(YYDESTRUCT_CALL)
995b53bb29fSJung-uk Kim #if YYBTYACC
996b53bb29fSJung-uk Kim if (!yytrial)
997b53bb29fSJung-uk Kim #endif /* YYBTYACC */
998b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
999b53bb29fSJung-uk Kim YYDESTRUCT_CALL("error: discarding state",
1000b53bb29fSJung-uk Kim yystos[*yystack.s_mark], yystack.l_mark, yystack.p_mark);
1001b53bb29fSJung-uk Kim #else
1002b53bb29fSJung-uk Kim YYDESTRUCT_CALL("error: discarding state",
1003b53bb29fSJung-uk Kim yystos[*yystack.s_mark], yystack.l_mark);
1004b53bb29fSJung-uk Kim #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
1005b53bb29fSJung-uk Kim #endif /* defined(YYDESTRUCT_CALL) */
1006b53bb29fSJung-uk Kim --yystack.s_mark;
1007b53bb29fSJung-uk Kim --yystack.l_mark;
1008b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1009b53bb29fSJung-uk Kim --yystack.p_mark;
1010b53bb29fSJung-uk Kim #endif
1011b53bb29fSJung-uk Kim }
1012b53bb29fSJung-uk Kim }
1013b53bb29fSJung-uk Kim }
1014b53bb29fSJung-uk Kim else
1015b53bb29fSJung-uk Kim {
1016b53bb29fSJung-uk Kim if (yychar == YYEOF) goto yyabort;
1017b53bb29fSJung-uk Kim #if YYDEBUG
1018b53bb29fSJung-uk Kim if (yydebug)
1019b53bb29fSJung-uk Kim {
1020b53bb29fSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
1021b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, error recovery discarding token %d (%s)\n",
1022b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, yystate, yychar, yys);
1023b53bb29fSJung-uk Kim }
1024b53bb29fSJung-uk Kim #endif
1025b53bb29fSJung-uk Kim #if defined(YYDESTRUCT_CALL)
1026b53bb29fSJung-uk Kim #if YYBTYACC
1027b53bb29fSJung-uk Kim if (!yytrial)
1028b53bb29fSJung-uk Kim #endif /* YYBTYACC */
1029b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1030b53bb29fSJung-uk Kim YYDESTRUCT_CALL("error: discarding token", yychar, &yylval, &yylloc);
1031b53bb29fSJung-uk Kim #else
1032b53bb29fSJung-uk Kim YYDESTRUCT_CALL("error: discarding token", yychar, &yylval);
1033b53bb29fSJung-uk Kim #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
1034b53bb29fSJung-uk Kim #endif /* defined(YYDESTRUCT_CALL) */
1035b53bb29fSJung-uk Kim yychar = YYEMPTY;
1036b53bb29fSJung-uk Kim goto yyloop;
1037b53bb29fSJung-uk Kim }
1038b53bb29fSJung-uk Kim
1039b53bb29fSJung-uk Kim yyreduce:
1040b53bb29fSJung-uk Kim yym = yylen[yyn];
1041b53bb29fSJung-uk Kim #if YYDEBUG
1042b53bb29fSJung-uk Kim if (yydebug)
1043b53bb29fSJung-uk Kim {
1044b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, reducing by rule %d (%s)",
1045b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, yystate, yyn, yyrule[yyn]);
1046b53bb29fSJung-uk Kim #ifdef YYSTYPE_TOSTRING
1047b53bb29fSJung-uk Kim #if YYBTYACC
1048b53bb29fSJung-uk Kim if (!yytrial)
1049b53bb29fSJung-uk Kim #endif /* YYBTYACC */
1050b53bb29fSJung-uk Kim if (yym > 0)
1051b53bb29fSJung-uk Kim {
1052b53bb29fSJung-uk Kim int i;
1053b53bb29fSJung-uk Kim fputc('<', stderr);
1054b53bb29fSJung-uk Kim for (i = yym; i > 0; i--)
1055b53bb29fSJung-uk Kim {
1056b53bb29fSJung-uk Kim if (i != yym) fputs(", ", stderr);
1057b53bb29fSJung-uk Kim fputs(YYSTYPE_TOSTRING(yystos[yystack.s_mark[1-i]],
1058b53bb29fSJung-uk Kim yystack.l_mark[1-i]), stderr);
1059b53bb29fSJung-uk Kim }
1060b53bb29fSJung-uk Kim fputc('>', stderr);
1061b53bb29fSJung-uk Kim }
1062b53bb29fSJung-uk Kim #endif
1063b53bb29fSJung-uk Kim fputc('\n', stderr);
1064b53bb29fSJung-uk Kim }
1065b53bb29fSJung-uk Kim #endif
1066b53bb29fSJung-uk Kim if (yym > 0)
1067b53bb29fSJung-uk Kim yyval = yystack.l_mark[1-yym];
1068b53bb29fSJung-uk Kim else
1069b53bb29fSJung-uk Kim memset(&yyval, 0, sizeof yyval);
1070b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1071b53bb29fSJung-uk Kim
1072b53bb29fSJung-uk Kim /* Perform position reduction */
1073b53bb29fSJung-uk Kim memset(&yyloc, 0, sizeof(yyloc));
1074b53bb29fSJung-uk Kim #if YYBTYACC
1075b53bb29fSJung-uk Kim if (!yytrial)
1076b53bb29fSJung-uk Kim #endif /* YYBTYACC */
1077b53bb29fSJung-uk Kim {
1078b53bb29fSJung-uk Kim YYLLOC_DEFAULT(yyloc, &yystack.p_mark[-yym], yym);
1079b53bb29fSJung-uk Kim /* just in case YYERROR is invoked within the action, save
1080b53bb29fSJung-uk Kim the start of the rhs as the error start position */
1081b53bb29fSJung-uk Kim yyerror_loc_range[1] = yystack.p_mark[1-yym];
1082b53bb29fSJung-uk Kim }
1083b53bb29fSJung-uk Kim #endif
1084b53bb29fSJung-uk Kim
1085b53bb29fSJung-uk Kim switch (yyn)
1086b53bb29fSJung-uk Kim {
1087b53bb29fSJung-uk Kim case 3:
1088b53bb29fSJung-uk Kim #line 28 "calc.y"
1089b53bb29fSJung-uk Kim { yyerrok ; }
1090*8e022d3cSDag-Erling Smørgrav #line 1091 "stdin2.calc.c"
1091b53bb29fSJung-uk Kim break;
1092b53bb29fSJung-uk Kim case 4:
1093b53bb29fSJung-uk Kim #line 32 "calc.y"
1094b53bb29fSJung-uk Kim { printf("%d\n",yystack.l_mark[0]);}
1095*8e022d3cSDag-Erling Smørgrav #line 1096 "stdin2.calc.c"
1096b53bb29fSJung-uk Kim break;
1097b53bb29fSJung-uk Kim case 5:
1098b53bb29fSJung-uk Kim #line 34 "calc.y"
1099b53bb29fSJung-uk Kim { regs[yystack.l_mark[-2]] = yystack.l_mark[0]; }
1100*8e022d3cSDag-Erling Smørgrav #line 1101 "stdin2.calc.c"
1101b53bb29fSJung-uk Kim break;
1102b53bb29fSJung-uk Kim case 6:
1103b53bb29fSJung-uk Kim #line 38 "calc.y"
1104b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-1]; }
1105*8e022d3cSDag-Erling Smørgrav #line 1106 "stdin2.calc.c"
1106b53bb29fSJung-uk Kim break;
1107b53bb29fSJung-uk Kim case 7:
1108b53bb29fSJung-uk Kim #line 40 "calc.y"
1109b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] + yystack.l_mark[0]; }
1110*8e022d3cSDag-Erling Smørgrav #line 1111 "stdin2.calc.c"
1111b53bb29fSJung-uk Kim break;
1112b53bb29fSJung-uk Kim case 8:
1113b53bb29fSJung-uk Kim #line 42 "calc.y"
1114b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] - yystack.l_mark[0]; }
1115*8e022d3cSDag-Erling Smørgrav #line 1116 "stdin2.calc.c"
1116b53bb29fSJung-uk Kim break;
1117b53bb29fSJung-uk Kim case 9:
1118b53bb29fSJung-uk Kim #line 44 "calc.y"
1119b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] * yystack.l_mark[0]; }
1120*8e022d3cSDag-Erling Smørgrav #line 1121 "stdin2.calc.c"
1121b53bb29fSJung-uk Kim break;
1122b53bb29fSJung-uk Kim case 10:
1123b53bb29fSJung-uk Kim #line 46 "calc.y"
1124b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] / yystack.l_mark[0]; }
1125*8e022d3cSDag-Erling Smørgrav #line 1126 "stdin2.calc.c"
1126b53bb29fSJung-uk Kim break;
1127b53bb29fSJung-uk Kim case 11:
1128b53bb29fSJung-uk Kim #line 48 "calc.y"
1129b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] % yystack.l_mark[0]; }
1130*8e022d3cSDag-Erling Smørgrav #line 1131 "stdin2.calc.c"
1131b53bb29fSJung-uk Kim break;
1132b53bb29fSJung-uk Kim case 12:
1133b53bb29fSJung-uk Kim #line 50 "calc.y"
1134b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] & yystack.l_mark[0]; }
1135*8e022d3cSDag-Erling Smørgrav #line 1136 "stdin2.calc.c"
1136b53bb29fSJung-uk Kim break;
1137b53bb29fSJung-uk Kim case 13:
1138b53bb29fSJung-uk Kim #line 52 "calc.y"
1139b53bb29fSJung-uk Kim { yyval = yystack.l_mark[-2] | yystack.l_mark[0]; }
1140*8e022d3cSDag-Erling Smørgrav #line 1141 "stdin2.calc.c"
1141b53bb29fSJung-uk Kim break;
1142b53bb29fSJung-uk Kim case 14:
1143b53bb29fSJung-uk Kim #line 54 "calc.y"
1144b53bb29fSJung-uk Kim { yyval = - yystack.l_mark[0]; }
1145*8e022d3cSDag-Erling Smørgrav #line 1146 "stdin2.calc.c"
1146b53bb29fSJung-uk Kim break;
1147b53bb29fSJung-uk Kim case 15:
1148b53bb29fSJung-uk Kim #line 56 "calc.y"
1149b53bb29fSJung-uk Kim { yyval = regs[yystack.l_mark[0]]; }
1150*8e022d3cSDag-Erling Smørgrav #line 1151 "stdin2.calc.c"
1151b53bb29fSJung-uk Kim break;
1152b53bb29fSJung-uk Kim case 17:
1153b53bb29fSJung-uk Kim #line 61 "calc.y"
1154b53bb29fSJung-uk Kim { yyval = yystack.l_mark[0]; base = (yystack.l_mark[0]==0) ? 8 : 10; }
1155*8e022d3cSDag-Erling Smørgrav #line 1156 "stdin2.calc.c"
1156b53bb29fSJung-uk Kim break;
1157b53bb29fSJung-uk Kim case 18:
1158b53bb29fSJung-uk Kim #line 63 "calc.y"
1159b53bb29fSJung-uk Kim { yyval = base * yystack.l_mark[-1] + yystack.l_mark[0]; }
1160*8e022d3cSDag-Erling Smørgrav #line 1161 "stdin2.calc.c"
1161b53bb29fSJung-uk Kim break;
1162*8e022d3cSDag-Erling Smørgrav #line 1163 "stdin2.calc.c"
1163b53bb29fSJung-uk Kim default:
1164b53bb29fSJung-uk Kim break;
1165b53bb29fSJung-uk Kim }
1166b53bb29fSJung-uk Kim yystack.s_mark -= yym;
1167b53bb29fSJung-uk Kim yystate = *yystack.s_mark;
1168b53bb29fSJung-uk Kim yystack.l_mark -= yym;
1169b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1170b53bb29fSJung-uk Kim yystack.p_mark -= yym;
1171b53bb29fSJung-uk Kim #endif
1172b53bb29fSJung-uk Kim yym = yylhs[yyn];
1173b53bb29fSJung-uk Kim if (yystate == 0 && yym == 0)
1174b53bb29fSJung-uk Kim {
1175b53bb29fSJung-uk Kim #if YYDEBUG
1176b53bb29fSJung-uk Kim if (yydebug)
1177b53bb29fSJung-uk Kim {
1178b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: after reduction, ", YYDEBUGSTR, yydepth);
1179b53bb29fSJung-uk Kim #ifdef YYSTYPE_TOSTRING
1180b53bb29fSJung-uk Kim #if YYBTYACC
1181b53bb29fSJung-uk Kim if (!yytrial)
1182b53bb29fSJung-uk Kim #endif /* YYBTYACC */
1183b53bb29fSJung-uk Kim fprintf(stderr, "result is <%s>, ", YYSTYPE_TOSTRING(yystos[YYFINAL], yyval));
1184b53bb29fSJung-uk Kim #endif
1185b53bb29fSJung-uk Kim fprintf(stderr, "shifting from state 0 to final state %d\n", YYFINAL);
1186b53bb29fSJung-uk Kim }
1187b53bb29fSJung-uk Kim #endif
1188b53bb29fSJung-uk Kim yystate = YYFINAL;
1189b53bb29fSJung-uk Kim *++yystack.s_mark = YYFINAL;
1190b53bb29fSJung-uk Kim *++yystack.l_mark = yyval;
1191b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1192b53bb29fSJung-uk Kim *++yystack.p_mark = yyloc;
1193b53bb29fSJung-uk Kim #endif
1194b53bb29fSJung-uk Kim if (yychar < 0)
1195b53bb29fSJung-uk Kim {
1196b53bb29fSJung-uk Kim #if YYBTYACC
1197b53bb29fSJung-uk Kim do {
1198b53bb29fSJung-uk Kim if (yylvp < yylve)
1199b53bb29fSJung-uk Kim {
1200b53bb29fSJung-uk Kim /* we're currently re-reading tokens */
1201b53bb29fSJung-uk Kim yylval = *yylvp++;
1202b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1203b53bb29fSJung-uk Kim yylloc = *yylpp++;
1204b53bb29fSJung-uk Kim #endif
1205b53bb29fSJung-uk Kim yychar = *yylexp++;
1206b53bb29fSJung-uk Kim break;
1207b53bb29fSJung-uk Kim }
1208b53bb29fSJung-uk Kim if (yyps->save)
1209b53bb29fSJung-uk Kim {
1210b53bb29fSJung-uk Kim /* in trial mode; save scanner results for future parse attempts */
1211b53bb29fSJung-uk Kim if (yylvp == yylvlim)
1212b53bb29fSJung-uk Kim { /* Enlarge lexical value queue */
1213b53bb29fSJung-uk Kim size_t p = (size_t) (yylvp - yylvals);
1214b53bb29fSJung-uk Kim size_t s = (size_t) (yylvlim - yylvals);
1215b53bb29fSJung-uk Kim
1216b53bb29fSJung-uk Kim s += YYLVQUEUEGROWTH;
1217b53bb29fSJung-uk Kim if ((yylexemes = (YYINT *)realloc(yylexemes, s * sizeof(YYINT))) == NULL)
1218b53bb29fSJung-uk Kim goto yyenomem;
1219b53bb29fSJung-uk Kim if ((yylvals = (YYSTYPE *)realloc(yylvals, s * sizeof(YYSTYPE))) == NULL)
1220b53bb29fSJung-uk Kim goto yyenomem;
1221b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1222b53bb29fSJung-uk Kim if ((yylpsns = (YYLTYPE *)realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL)
1223b53bb29fSJung-uk Kim goto yyenomem;
1224b53bb29fSJung-uk Kim #endif
1225b53bb29fSJung-uk Kim yylvp = yylve = yylvals + p;
1226b53bb29fSJung-uk Kim yylvlim = yylvals + s;
1227b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1228b53bb29fSJung-uk Kim yylpp = yylpe = yylpsns + p;
1229b53bb29fSJung-uk Kim yylplim = yylpsns + s;
1230b53bb29fSJung-uk Kim #endif
1231b53bb29fSJung-uk Kim yylexp = yylexemes + p;
1232b53bb29fSJung-uk Kim }
1233b53bb29fSJung-uk Kim *yylexp = (YYINT) YYLEX;
1234b53bb29fSJung-uk Kim *yylvp++ = yylval;
1235b53bb29fSJung-uk Kim yylve++;
1236b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1237b53bb29fSJung-uk Kim *yylpp++ = yylloc;
1238b53bb29fSJung-uk Kim yylpe++;
1239b53bb29fSJung-uk Kim #endif
1240b53bb29fSJung-uk Kim yychar = *yylexp++;
1241b53bb29fSJung-uk Kim break;
1242b53bb29fSJung-uk Kim }
1243b53bb29fSJung-uk Kim /* normal operation, no conflict encountered */
1244b53bb29fSJung-uk Kim #endif /* YYBTYACC */
1245b53bb29fSJung-uk Kim yychar = YYLEX;
1246b53bb29fSJung-uk Kim #if YYBTYACC
1247b53bb29fSJung-uk Kim } while (0);
1248b53bb29fSJung-uk Kim #endif /* YYBTYACC */
1249b53bb29fSJung-uk Kim if (yychar < 0) yychar = YYEOF;
1250b53bb29fSJung-uk Kim #if YYDEBUG
1251b53bb29fSJung-uk Kim if (yydebug)
1252b53bb29fSJung-uk Kim {
1253b53bb29fSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
1254b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)\n",
1255b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, YYFINAL, yychar, yys);
1256b53bb29fSJung-uk Kim }
1257b53bb29fSJung-uk Kim #endif
1258b53bb29fSJung-uk Kim }
1259b53bb29fSJung-uk Kim if (yychar == YYEOF) goto yyaccept;
1260b53bb29fSJung-uk Kim goto yyloop;
1261b53bb29fSJung-uk Kim }
1262b53bb29fSJung-uk Kim if (((yyn = yygindex[yym]) != 0) && (yyn += yystate) >= 0 &&
1263b53bb29fSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yystate)
1264b53bb29fSJung-uk Kim yystate = yytable[yyn];
1265b53bb29fSJung-uk Kim else
1266b53bb29fSJung-uk Kim yystate = yydgoto[yym];
1267b53bb29fSJung-uk Kim #if YYDEBUG
1268b53bb29fSJung-uk Kim if (yydebug)
1269b53bb29fSJung-uk Kim {
1270b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: after reduction, ", YYDEBUGSTR, yydepth);
1271b53bb29fSJung-uk Kim #ifdef YYSTYPE_TOSTRING
1272b53bb29fSJung-uk Kim #if YYBTYACC
1273b53bb29fSJung-uk Kim if (!yytrial)
1274b53bb29fSJung-uk Kim #endif /* YYBTYACC */
1275b53bb29fSJung-uk Kim fprintf(stderr, "result is <%s>, ", YYSTYPE_TOSTRING(yystos[yystate], yyval));
1276b53bb29fSJung-uk Kim #endif
1277b53bb29fSJung-uk Kim fprintf(stderr, "shifting from state %d to state %d\n", *yystack.s_mark, yystate);
1278b53bb29fSJung-uk Kim }
1279b53bb29fSJung-uk Kim #endif
1280b53bb29fSJung-uk Kim if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
1281b53bb29fSJung-uk Kim *++yystack.s_mark = (YYINT) yystate;
1282b53bb29fSJung-uk Kim *++yystack.l_mark = yyval;
1283b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1284b53bb29fSJung-uk Kim *++yystack.p_mark = yyloc;
1285b53bb29fSJung-uk Kim #endif
1286b53bb29fSJung-uk Kim goto yyloop;
1287b53bb29fSJung-uk Kim #if YYBTYACC
1288b53bb29fSJung-uk Kim
1289b53bb29fSJung-uk Kim /* Reduction declares that this path is valid. Set yypath and do a full parse */
1290b53bb29fSJung-uk Kim yyvalid:
1291b53bb29fSJung-uk Kim if (yypath) YYABORT;
1292b53bb29fSJung-uk Kim while (yyps->save)
1293b53bb29fSJung-uk Kim {
1294b53bb29fSJung-uk Kim YYParseState *save = yyps->save;
1295b53bb29fSJung-uk Kim yyps->save = save->save;
1296b53bb29fSJung-uk Kim save->save = yypath;
1297b53bb29fSJung-uk Kim yypath = save;
1298b53bb29fSJung-uk Kim }
1299b53bb29fSJung-uk Kim #if YYDEBUG
1300b53bb29fSJung-uk Kim if (yydebug)
1301b53bb29fSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, CONFLICT trial successful, backtracking to state %d, %d tokens\n",
1302b53bb29fSJung-uk Kim YYDEBUGSTR, yydepth, yystate, yypath->state, (int)(yylvp - yylvals - yypath->lexeme));
1303b53bb29fSJung-uk Kim #endif
1304b53bb29fSJung-uk Kim if (yyerrctx)
1305b53bb29fSJung-uk Kim {
1306b53bb29fSJung-uk Kim yyFreeState(yyerrctx);
1307b53bb29fSJung-uk Kim yyerrctx = NULL;
1308b53bb29fSJung-uk Kim }
1309b53bb29fSJung-uk Kim yylvp = yylvals + yypath->lexeme;
1310b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1311b53bb29fSJung-uk Kim yylpp = yylpsns + yypath->lexeme;
1312b53bb29fSJung-uk Kim #endif
1313b53bb29fSJung-uk Kim yylexp = yylexemes + yypath->lexeme;
1314b53bb29fSJung-uk Kim yychar = YYEMPTY;
1315b53bb29fSJung-uk Kim yystack.s_mark = yystack.s_base + (yypath->yystack.s_mark - yypath->yystack.s_base);
1316b53bb29fSJung-uk Kim memcpy (yystack.s_base, yypath->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
1317b53bb29fSJung-uk Kim yystack.l_mark = yystack.l_base + (yypath->yystack.l_mark - yypath->yystack.l_base);
1318b53bb29fSJung-uk Kim memcpy (yystack.l_base, yypath->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
1319b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1320b53bb29fSJung-uk Kim yystack.p_mark = yystack.p_base + (yypath->yystack.p_mark - yypath->yystack.p_base);
1321b53bb29fSJung-uk Kim memcpy (yystack.p_base, yypath->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
1322b53bb29fSJung-uk Kim #endif
1323b53bb29fSJung-uk Kim yystate = yypath->state;
1324b53bb29fSJung-uk Kim goto yyloop;
1325b53bb29fSJung-uk Kim #endif /* YYBTYACC */
1326b53bb29fSJung-uk Kim
1327b53bb29fSJung-uk Kim yyoverflow:
1328b53bb29fSJung-uk Kim YYERROR_CALL("yacc stack overflow");
1329b53bb29fSJung-uk Kim #if YYBTYACC
1330b53bb29fSJung-uk Kim goto yyabort_nomem;
1331b53bb29fSJung-uk Kim yyenomem:
1332b53bb29fSJung-uk Kim YYERROR_CALL("memory exhausted");
1333b53bb29fSJung-uk Kim yyabort_nomem:
1334b53bb29fSJung-uk Kim #endif /* YYBTYACC */
1335b53bb29fSJung-uk Kim yyresult = 2;
1336b53bb29fSJung-uk Kim goto yyreturn;
1337b53bb29fSJung-uk Kim
1338b53bb29fSJung-uk Kim yyabort:
1339b53bb29fSJung-uk Kim yyresult = 1;
1340b53bb29fSJung-uk Kim goto yyreturn;
1341b53bb29fSJung-uk Kim
1342b53bb29fSJung-uk Kim yyaccept:
1343b53bb29fSJung-uk Kim #if YYBTYACC
1344b53bb29fSJung-uk Kim if (yyps->save) goto yyvalid;
1345b53bb29fSJung-uk Kim #endif /* YYBTYACC */
1346b53bb29fSJung-uk Kim yyresult = 0;
1347b53bb29fSJung-uk Kim
1348b53bb29fSJung-uk Kim yyreturn:
1349b53bb29fSJung-uk Kim #if defined(YYDESTRUCT_CALL)
1350b53bb29fSJung-uk Kim if (yychar != YYEOF && yychar != YYEMPTY)
1351b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1352b53bb29fSJung-uk Kim YYDESTRUCT_CALL("cleanup: discarding token", yychar, &yylval, &yylloc);
1353b53bb29fSJung-uk Kim #else
1354b53bb29fSJung-uk Kim YYDESTRUCT_CALL("cleanup: discarding token", yychar, &yylval);
1355b53bb29fSJung-uk Kim #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
1356b53bb29fSJung-uk Kim
1357b53bb29fSJung-uk Kim {
1358b53bb29fSJung-uk Kim YYSTYPE *pv;
1359b53bb29fSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1360b53bb29fSJung-uk Kim YYLTYPE *pp;
1361b53bb29fSJung-uk Kim
1362b53bb29fSJung-uk Kim for (pv = yystack.l_base, pp = yystack.p_base; pv <= yystack.l_mark; ++pv, ++pp)
1363b53bb29fSJung-uk Kim YYDESTRUCT_CALL("cleanup: discarding state",
1364b53bb29fSJung-uk Kim yystos[*(yystack.s_base + (pv - yystack.l_base))], pv, pp);
1365b53bb29fSJung-uk Kim #else
1366b53bb29fSJung-uk Kim for (pv = yystack.l_base; pv <= yystack.l_mark; ++pv)
1367b53bb29fSJung-uk Kim YYDESTRUCT_CALL("cleanup: discarding state",
1368b53bb29fSJung-uk Kim yystos[*(yystack.s_base + (pv - yystack.l_base))], pv);
1369b53bb29fSJung-uk Kim #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
1370b53bb29fSJung-uk Kim }
1371b53bb29fSJung-uk Kim #endif /* defined(YYDESTRUCT_CALL) */
1372b53bb29fSJung-uk Kim
1373b53bb29fSJung-uk Kim #if YYBTYACC
1374b53bb29fSJung-uk Kim if (yyerrctx)
1375b53bb29fSJung-uk Kim {
1376b53bb29fSJung-uk Kim yyFreeState(yyerrctx);
1377b53bb29fSJung-uk Kim yyerrctx = NULL;
1378b53bb29fSJung-uk Kim }
1379b53bb29fSJung-uk Kim while (yyps)
1380b53bb29fSJung-uk Kim {
1381b53bb29fSJung-uk Kim YYParseState *save = yyps;
1382b53bb29fSJung-uk Kim yyps = save->save;
1383b53bb29fSJung-uk Kim save->save = NULL;
1384b53bb29fSJung-uk Kim yyFreeState(save);
1385b53bb29fSJung-uk Kim }
1386b53bb29fSJung-uk Kim while (yypath)
1387b53bb29fSJung-uk Kim {
1388b53bb29fSJung-uk Kim YYParseState *save = yypath;
1389b53bb29fSJung-uk Kim yypath = save->save;
1390b53bb29fSJung-uk Kim save->save = NULL;
1391b53bb29fSJung-uk Kim yyFreeState(save);
1392b53bb29fSJung-uk Kim }
1393b53bb29fSJung-uk Kim #endif /* YYBTYACC */
1394b53bb29fSJung-uk Kim yyfreestack(&yystack);
1395b53bb29fSJung-uk Kim return (yyresult);
1396b53bb29fSJung-uk Kim }
1397