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[] = {
79 /* define the initial stack-sizes */
82 #define YYMAXDEPTH YYSTACKSIZE
85 #define YYSTACKSIZE YYMAXDEPTH
87 #define YYSTACKSIZE 10000
88 #define YYMAXDEPTH 10000
92 #define YYINITSTACKSIZE 200
102 /* variables for the parser stack */
103 static YYSTACKDATA yystack;
104 #line 12 "code_debug.y"
109 extern int YYLEX_DECL();
115 printf("yyparse() = %d\n", yyparse());
126 yyerror(const char* s)
130 #line 132 "rename_debug.c"
133 #include <stdio.h> /* needed for printf */
136 #include <stdlib.h> /* needed for malloc, etc */
137 #include <string.h> /* needed for memset */
139 /* allocate initial stack or double stack size, up to YYMAXDEPTH */
140 static int yygrowstack(YYSTACKDATA *data)
147 if ((newsize = data->stacksize) == 0)
148 newsize = YYINITSTACKSIZE;
149 else if (newsize >= YYMAXDEPTH)
151 else if ((newsize *= 2) > YYMAXDEPTH)
152 newsize = YYMAXDEPTH;
154 i = (int) (data->s_mark - data->s_base);
155 newss = (YYINT *)realloc(data->s_base, newsize * sizeof(*newss));
159 data->s_base = newss;
160 data->s_mark = newss + i;
162 newvs = (YYSTYPE *)realloc(data->l_base, newsize * sizeof(*newvs));
166 data->l_base = newvs;
167 data->l_mark = newvs + i;
169 data->stacksize = newsize;
170 data->s_last = data->s_base + newsize - 1;
174 #if YYPURE || defined(YY_NO_LEAKS)
175 static void yyfreestack(YYSTACKDATA *data)
179 memset(data, 0, sizeof(*data));
182 #define yyfreestack(data) /* nothing */
185 #define YYABORT goto yyabort
186 #define YYREJECT goto yyabort
187 #define YYACCEPT goto yyaccept
188 #define YYERROR goto yyerrlab
193 int yym, yyn, yystate;
197 if ((yys = getenv("YYDEBUG")) != 0)
200 if (yyn >= '0' && yyn <= '9')
213 memset(&yystack, 0, sizeof(yystack));
216 if (yystack.s_base == NULL && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
217 yystack.s_mark = yystack.s_base;
218 yystack.l_mark = yystack.l_base;
223 if ((yyn = yydefred[yystate]) != 0) goto yyreduce;
227 if (yychar < 0) yychar = YYEOF;
231 if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
232 printf("%sdebug: state %d, reading %d (%s)\n",
233 YYPREFIX, yystate, yychar, yys);
237 if (((yyn = yysindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
238 yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
242 printf("%sdebug: state %d, shifting to state %d\n",
243 YYPREFIX, yystate, yytable[yyn]);
245 if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
246 yystate = yytable[yyn];
247 *++yystack.s_mark = yytable[yyn];
248 *++yystack.l_mark = yylval;
250 if (yyerrflag > 0) --yyerrflag;
253 if (((yyn = yyrindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
254 yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
259 if (yyerrflag != 0) goto yyinrecovery;
261 YYERROR_CALL("syntax error");
263 goto yyerrlab; /* redundant goto avoids 'unused label' warning */
273 if (((yyn = yysindex[*yystack.s_mark]) != 0) && (yyn += YYERRCODE) >= 0 &&
274 yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) YYERRCODE)
278 printf("%sdebug: state %d, error recovery shifting\
279 to state %d\n", YYPREFIX, *yystack.s_mark, yytable[yyn]);
281 if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
282 yystate = yytable[yyn];
283 *++yystack.s_mark = yytable[yyn];
284 *++yystack.l_mark = yylval;
291 printf("%sdebug: error recovery discarding state %d\n",
292 YYPREFIX, *yystack.s_mark);
294 if (yystack.s_mark <= yystack.s_base) goto yyabort;
302 if (yychar == YYEOF) goto yyabort;
306 if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
307 printf("%sdebug: state %d, error recovery discards token %d (%s)\n",
308 YYPREFIX, yystate, yychar, yys);
318 printf("%sdebug: state %d, reducing by rule %d (%s)\n",
319 YYPREFIX, yystate, yyn, yyrule[yyn]);
323 yyval = yystack.l_mark[1-yym];
325 memset(&yyval, 0, sizeof yyval);
330 yystack.s_mark -= yym;
331 yystate = *yystack.s_mark;
332 yystack.l_mark -= yym;
334 if (yystate == 0 && yym == 0)
338 printf("%sdebug: after reduction, shifting from state 0 to\
339 state %d\n", YYPREFIX, YYFINAL);
342 *++yystack.s_mark = YYFINAL;
343 *++yystack.l_mark = yyval;
347 if (yychar < 0) yychar = YYEOF;
351 if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
352 printf("%sdebug: state %d, reading %d (%s)\n",
353 YYPREFIX, YYFINAL, yychar, yys);
357 if (yychar == YYEOF) goto yyaccept;
360 if (((yyn = yygindex[yym]) != 0) && (yyn += yystate) >= 0 &&
361 yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yystate)
362 yystate = yytable[yyn];
364 yystate = yydgoto[yym];
367 printf("%sdebug: after reduction, shifting from state %d \
368 to state %d\n", YYPREFIX, *yystack.s_mark, yystate);
370 if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
371 *++yystack.s_mark = (YYINT) yystate;
372 *++yystack.l_mark = yyval;
376 YYERROR_CALL("yacc stack overflow");
379 yyfreestack(&yystack);
383 yyfreestack(&yystack);