13e12c5d1SDavid du Colombier #include <stdio.h>
23e12c5d1SDavid du Colombier #include "awk.h"
33e12c5d1SDavid du Colombier #include "y.tab.h"
43e12c5d1SDavid du Colombier
5*7dd7cddfSDavid du Colombier static char *printname[92] = {
6*7dd7cddfSDavid du Colombier (char *) "FIRSTTOKEN", /* 57346 */
7*7dd7cddfSDavid du Colombier (char *) "PROGRAM", /* 57347 */
8*7dd7cddfSDavid du Colombier (char *) "PASTAT", /* 57348 */
9*7dd7cddfSDavid du Colombier (char *) "PASTAT2", /* 57349 */
10*7dd7cddfSDavid du Colombier (char *) "XBEGIN", /* 57350 */
11*7dd7cddfSDavid du Colombier (char *) "XEND", /* 57351 */
12*7dd7cddfSDavid du Colombier (char *) "NL", /* 57352 */
13*7dd7cddfSDavid du Colombier (char *) "ARRAY", /* 57353 */
14*7dd7cddfSDavid du Colombier (char *) "MATCH", /* 57354 */
15*7dd7cddfSDavid du Colombier (char *) "NOTMATCH", /* 57355 */
16*7dd7cddfSDavid du Colombier (char *) "MATCHOP", /* 57356 */
17*7dd7cddfSDavid du Colombier (char *) "FINAL", /* 57357 */
18*7dd7cddfSDavid du Colombier (char *) "DOT", /* 57358 */
19*7dd7cddfSDavid du Colombier (char *) "ALL", /* 57359 */
20*7dd7cddfSDavid du Colombier (char *) "CCL", /* 57360 */
21*7dd7cddfSDavid du Colombier (char *) "NCCL", /* 57361 */
22*7dd7cddfSDavid du Colombier (char *) "CHAR", /* 57362 */
23*7dd7cddfSDavid du Colombier (char *) "OR", /* 57363 */
24*7dd7cddfSDavid du Colombier (char *) "STAR", /* 57364 */
25*7dd7cddfSDavid du Colombier (char *) "QUEST", /* 57365 */
26*7dd7cddfSDavid du Colombier (char *) "PLUS", /* 57366 */
27*7dd7cddfSDavid du Colombier (char *) "AND", /* 57367 */
28*7dd7cddfSDavid du Colombier (char *) "BOR", /* 57368 */
29*7dd7cddfSDavid du Colombier (char *) "APPEND", /* 57369 */
30*7dd7cddfSDavid du Colombier (char *) "EQ", /* 57370 */
31*7dd7cddfSDavid du Colombier (char *) "GE", /* 57371 */
32*7dd7cddfSDavid du Colombier (char *) "GT", /* 57372 */
33*7dd7cddfSDavid du Colombier (char *) "LE", /* 57373 */
34*7dd7cddfSDavid du Colombier (char *) "LT", /* 57374 */
35*7dd7cddfSDavid du Colombier (char *) "NE", /* 57375 */
36*7dd7cddfSDavid du Colombier (char *) "IN", /* 57376 */
37*7dd7cddfSDavid du Colombier (char *) "ARG", /* 57377 */
38*7dd7cddfSDavid du Colombier (char *) "BLTIN", /* 57378 */
39*7dd7cddfSDavid du Colombier (char *) "BREAK", /* 57379 */
40*7dd7cddfSDavid du Colombier (char *) "CLOSE", /* 57380 */
41*7dd7cddfSDavid du Colombier (char *) "CONTINUE", /* 57381 */
42*7dd7cddfSDavid du Colombier (char *) "DELETE", /* 57382 */
43*7dd7cddfSDavid du Colombier (char *) "DO", /* 57383 */
44*7dd7cddfSDavid du Colombier (char *) "EXIT", /* 57384 */
45*7dd7cddfSDavid du Colombier (char *) "FOR", /* 57385 */
46*7dd7cddfSDavid du Colombier (char *) "FUNC", /* 57386 */
47*7dd7cddfSDavid du Colombier (char *) "SUB", /* 57387 */
48*7dd7cddfSDavid du Colombier (char *) "GSUB", /* 57388 */
49*7dd7cddfSDavid du Colombier (char *) "IF", /* 57389 */
50*7dd7cddfSDavid du Colombier (char *) "INDEX", /* 57390 */
51*7dd7cddfSDavid du Colombier (char *) "LSUBSTR", /* 57391 */
52*7dd7cddfSDavid du Colombier (char *) "MATCHFCN", /* 57392 */
53*7dd7cddfSDavid du Colombier (char *) "NEXT", /* 57393 */
54*7dd7cddfSDavid du Colombier (char *) "NEXTFILE", /* 57394 */
55*7dd7cddfSDavid du Colombier (char *) "ADD", /* 57395 */
56*7dd7cddfSDavid du Colombier (char *) "MINUS", /* 57396 */
57*7dd7cddfSDavid du Colombier (char *) "MULT", /* 57397 */
58*7dd7cddfSDavid du Colombier (char *) "DIVIDE", /* 57398 */
59*7dd7cddfSDavid du Colombier (char *) "MOD", /* 57399 */
60*7dd7cddfSDavid du Colombier (char *) "ASSIGN", /* 57400 */
61*7dd7cddfSDavid du Colombier (char *) "ASGNOP", /* 57401 */
62*7dd7cddfSDavid du Colombier (char *) "ADDEQ", /* 57402 */
63*7dd7cddfSDavid du Colombier (char *) "SUBEQ", /* 57403 */
64*7dd7cddfSDavid du Colombier (char *) "MULTEQ", /* 57404 */
65*7dd7cddfSDavid du Colombier (char *) "DIVEQ", /* 57405 */
66*7dd7cddfSDavid du Colombier (char *) "MODEQ", /* 57406 */
67*7dd7cddfSDavid du Colombier (char *) "POWEQ", /* 57407 */
68*7dd7cddfSDavid du Colombier (char *) "PRINT", /* 57408 */
69*7dd7cddfSDavid du Colombier (char *) "PRINTF", /* 57409 */
70*7dd7cddfSDavid du Colombier (char *) "SPRINTF", /* 57410 */
71*7dd7cddfSDavid du Colombier (char *) "ELSE", /* 57411 */
72*7dd7cddfSDavid du Colombier (char *) "INTEST", /* 57412 */
73*7dd7cddfSDavid du Colombier (char *) "CONDEXPR", /* 57413 */
74*7dd7cddfSDavid du Colombier (char *) "POSTINCR", /* 57414 */
75*7dd7cddfSDavid du Colombier (char *) "PREINCR", /* 57415 */
76*7dd7cddfSDavid du Colombier (char *) "POSTDECR", /* 57416 */
77*7dd7cddfSDavid du Colombier (char *) "PREDECR", /* 57417 */
78*7dd7cddfSDavid du Colombier (char *) "VAR", /* 57418 */
79*7dd7cddfSDavid du Colombier (char *) "IVAR", /* 57419 */
80*7dd7cddfSDavid du Colombier (char *) "VARNF", /* 57420 */
81*7dd7cddfSDavid du Colombier (char *) "CALL", /* 57421 */
82*7dd7cddfSDavid du Colombier (char *) "NUMBER", /* 57422 */
83*7dd7cddfSDavid du Colombier (char *) "STRING", /* 57423 */
84*7dd7cddfSDavid du Colombier (char *) "REGEXPR", /* 57424 */
85*7dd7cddfSDavid du Colombier (char *) "GETLINE", /* 57425 */
86*7dd7cddfSDavid du Colombier (char *) "RETURN", /* 57426 */
87*7dd7cddfSDavid du Colombier (char *) "SPLIT", /* 57427 */
88*7dd7cddfSDavid du Colombier (char *) "SUBSTR", /* 57428 */
89*7dd7cddfSDavid du Colombier (char *) "WHILE", /* 57429 */
90*7dd7cddfSDavid du Colombier (char *) "CAT", /* 57430 */
91*7dd7cddfSDavid du Colombier (char *) "NOT", /* 57431 */
92*7dd7cddfSDavid du Colombier (char *) "UMINUS", /* 57432 */
93*7dd7cddfSDavid du Colombier (char *) "POWER", /* 57433 */
94*7dd7cddfSDavid du Colombier (char *) "DECR", /* 57434 */
95*7dd7cddfSDavid du Colombier (char *) "INCR", /* 57435 */
96*7dd7cddfSDavid du Colombier (char *) "INDIRECT", /* 57436 */
97*7dd7cddfSDavid du Colombier (char *) "LASTTOKEN", /* 57437 */
983e12c5d1SDavid du Colombier };
993e12c5d1SDavid du Colombier
1003e12c5d1SDavid du Colombier
1013e12c5d1SDavid du Colombier Cell *(*proctab[92])(Node **, int) = {
1023e12c5d1SDavid du Colombier nullproc, /* FIRSTTOKEN */
1033e12c5d1SDavid du Colombier program, /* PROGRAM */
1043e12c5d1SDavid du Colombier pastat, /* PASTAT */
1053e12c5d1SDavid du Colombier dopa2, /* PASTAT2 */
1063e12c5d1SDavid du Colombier nullproc, /* XBEGIN */
1073e12c5d1SDavid du Colombier nullproc, /* XEND */
1083e12c5d1SDavid du Colombier nullproc, /* NL */
1093e12c5d1SDavid du Colombier array, /* ARRAY */
1103e12c5d1SDavid du Colombier matchop, /* MATCH */
1113e12c5d1SDavid du Colombier matchop, /* NOTMATCH */
1123e12c5d1SDavid du Colombier nullproc, /* MATCHOP */
1133e12c5d1SDavid du Colombier nullproc, /* FINAL */
1143e12c5d1SDavid du Colombier nullproc, /* DOT */
1153e12c5d1SDavid du Colombier nullproc, /* ALL */
1163e12c5d1SDavid du Colombier nullproc, /* CCL */
1173e12c5d1SDavid du Colombier nullproc, /* NCCL */
1183e12c5d1SDavid du Colombier nullproc, /* CHAR */
1193e12c5d1SDavid du Colombier nullproc, /* OR */
1203e12c5d1SDavid du Colombier nullproc, /* STAR */
1213e12c5d1SDavid du Colombier nullproc, /* QUEST */
1223e12c5d1SDavid du Colombier nullproc, /* PLUS */
1233e12c5d1SDavid du Colombier boolop, /* AND */
1243e12c5d1SDavid du Colombier boolop, /* BOR */
1253e12c5d1SDavid du Colombier nullproc, /* APPEND */
1263e12c5d1SDavid du Colombier relop, /* EQ */
1273e12c5d1SDavid du Colombier relop, /* GE */
1283e12c5d1SDavid du Colombier relop, /* GT */
1293e12c5d1SDavid du Colombier relop, /* LE */
1303e12c5d1SDavid du Colombier relop, /* LT */
1313e12c5d1SDavid du Colombier relop, /* NE */
1323e12c5d1SDavid du Colombier instat, /* IN */
1333e12c5d1SDavid du Colombier arg, /* ARG */
1343e12c5d1SDavid du Colombier bltin, /* BLTIN */
1353e12c5d1SDavid du Colombier jump, /* BREAK */
1363e12c5d1SDavid du Colombier closefile, /* CLOSE */
1373e12c5d1SDavid du Colombier jump, /* CONTINUE */
138*7dd7cddfSDavid du Colombier awkdelete, /* DELETE */
1393e12c5d1SDavid du Colombier dostat, /* DO */
1403e12c5d1SDavid du Colombier jump, /* EXIT */
1413e12c5d1SDavid du Colombier forstat, /* FOR */
1423e12c5d1SDavid du Colombier nullproc, /* FUNC */
1433e12c5d1SDavid du Colombier sub, /* SUB */
1443e12c5d1SDavid du Colombier gsub, /* GSUB */
1453e12c5d1SDavid du Colombier ifstat, /* IF */
1463e12c5d1SDavid du Colombier sindex, /* INDEX */
1473e12c5d1SDavid du Colombier nullproc, /* LSUBSTR */
1483e12c5d1SDavid du Colombier matchop, /* MATCHFCN */
1493e12c5d1SDavid du Colombier jump, /* NEXT */
150*7dd7cddfSDavid du Colombier jump, /* NEXTFILE */
1513e12c5d1SDavid du Colombier arith, /* ADD */
1523e12c5d1SDavid du Colombier arith, /* MINUS */
1533e12c5d1SDavid du Colombier arith, /* MULT */
1543e12c5d1SDavid du Colombier arith, /* DIVIDE */
1553e12c5d1SDavid du Colombier arith, /* MOD */
1563e12c5d1SDavid du Colombier assign, /* ASSIGN */
1573e12c5d1SDavid du Colombier nullproc, /* ASGNOP */
1583e12c5d1SDavid du Colombier assign, /* ADDEQ */
1593e12c5d1SDavid du Colombier assign, /* SUBEQ */
1603e12c5d1SDavid du Colombier assign, /* MULTEQ */
1613e12c5d1SDavid du Colombier assign, /* DIVEQ */
1623e12c5d1SDavid du Colombier assign, /* MODEQ */
1633e12c5d1SDavid du Colombier assign, /* POWEQ */
1643e12c5d1SDavid du Colombier printstat, /* PRINT */
165*7dd7cddfSDavid du Colombier awkprintf, /* PRINTF */
166*7dd7cddfSDavid du Colombier awksprintf, /* SPRINTF */
1673e12c5d1SDavid du Colombier nullproc, /* ELSE */
1683e12c5d1SDavid du Colombier intest, /* INTEST */
1693e12c5d1SDavid du Colombier condexpr, /* CONDEXPR */
1703e12c5d1SDavid du Colombier incrdecr, /* POSTINCR */
1713e12c5d1SDavid du Colombier incrdecr, /* PREINCR */
1723e12c5d1SDavid du Colombier incrdecr, /* POSTDECR */
1733e12c5d1SDavid du Colombier incrdecr, /* PREDECR */
1743e12c5d1SDavid du Colombier nullproc, /* VAR */
1753e12c5d1SDavid du Colombier nullproc, /* IVAR */
1763e12c5d1SDavid du Colombier getnf, /* VARNF */
1773e12c5d1SDavid du Colombier call, /* CALL */
1783e12c5d1SDavid du Colombier nullproc, /* NUMBER */
1793e12c5d1SDavid du Colombier nullproc, /* STRING */
1803e12c5d1SDavid du Colombier nullproc, /* REGEXPR */
1813e12c5d1SDavid du Colombier getline, /* GETLINE */
1823e12c5d1SDavid du Colombier jump, /* RETURN */
1833e12c5d1SDavid du Colombier split, /* SPLIT */
1843e12c5d1SDavid du Colombier substr, /* SUBSTR */
1853e12c5d1SDavid du Colombier whilestat, /* WHILE */
1863e12c5d1SDavid du Colombier cat, /* CAT */
1873e12c5d1SDavid du Colombier boolop, /* NOT */
1883e12c5d1SDavid du Colombier arith, /* UMINUS */
1893e12c5d1SDavid du Colombier arith, /* POWER */
1903e12c5d1SDavid du Colombier nullproc, /* DECR */
1913e12c5d1SDavid du Colombier nullproc, /* INCR */
1923e12c5d1SDavid du Colombier indirect, /* INDIRECT */
1933e12c5d1SDavid du Colombier nullproc, /* LASTTOKEN */
1943e12c5d1SDavid du Colombier };
1953e12c5d1SDavid du Colombier
tokname(int n)196*7dd7cddfSDavid du Colombier char *tokname(int n)
1973e12c5d1SDavid du Colombier {
198*7dd7cddfSDavid du Colombier static char buf[100];
1993e12c5d1SDavid du Colombier
2003e12c5d1SDavid du Colombier if (n < FIRSTTOKEN || n > LASTTOKEN) {
2013e12c5d1SDavid du Colombier sprintf(buf, "token %d", n);
2023e12c5d1SDavid du Colombier return buf;
2033e12c5d1SDavid du Colombier }
2043e12c5d1SDavid du Colombier return printname[n-FIRSTTOKEN];
2053e12c5d1SDavid du Colombier }
206