]> git.saurik.com Git - wxWidgets.git/blame - src/common/dosyacc.c
Added IsTopLevel() as a virtual function.
[wxWidgets.git] / src / common / dosyacc.c
CommitLineData
2bda0e17
KB
1#ifndef lint
2static char yysccsid[] = "@(#)yaccpar 1.7 (Berkeley) 09/09/90";
3#endif
4#define YYBYACC 1
5#line 2 "parser.y"
6#include "string.h"
004fd0c8 7#if defined(_MSC_VER) || defined(__VISAGECPP__)
b8c631bb
JS
8#include <io.h>
9#endif
2bda0e17
KB
10#include "wx/expr.h"
11
12#ifndef __EXTERN_C__
13#define __EXTERN_C__ 1
14#endif
15
16#if defined(__cplusplus) || defined(__STDC__)
17#if defined(__cplusplus) && defined(__EXTERN_C__)
18extern "C" {
19#endif
20#endif
21int yylex(void);
22int yylook(void);
23int yywrap(void);
24int yyback(int *, int);
25
26/* You may need to put /DLEX_SCANNER in your makefile
27 * if you're using LEX!
2bda0e17
KB
28 */
29#ifdef LEX_SCANNER
30/* int yyoutput(int); */
31void yyoutput(int);
32#else
33void yyoutput(int);
34#endif
35
36#if defined(__cplusplus) || defined(__STDC__)
37#if defined(__cplusplus) && defined(__EXTERN_C__)
38}
39#endif
40#endif
41#line 36 "parser.y"
42typedef union {
43 char *s;
44/* struct pexpr *expr; */
45} YYSTYPE;
46#line 44 "y_tab.c"
47#define INTEGER 1
48#define WORD 2
49#define STRING 3
50#define PERIOD 13
51#define OPEN 4
52#define CLOSE 5
53#define COMMA 6
54#define NEWLINE 7
55#define ERROR 8
56#define OPEN_SQUARE 9
57#define CLOSE_SQUARE 10
58#define EQUALS 11
59#define EXP 14
60#define YYERRCODE 256
61short yylhs[] = { -1,
62 0, 0, 1, 1, 1, 2, 2, 2, 3, 3,
63 3, 4, 4, 5, 5, 5, 5, 5, 5, 5,
64};
65short yylen[] = { 2,
66 0, 2, 2, 2, 2, 4, 2, 3, 0, 1,
67 3, 3, 1, 1, 1, 1, 3, 3, 5, 1,
68};
69short yydefred[] = { 1,
70 0, 0, 0, 0, 2, 0, 5, 3, 0, 0,
71 0, 15, 7, 20, 0, 0, 13, 4, 0, 0,
72 0, 0, 8, 0, 6, 0, 18, 0, 12, 11,
73 0, 19,
74};
75short yydgoto[] = { 1,
76 5, 14, 15, 16, 17,
77};
78short yysindex[] = { 0,
79 -2, 9, 2, 1, 0, 10, 0, 0, 11, -5,
80 17, 0, 0, 0, 14, -1, 0, 0, 33, 38,
81 41, 16, 0, 11, 0, 29, 0, 40, 0, 0,
82 44, 0,
83};
84short yyrindex[] = { 0,
85 0, 0, 0, 0, 0, 0, 0, 0, 42, 21,
86 24, 0, 0, 0, 0, 30, 0, 0, 0, 0,
87 0, 0, 0, 31, 0, 27, 0, 24, 0, 0,
88 0, 0,
89};
90short yygindex[] = { 0,
91 0, 45, -8, 0, 26,
92};
93#define YYTABLESIZE 254
94short yytable[] = { 3,
95 19, 10, 11, 12, 24, 9, 4, 20, 21, 4,
96 13, 10, 11, 12, 8, 30, 10, 28, 12, 4,
97 9, 7, 18, 23, 4, 16, 16, 22, 14, 14,
98 16, 17, 17, 14, 10, 9, 17, 25, 26, 10,
99 9, 27, 31, 9, 32, 6, 9, 29, 0, 0,
100 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
101 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
102 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
103 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
104 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
105 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
106 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
107 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
108 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
109 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
110 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
111 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
112 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
113 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
114 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
115 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
116 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
117 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
118 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
119 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
120 0, 0, 0, 2,
121};
122short yycheck[] = { 2,
123 9, 1, 2, 3, 6, 4, 9, 13, 14, 9,
124 10, 1, 2, 3, 13, 24, 1, 2, 3, 9,
125 4, 13, 13, 10, 9, 5, 6, 11, 5, 6,
126 10, 5, 6, 10, 5, 5, 10, 5, 1, 10,
127 10, 1, 14, 4, 1, 1, 5, 22, -1, -1,
128 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
129 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
130 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
131 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
132 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
133 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
134 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
135 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
136 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
137 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
138 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
139 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
140 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
141 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
142 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
143 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
144 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
145 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
146 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
147 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
148 -1, -1, -1, 256,
149};
150#define YYFINAL 1
151#ifndef YYDEBUG
152#define YYDEBUG 0
153#endif
154#define YYMAXTOKEN 14
155#if YYDEBUG
156char *yyname[] = {
157"end-of-file","INTEGER","WORD","STRING","OPEN","CLOSE","COMMA","NEWLINE",
158"ERROR","OPEN_SQUARE","CLOSE_SQUARE","EQUALS",0,"PERIOD","EXP",
159};
160char *yyrule[] = {
161"$accept : commands",
162"commands :",
163"commands : commands command",
164"command : WORD PERIOD",
165"command : expr PERIOD",
166"command : error PERIOD",
167"expr : WORD OPEN arglist CLOSE",
168"expr : OPEN_SQUARE CLOSE_SQUARE",
169"expr : OPEN_SQUARE arglist CLOSE_SQUARE",
170"arglist :",
171"arglist : arg",
172"arglist : arg COMMA arglist",
173"arg : WORD EQUALS arg1",
174"arg : arg1",
175"arg1 : WORD",
176"arg1 : STRING",
177"arg1 : INTEGER",
178"arg1 : INTEGER PERIOD INTEGER",
179"arg1 : INTEGER EXP INTEGER",
180"arg1 : INTEGER PERIOD INTEGER EXP INTEGER",
181"arg1 : expr",
182};
183#endif
184#define yyclearin (yychar=(-1))
185#define yyerrok (yyerrflag=0)
186#ifdef YYSTACKSIZE
187#ifndef YYMAXDEPTH
188#define YYMAXDEPTH YYSTACKSIZE
189#endif
190#else
191#ifdef YYMAXDEPTH
192#define YYSTACKSIZE YYMAXDEPTH
193#else
194#define YYSTACKSIZE 600
195#define YYMAXDEPTH 600
196#endif
197#endif
198int yydebug;
199int yynerrs;
200int yyerrflag;
201int yychar;
202short *yyssp;
203YYSTYPE *yyvsp;
204YYSTYPE yyval;
205YYSTYPE yylval;
206short yyss[YYSTACKSIZE];
207YYSTYPE yyvs[YYSTACKSIZE];
208#define yystacksize YYSTACKSIZE
209#line 118 "parser.y"
210
a367b9b3
JS
211#ifdef IDE_INVOKED
212#include "../common/doslex.c"
213#else
2bda0e17 214#include "../common/lex_yy.c"
a367b9b3 215#endif
2bda0e17
KB
216
217/*
218void yyerror(s)
219char *s;
220{
221 syntax_error(s);
222}
223*/
224
225/* Ansi prototype. If this doesn't work for you... uncomment
226 the above instead.
227 */
228
229void yyerror(char *s)
230{
231 syntax_error(s);
232}
233
234/*
235 * Unfortunately, my DOS version of FLEX
236 * requires yywrap to be #def'ed, whereas
237 * the UNIX flex expects a proper function.
238 */
239
240/* Not sure if __SC__ is the appropriate thing
241 * to test
242 */
243
244#ifndef __SC__
245#ifdef USE_DEFINE
246#ifndef yywrap
247#define yywrap() 1
248#endif
249#else
250int yywrap() { return 1; }
251#endif
252#endif
253#line 247 "y_tab.c"
254#define YYABORT goto yyabort
255#define YYACCEPT goto yyaccept
256#define YYERROR goto yyerrlab
257int
258yyparse()
259{
260 register int yym, yyn, yystate;
261#if YYDEBUG
262 register char *yys;
263 extern char *getenv();
264
004fd0c8
DW
265 yys = getenv("YYDEBUG");
266 if (yys)
2bda0e17
KB
267 {
268 yyn = *yys;
269 if (yyn >= '0' && yyn <= '9')
270 yydebug = yyn - '0';
271 }
272#endif
273
274 yynerrs = 0;
275 yyerrflag = 0;
276 yychar = (-1);
277
278 yyssp = yyss;
279 yyvsp = yyvs;
280 *yyssp = yystate = 0;
281
282yyloop:
004fd0c8
DW
283 yyn = yydefred[yystate];
284 if (yyn != 0) goto yyreduce;
2bda0e17
KB
285 if (yychar < 0)
286 {
287 if ((yychar = yylex()) < 0) yychar = 0;
288#if YYDEBUG
289 if (yydebug)
290 {
291 yys = 0;
292 if (yychar <= YYMAXTOKEN) yys = yyname[yychar];
293 if (!yys) yys = "illegal-symbol";
294 printf("yydebug: state %d, reading %d (%s)\n", yystate,
295 yychar, yys);
296 }
297#endif
298 }
299 if ((yyn = yysindex[yystate]) && (yyn += yychar) >= 0 &&
300 yyn <= YYTABLESIZE && yycheck[yyn] == yychar)
301 {
302#if YYDEBUG
303 if (yydebug)
304 printf("yydebug: state %d, shifting to state %d\n",
305 yystate, yytable[yyn]);
306#endif
307 if (yyssp >= yyss + yystacksize - 1)
308 {
309 goto yyoverflow;
310 }
311 *++yyssp = yystate = yytable[yyn];
312 *++yyvsp = yylval;
313 yychar = (-1);
314 if (yyerrflag > 0) --yyerrflag;
315 goto yyloop;
316 }
317 if ((yyn = yyrindex[yystate]) && (yyn += yychar) >= 0 &&
318 yyn <= YYTABLESIZE && yycheck[yyn] == yychar)
319 {
320 yyn = yytable[yyn];
321 goto yyreduce;
322 }
323 if (yyerrflag) goto yyinrecovery;
324#ifdef lint
325 goto yynewerror;
326#endif
327yynewerror:
328 yyerror("syntax error");
329#ifdef lint
330 goto yyerrlab;
331#endif
332yyerrlab:
333 ++yynerrs;
334yyinrecovery:
335 if (yyerrflag < 3)
336 {
337 yyerrflag = 3;
338 for (;;)
339 {
340 if ((yyn = yysindex[*yyssp]) && (yyn += YYERRCODE) >= 0 &&
341 yyn <= YYTABLESIZE && yycheck[yyn] == YYERRCODE)
342 {
343#if YYDEBUG
344 if (yydebug)
345 printf("yydebug: state %d, error recovery shifting\
346 to state %d\n", *yyssp, yytable[yyn]);
347#endif
348 if (yyssp >= yyss + yystacksize - 1)
349 {
350 goto yyoverflow;
351 }
352 *++yyssp = yystate = yytable[yyn];
353 *++yyvsp = yylval;
354 goto yyloop;
355 }
356 else
357 {
358#if YYDEBUG
359 if (yydebug)
360 printf("yydebug: error recovery discarding state %d\n",
361 *yyssp);
362#endif
363 if (yyssp <= yyss) goto yyabort;
364 --yyssp;
365 --yyvsp;
366 }
367 }
368 }
369 else
370 {
371 if (yychar == 0) goto yyabort;
372#if YYDEBUG
373 if (yydebug)
374 {
375 yys = 0;
376 if (yychar <= YYMAXTOKEN) yys = yyname[yychar];
377 if (!yys) yys = "illegal-symbol";
378 printf("yydebug: state %d, error recovery discards token %d (%s)\n",
379 yystate, yychar, yys);
380 }
381#endif
382 yychar = (-1);
383 goto yyloop;
384 }
385yyreduce:
386#if YYDEBUG
387 if (yydebug)
388 printf("yydebug: state %d, reducing by rule %d (%s)\n",
389 yystate, yyn, yyrule[yyn]);
390#endif
391 yym = yylen[yyn];
392 yyval = yyvsp[1-yym];
393 switch (yyn)
394 {
395case 3:
396#line 68 "parser.y"
5b077d48 397{process_command(proio_cons(wxmake_word(yyvsp[-1].s), NULL)); free(yyvsp[-1].s);}
2bda0e17
KB
398break;
399case 4:
400#line 70 "parser.y"
401{process_command(yyvsp[-1].s);}
402break;
403case 5:
404#line 72 "parser.y"
405{syntax_error("Unrecognized command.");}
406break;
407case 6:
408#line 76 "parser.y"
5b077d48 409{yyval.s = proio_cons(wxmake_word(yyvsp[-3].s), yyvsp[-1].s); free(yyvsp[-3].s);}
2bda0e17
KB
410break;
411case 7:
412#line 78 "parser.y"
413{yyval.s = proio_cons(NULL, NULL);}
414break;
415case 8:
416#line 80 "parser.y"
417{yyval.s = yyvsp[-1].s; }
418break;
419case 9:
420#line 84 "parser.y"
421{yyval.s = NULL;}
422break;
423case 10:
424#line 86 "parser.y"
425{yyval.s = proio_cons(yyvsp[0].s, NULL);}
426break;
427case 11:
428#line 89 "parser.y"
429{yyval.s = proio_cons(yyvsp[-2].s, yyvsp[0].s);}
430break;
431case 12:
432#line 93 "parser.y"
5b077d48 433{yyval.s = proio_cons(wxmake_word("="), proio_cons(wxmake_word(yyvsp[-2].s), proio_cons(yyvsp[0].s, NULL)));
2bda0e17
KB
434 free(yyvsp[-2].s); }
435break;
436case 13:
437#line 96 "parser.y"
438{yyval.s = yyvsp[0].s; }
439break;
440case 14:
441#line 99 "parser.y"
5b077d48 442{yyval.s = wxmake_word(yyvsp[0].s); free(yyvsp[0].s);}
2bda0e17
KB
443break;
444case 15:
445#line 101 "parser.y"
5b077d48 446{yyval.s = wxmake_string(yyvsp[0].s); free(yyvsp[0].s);}
2bda0e17
KB
447break;
448case 16:
449#line 103 "parser.y"
5b077d48 450{yyval.s = wxmake_integer(yyvsp[0].s); free(yyvsp[0].s);}
2bda0e17
KB
451break;
452case 17:
453#line 105 "parser.y"
5b077d48 454{yyval.s = wxmake_real(yyvsp[-2].s, yyvsp[0].s); free(yyvsp[-2].s); free(yyvsp[0].s); }
2bda0e17
KB
455break;
456case 18:
457#line 107 "parser.y"
5b077d48 458{yyval.s = wxmake_exp(yyvsp[-2].s, yyvsp[0].s); free(yyvsp[-2].s); free(yyvsp[0].s); }
2bda0e17
KB
459break;
460case 19:
461#line 110 "parser.y"
5b077d48 462{yyval.s = wxmake_exp2(yyvsp[-4].s, yyvsp[-2].s, yyvsp[0].s); free(yyvsp[-4].s); free(yyvsp[-2].s);
2bda0e17
KB
463 free(yyvsp[0].s); }
464break;
465case 20:
466#line 114 "parser.y"
467{yyval.s = yyvsp[0].s;}
468break;
469#line 461 "y_tab.c"
470 }
471 yyssp -= yym;
472 yystate = *yyssp;
473 yyvsp -= yym;
474 yym = yylhs[yyn];
475 if (yystate == 0 && yym == 0)
476 {
477#if YYDEBUG
478 if (yydebug)
479 printf("yydebug: after reduction, shifting from state 0 to\
480 state %d\n", YYFINAL);
481#endif
482 yystate = YYFINAL;
483 *++yyssp = YYFINAL;
484 *++yyvsp = yyval;
485 if (yychar < 0)
486 {
487 if ((yychar = yylex()) < 0) yychar = 0;
488#if YYDEBUG
489 if (yydebug)
490 {
491 yys = 0;
492 if (yychar <= YYMAXTOKEN) yys = yyname[yychar];
493 if (!yys) yys = "illegal-symbol";
494 printf("yydebug: state %d, reading %d (%s)\n",
495 YYFINAL, yychar, yys);
496 }
497#endif
498 }
499 if (yychar == 0) goto yyaccept;
500 goto yyloop;
501 }
502 if ((yyn = yygindex[yym]) && (yyn += yystate) >= 0 &&
503 yyn <= YYTABLESIZE && yycheck[yyn] == yystate)
504 yystate = yytable[yyn];
505 else
506 yystate = yydgoto[yym];
507#if YYDEBUG
508 if (yydebug)
509 printf("yydebug: after reduction, shifting from state %d \
510to state %d\n", *yyssp, yystate);
511#endif
512 if (yyssp >= yyss + yystacksize - 1)
513 {
514 goto yyoverflow;
515 }
516 *++yyssp = yystate;
517 *++yyvsp = yyval;
518 goto yyloop;
519yyoverflow:
520 yyerror("yacc stack overflow");
521yyabort:
522 return (1);
523yyaccept:
524 return (0);
525}