1 /* original parser id follows */
2 /* yysccsid[] = "@(#)yaccpar 1.9 (Berkeley) 02/21/93" */
3 /* (use YYMAJOR/YYMINOR for ifdefs dependent on parser version) */
8 #define YYCHECK "yyyymmdd"
11 #define yyclearin (yychar = YYEMPTY)
12 #define yyerrok (yyerrflag = 0)
13 #define YYRECOVERING() (yyerrflag != 0)
16 #line 17 "rename_debug.c"
17 #include "rename_debug.i"
18 #include "rename_debug.h"
20 static const YYINT yylhs[] = { -1,
23 static const YYINT yylen[] = { 2,
26 static const YYINT yydefred[] = { 0,
29 static const YYINT yydgoto[] = { 2,
31 static const YYINT yysindex[] = { -256,
34 static const YYINT yyrindex[] = { 0,
37 static const YYINT yygindex[] = { 0,
40 static const YYINT yytable[] = { 1,
42 static const YYINT yycheck[] = { 256,
48 #define YYMAXTOKEN 256
49 #define YYUNDFTOKEN 259
50 #define YYTRANSLATE(a) ((a) > YYMAXTOKEN ? YYUNDFTOKEN : (a))
52 static const char *const yyname[] = {
54 "end-of-file",0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
55 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
56 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
57 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
58 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
59 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
60 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,"illegal-symbol",
62 static const char *const yyrule[] = {
77 /* define the initial stack-sizes */
80 #define YYMAXDEPTH YYSTACKSIZE
83 #define YYSTACKSIZE YYMAXDEPTH
85 #define YYSTACKSIZE 10000
86 #define YYMAXDEPTH 10000
90 #define YYINITSTACKSIZE 200
100 /* variables for the parser stack */
101 static YYSTACKDATA yystack;
102 #line 12 "code_debug.y"
107 extern int YYLEX_DECL();
113 printf("yyparse() = %d\n", yyparse());
124 yyerror(const char* s)
128 #line 130 "rename_debug.c"
131 #include <stdio.h> /* needed for printf */
134 #include <stdlib.h> /* needed for malloc, etc */
135 #include <string.h> /* needed for memset */
137 /* allocate initial stack or double stack size, up to YYMAXDEPTH */
138 static int yygrowstack(YYSTACKDATA *data)
145 if ((newsize = data->stacksize) == 0)
146 newsize = YYINITSTACKSIZE;
147 else if (newsize >= YYMAXDEPTH)
149 else if ((newsize *= 2) > YYMAXDEPTH)
150 newsize = YYMAXDEPTH;
152 i = (int) (data->s_mark - data->s_base);
153 newss = (YYINT *)realloc(data->s_base, newsize * sizeof(*newss));
157 data->s_base = newss;
158 data->s_mark = newss + i;
160 newvs = (YYSTYPE *)realloc(data->l_base, newsize * sizeof(*newvs));
164 data->l_base = newvs;
165 data->l_mark = newvs + i;
167 data->stacksize = newsize;
168 data->s_last = data->s_base + newsize - 1;
172 #if YYPURE || defined(YY_NO_LEAKS)
173 static void yyfreestack(YYSTACKDATA *data)
177 memset(data, 0, sizeof(*data));
180 #define yyfreestack(data) /* nothing */
183 #define YYABORT goto yyabort
184 #define YYREJECT goto yyabort
185 #define YYACCEPT goto yyaccept
186 #define YYERROR goto yyerrlab
191 int yym, yyn, yystate;
195 if ((yys = getenv("YYDEBUG")) != 0)
198 if (yyn >= '0' && yyn <= '9')
211 memset(&yystack, 0, sizeof(yystack));
214 if (yystack.s_base == NULL && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
215 yystack.s_mark = yystack.s_base;
216 yystack.l_mark = yystack.l_base;
221 if ((yyn = yydefred[yystate]) != 0) goto yyreduce;
225 if (yychar < 0) yychar = YYEOF;
229 if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
230 printf("%sdebug: state %d, reading %d (%s)\n",
231 YYPREFIX, yystate, yychar, yys);
235 if (((yyn = yysindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
236 yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
240 printf("%sdebug: state %d, shifting to state %d\n",
241 YYPREFIX, yystate, yytable[yyn]);
243 if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
244 yystate = yytable[yyn];
245 *++yystack.s_mark = yytable[yyn];
246 *++yystack.l_mark = yylval;
248 if (yyerrflag > 0) --yyerrflag;
251 if (((yyn = yyrindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
252 yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
257 if (yyerrflag != 0) goto yyinrecovery;
259 YYERROR_CALL("syntax error");
261 goto yyerrlab; /* redundant goto avoids 'unused label' warning */
271 if (((yyn = yysindex[*yystack.s_mark]) != 0) && (yyn += YYERRCODE) >= 0 &&
272 yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) YYERRCODE)
276 printf("%sdebug: state %d, error recovery shifting\
277 to state %d\n", YYPREFIX, *yystack.s_mark, yytable[yyn]);
279 if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
280 yystate = yytable[yyn];
281 *++yystack.s_mark = yytable[yyn];
282 *++yystack.l_mark = yylval;
289 printf("%sdebug: error recovery discarding state %d\n",
290 YYPREFIX, *yystack.s_mark);
292 if (yystack.s_mark <= yystack.s_base) goto yyabort;
300 if (yychar == YYEOF) goto yyabort;
304 if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
305 printf("%sdebug: state %d, error recovery discards token %d (%s)\n",
306 YYPREFIX, yystate, yychar, yys);
316 printf("%sdebug: state %d, reducing by rule %d (%s)\n",
317 YYPREFIX, yystate, yyn, yyrule[yyn]);
321 yyval = yystack.l_mark[1-yym];
323 memset(&yyval, 0, sizeof yyval);
328 yystack.s_mark -= yym;
329 yystate = *yystack.s_mark;
330 yystack.l_mark -= yym;
332 if (yystate == 0 && yym == 0)
336 printf("%sdebug: after reduction, shifting from state 0 to\
337 state %d\n", YYPREFIX, YYFINAL);
340 *++yystack.s_mark = YYFINAL;
341 *++yystack.l_mark = yyval;
345 if (yychar < 0) yychar = YYEOF;
349 if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
350 printf("%sdebug: state %d, reading %d (%s)\n",
351 YYPREFIX, YYFINAL, yychar, yys);
355 if (yychar == YYEOF) goto yyaccept;
358 if (((yyn = yygindex[yym]) != 0) && (yyn += yystate) >= 0 &&
359 yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yystate)
360 yystate = yytable[yyn];
362 yystate = yydgoto[yym];
365 printf("%sdebug: after reduction, shifting from state %d \
366 to state %d\n", YYPREFIX, *yystack.s_mark, yystate);
368 if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
369 *++yystack.s_mark = (YYINT) yystate;
370 *++yystack.l_mark = yyval;
374 YYERROR_CALL("yacc stack overflow");
377 yyfreestack(&yystack);
381 yyfreestack(&yystack);