dono@killer.UUCP (09/24/87)
I am reposting this from an earlier posting by Mark H. Colburn a/o feb 1, 1987 Here is part two of the public domain yacc. Reposted by Don O'Connell --------------------------------- CUT HERE ----------------------------------- #! /bin/sh # This is a shell archive (part 2 of 2), meaning: # 1. Remove everything above the #! /bin/sh line. # 2. Save the resulting text in a file. # 3. Execute the file with /bin/sh (not csh). # # The following files will be created: # youtpt.c # y2imp.c # ydefin.c # ywract.c # yapack.c # yothrs.c # ywstat.c # ystin.c # system.h # ysumry.c # README # yg2gen.c # y4.h # ycpfir.c # yg2out.c # ycpres.c # y3.h # ygin.c # ymain.c # yprcft.c # ycpuni.c # ydfout.c # ywritm.c # yflset.c # yhdprd.c # yptitm.c # ycpycd.c # ygtnm.c # yskpcm.c # yosmry.c # y4imp.c # ynxti.c # ychfnd.c # yyless.c # yarout.c # yerror.c # ywarry.c # yfdtyp.c # yprlok.c # ystuni.c # yaoput.c # y3imp.c # ycstsh.c # ysmnam.c # yaryfl.c # ychcpy.c # yfnact.c # # Created by mark@ems (Mark H. Colburn) on Sun Feb 1 01:20:12 1987 # if test -f 'youtpt.c' then echo shar: will not over-write existing "'youtpt.c'" else echo extracting "'youtpt.c'" sed 's/^X//' >youtpt.c <<'SHAR_EOF' X#include "y3.h" X Xoutput() X{ X /* print the output for the states */ X X int i, k, c; X register struct wset *u, *v; X X fprintf( ftable, "short yyexca[] ={\n" ); X X SLOOP(i) X { X /* output the stuff for state i */ X nolook = !(tystate[i] == MUSTLOOKAHEAD); X closure(i); X /* output actions */ X nolook = 1; X aryfil( temp1, ntokens + nnonter + 1, 0 ); X WSLOOP(wsets, u) X { X c = *( u->pitem ); X if ( c > 1 && c < NTBASE && temp1[c] == 0 ) { X WSLOOP(u, v) X { X if ( c == *(v->pitem) ) X putitem( v->pitem + 1, (struct looksets *)0 ); X } X temp1[c] = state(c); X } else if ( c > NTBASE && temp1[ (c -= NTBASE) + ntokens ] == 0 ) { X temp1[ c+ntokens ] = amem[indgo[i]+c]; X } X } X X if ( i == 1 ) X temp1[1] = ACCEPTCODE; X X /* now, we have the shifts; look at the reductions */ X X lastred = 0; X WSLOOP(wsets, u) X { X c = *( u->pitem ); X if ( c <= 0 ) { X /* reduction */ X lastred = -c; X TLOOP(k) X { X if ( BIT(u->ws.lset, k) ) { X if ( temp1[k] == 0 ) X temp1[k] = c; X else if ( temp1[k] < 0 ) { X /* reduce/reduce conflict */ X if ( foutput != NULL ) X fprintf( foutput, X "\n%d: reduce/reduce conflict (red'ns %d and %d ) on %s", X i, -temp1[k], lastred, symnam(k) ); X if ( -temp1[k] > lastred ) X temp1[k] = -lastred; X ++zzrrconf; X } else { X /* potential shift/reduce conflict */ X precftn( lastred, k, i ); X } X } X } X } X } X wract(i); X } X X fprintf( ftable, "\t};\n" ); X X wdef( "YYNPROD", nprod ); X X} X X SHAR_EOF if test 1597 -ne "`wc -c < 'youtpt.c'`" then echo shar: error transmitting "'youtpt.c'" '(should have been 1597 characters)' fi chmod 644 youtpt.c fi if test -f 'y2imp.c' then echo shar: will not over-write existing "'y2imp.c'" else echo extracting "'y2imp.c'" sed 's/^X//' >y2imp.c <<'SHAR_EOF' X/* X * y2imp.c - impure date needed by routines pulled from y2.c X * X * HISTORY X */ X X#define y2imp YES X#include "dtxtrn.h" X X X/* communication variables between various I/O routines */ X Xchar *infile; /* input file name */ Xint numbval; /* value of an input number */ Xchar tokname[NAMESIZE]; /* input token name */ X X X/* storage of names */ X Xchar cnames[CNAMSZ]; /* token and nonterminal name storage */ Xint cnamsz = CNAMSZ; /* size of cnames */ Xchar *cnamp = cnames; /* place where next name is to be put in */ Xint ndefout = 3; /* number of defined symbols output */ X X X/* storage of types */ X Xint ntypes; /* number of types defined */ Xchar *typeset[NTYPES]; /* pointers to type tags */ X X X/* symbol tables for tokens and nonterminals */ X Xint ntokens = 0; Xstruct toksymb tokset[NTERMS]; Xint toklev[NTERMS]; Xint nnonter = -1; Xstruct ntsymb nontrst[NNONTERM]; Xint start; /* start symbol */ X X X/* assigned token type values */ X Xint extval = 0; X X X/* input and output file descriptors */ X XFILE *finput; /* yacc input file */ XFILE *faction; /* file for saving actions */ XFILE *fdefine; /* file for # defines */ XFILE *ftable; /* y.tab.c file */ XFILE *ftemp; /* tempfile to pass 2 */ XFILE *foutput; /* y.output file */ X X X/* storage for grammar rules */ X Xint mem0[MEMSIZE]; /* production storage */ Xint *mem = mem0; Xint nprod = 1; /* number of productions */ Xint *prdptr[NPROD]; /* pointers to descriptions of productions */ Xint levprd[NPROD]; /* precedence levels for the productions */ X X X/* Statics pulled from modules */ X Xint peekline; /* from gettok() */ SHAR_EOF if test 1586 -ne "`wc -c < 'y2imp.c'`" then echo shar: error transmitting "'y2imp.c'" '(should have been 1586 characters)' fi chmod 644 y2imp.c fi if test -f 'ydefin.c' then echo shar: will not over-write existing "'ydefin.c'" else echo extracting "'ydefin.c'" sed 's/^X//' >ydefin.c <<'SHAR_EOF' X#include "y2.h" X Xdefin( t, s ) Xregister char *s; X X{ X /* define s to be a terminal if t=0 X or a nonterminal if t=1 */ X X register val; X X if (t) { X if ( ++nnonter >= NNONTERM ) X error("too many nonterminals, limit %d", NNONTERM); X nontrst[nnonter].name = cstash(s); X return( NTBASE + nnonter ); X } X /* must be a token */ X if ( ++ntokens >= NTERMS ) X error("too many terminals, limit %d", NTERMS ); X tokset[ntokens].name = cstash(s); X X /* establish value for token */ X X if ( s[0] == ' ' && s[2] == '\0' ) /* single character literal */ X val = s[1]; X else if ( s[0] == ' ' && s[1] == '\\' ) { X /* escape sequence */ X if ( s[3] == '\0' ) { X /* single character escape sequence */ X switch ( s[2] ) { X /* character which is escaped */ X case 'n': X val = '\n'; X break; X case 'r': X val = '\r'; X break; X case 'b': X val = '\b'; X break; X case 't': X val = '\t'; X break; X case 'f': X val = '\f'; X break; X case '\'': X val = '\''; X break; X case '"': X val = '"'; X break; X case '\\': X val = '\\'; X break; X default: X error( "invalid escape" ); X } X } else if ( s[2] <= '7' && s[2] >= '0' ) { X /* \nnn sequence */ X if ( s[3] < '0' || s[3] > '7' || s[4] < '0' || X s[4] > '7' || s[5] != '\0' ) X error("illegal \\nnn construction" ); X val = 64 * s[2] + 8 * s[3] + s[4] - 73 * '0'; X if ( val == 0 ) X error( "'\\000' is illegal" ); X } X } else { X val = extval++; X } X tokset[ntokens].value = val; X toklev[ntokens] = 0; X return( ntokens ); X} X X SHAR_EOF if test 1550 -ne "`wc -c < 'ydefin.c'`" then echo shar: error transmitting "'ydefin.c'" '(should have been 1550 characters)' fi chmod 644 ydefin.c fi if test -f 'ywract.c' then echo shar: will not over-write existing "'ywract.c'" else echo extracting "'ywract.c'" sed 's/^X//' >ywract.c <<'SHAR_EOF' X#include "y3.h" X Xwract(i) X{ X /* output state i */ X /* temp1 has the actions, lastred the default */ X int p, p0, p1; X int ntimes, tred, count, j; X int flag; X X /* find the best choice for lastred */ X X lastred = 0; X ntimes = 0; X TLOOP(j) X { X if ( temp1[j] >= 0 ) X continue; X if ( temp1[j] + lastred == 0 ) X continue; X /* count the number of appearances of temp1[j] */ X count = 0; X tred = -temp1[j]; X levprd[tred] |= REDFLAG; X TLOOP(p) X { X if ( temp1[p] + tred == 0 ) X ++count; X } X if ( count > ntimes ) { X lastred = tred; X ntimes = count; X } X } X X /* for error recovery, arrange that, if there is a shift on the X /* error recovery token, `error', that the default be the error action */ X if ( temp1[1] > 0 ) X lastred = 0; X X /* clear out entries in temp1 which equal lastred */ X TLOOP(p) if ( temp1[p] + lastred == 0 ) X temp1[p] = 0; X X wrstate(i); X defact[i] = lastred; X X flag = 0; X TLOOP(p0) X { X if ( (p1 = temp1[p0]) != 0 ) { X if ( p1 < 0 ) { X p1 = -p1; X goto exc; X } else if ( p1 == ACCEPTCODE ) { X p1 = -1; X goto exc; X } else if ( p1 == ERRCODE ) { X p1 = 0; X goto exc; Xexc: X if ( flag++ == 0 ) X fprintf( ftable, "-1, %d,\n", i ); X fprintf( ftable, "\t%d, %d,\n", tokset[p0].value, p1 ); X ++zzexcp; X } else { X fprintf( ftemp, "%d,%d,", tokset[p0].value, p1 ); X ++zzacent; X } X } X } X if ( flag ) { X defact[i] = -2; X fprintf( ftable, "\t-2, %d,\n", lastred ); X } X fprintf( ftemp, "\n" ); X return; X} X X SHAR_EOF if test 1499 -ne "`wc -c < 'ywract.c'`" then echo shar: error transmitting "'ywract.c'" '(should have been 1499 characters)' fi chmod 644 ywract.c fi if test -f 'yapack.c' then echo shar: will not over-write existing "'yapack.c'" else echo extracting "'yapack.c'" sed 's/^X//' >yapack.c <<'SHAR_EOF' X/* X * yapack.c - X * X * HISTORY X * {1} 28-Aug-81 Bob Denny X * Modified to make debug code conditionally compile. X */ X X#include "y3.h" X X Xint apack(p, n ) Xint *p; X{ X /* pack state i from temp1 into amem */ X int off; X register *pp, *qq, *rr; X int *q, *r; X X /* X * we don't need to worry about checking because we we will only X * look entries known to be there... X */ X X /* eliminate leading and trailing 0's */ X X q = p + n; X for (pp = p, off = 0; *pp == 0 && pp <= q; ++pp, --off) X /* VOID */; X if (pp > q) X return (0); /* no actions */ X p = pp; X X /* now, find a place for the elements from p to q, inclusive */ X X r = &amem[ACTSIZE - 1]; X for (rr = amem; rr <= r; ++rr, ++off) { X /* try rr */ X for (qq = rr, pp = p; pp <= q; ++pp, ++qq) { X if (*pp != 0) { X if (*pp != *qq && *qq != 0) X goto nextk; X } X } X X /* we have found an acceptable k */ X X#ifdef debug X if (foutput != NULL) X fprintf(foutput, "off = %d, k = %d\n", off, rr - amem); X#endif X for (qq = rr, pp = p; pp <= q; ++pp, ++qq) { X if (*pp) { X if (qq > r) X error("action table overflow"); X if (qq > memp) X memp = qq; X *qq = *pp; X } X } X#ifdef debug X if (foutput != NULL) { X for (pp = amem; pp <= memp; pp += 10) { X fprintf(foutput, "\t"); X for (qq = pp; qq <= pp + 9; ++qq) X fprintf(foutput, "%d ", *qq); X fprintf(foutput, "\n"); X } X } X#endif X return (off); Xnextk: X ; X } X error("no space in action table"); X /* NOTREACHED */ X} X X SHAR_EOF if test 1450 -ne "`wc -c < 'yapack.c'`" then echo shar: error transmitting "'yapack.c'" '(should have been 1450 characters)' fi chmod 644 yapack.c fi if test -f 'yothrs.c' then echo shar: will not over-write existing "'yothrs.c'" else echo extracting "'yothrs.c'" sed 's/^X//' >yothrs.c <<'SHAR_EOF' X/* Edits: X * 06-Dec-80 Original code broken out of y1.c. X * 18-Dec-80 Add conditional code for Decus for tempfile deletion. X */ X X#include "y1.h" X Xint others() X{ X /* put out other arrays, copy the parsers */ X register c, i, j; X X finput = (FILE * )fopen(PARSER, "r"); X if (finput == (FILE * )NULL) X error("cannot find parser %s", PARSER); X X warray("yyr1", levprd, nprod); X X aryfil(temp1, nprod, 0); X PLOOP(1, i) temp1[i] = prdptr[i + 1] - prdptr[i] - 2; X warray("yyr2", temp1, nprod); X X aryfil(temp1, nstate, -1000); X TLOOP(i) { X for (j = tstates[i]; j != 0; j = mstates[j]) { X temp1[j] = tokset[i].value; X } X } X NTLOOP(i) { X for (j = ntstates[i]; j != 0; j = mstates[j]) { X temp1[j] = -i; X } X } X warray("yychk", temp1, nstate); X X warray("yydef", defact, nstate); X X /* copy parser text */ X X while ((c = unix_getc(finput)) != EOF) { X if (c == '$') { X if ((c = unix_getc(finput)) != 'A') X putc('$', ftable); X else { X /* copy actions */ X faction = fopen(ACTNAME, "r"); X if (faction == NULL) X error("cannot reopen action tempfile"); X while ((c = unix_getc(faction)) != EOF) X putc(c, ftable); X fclose(faction); X ZAPFILE(ACTNAME); X c = unix_getc(finput); X } X } X putc(c, ftable); X } X fclose(ftable); X} X X Xint unix_getc(iop) XFILE *iop; X{ X int c; X X c = getc(iop); X /* Stop on Control-Z */ X if (c == '\032') X return (EOF); X else X return (c); X} X X SHAR_EOF if test 1395 -ne "`wc -c < 'yothrs.c'`" then echo shar: error transmitting "'yothrs.c'" '(should have been 1395 characters)' fi chmod 644 yothrs.c fi if test -f 'ywstat.c' then echo shar: will not over-write existing "'ywstat.c'" else echo extracting "'ywstat.c'" sed 's/^X//' >ywstat.c <<'SHAR_EOF' X#include "y3.h" X Xwrstate(i) X{ X /* writes state i */ X register j0, j1; X register struct item *pp, *qq; X register struct wset *u; X X if ( foutput == NULL ) X return; X fprintf( foutput, "\nstate %d\n", i); X ITMLOOP(i, pp, qq) fprintf( foutput, "\t%s\n", writem(pp->pitem)); X if ( tystate[i] == MUSTLOOKAHEAD ) { X /* print out empty productions in closure */ X WSLOOP( wsets + (pstate[i+1] - pstate[i]), u ) X { X if ( *(u->pitem) < 0 ) X fprintf( foutput, "\t%s\n", writem(u->pitem) ); X } X } X X /* check for state equal to another */ X X TLOOP(j0) if ( (j1 = temp1[j0]) != 0 ) { X fprintf( foutput, "\n\t%s ", symnam(j0) ); X if ( j1 > 0 ) { X /* shift, error, or accept */ X if ( j1 == ACCEPTCODE ) X fprintf( foutput, "accept" ); X else if ( j1 == ERRCODE ) X fprintf( foutput, "error" ); X else X fprintf( foutput, "shift %d", j1 ); X } else X fprintf( foutput, "reduce %d", -j1 ); X } X X /* output the final production */ X X if ( lastred ) X fprintf( foutput, "\n\t. reduce %d\n\n", lastred ); X else X fprintf( foutput, "\n\t. error\n\n" ); X X /* now, output nonterminal actions */ X X j1 = ntokens; X for ( j0 = 1; j0 <= nnonter; ++j0 ) { X if ( temp1[++j1] ) X fprintf( foutput, "\t%s goto %d\n", symnam( j0 + NTBASE), temp1[j1] ); X } X X} X X Xwdef( s, n ) Xchar *s; X X{ X /* output a definition of s to the value n */ X fprintf( ftable, "# define %s %d\n", s, n ); X} X X SHAR_EOF if test 1388 -ne "`wc -c < 'ywstat.c'`" then echo shar: error transmitting "'ywstat.c'" '(should have been 1388 characters)' fi chmod 644 ywstat.c fi if test -f 'ystin.c' then echo shar: will not over-write existing "'ystin.c'" else echo extracting "'ystin.c'" sed 's/^X//' >ystin.c <<'SHAR_EOF' X#include "y4.h" X Xstin(i) X{ X register *r, *s, n, flag, j, *q1, *q2; X X greed[i] = 0; X X /* enter state i into the a array */ X X q2 = mem0 + yypact[i+1]; X q1 = mem0 + yypact[i]; X /* find an acceptable place */ X X for ( n = -maxoff; n < ACTSIZE; ++n ) { X X flag = 0; X for ( r = q1; r < q2; r += 2 ) { X if ( (s = *r + n + a ) < a ) X goto nextn; X if ( *s == 0 ) X ++flag; X else if ( *s != r[1] ) X goto nextn; X } X X /* check that the position equals another only if the states are identical */ X X for ( j = 0; j < nstate; ++j ) { X if ( pa[j] == n ) { X if ( flag ) X goto nextn; /* we have some disagreement */ X if ( yypact[j+1] + yypact[i] == yypact[j] + yypact[i+1] ) { X /* states are equal */ X pa[i] = n; X if ( adb > 1 ) X fprintf( ftable, "State %d: entry at %d equals state %d\n", X i, n, j ); X return; X } X goto nextn; /* we have some disagreement */ X } X } X X for ( r = q1; r < q2; r += 2 ) { X if ( (s = *r + n + a ) >= &a[ACTSIZE] ) X error( "out of space in optimizer a array" ); X if ( s > maxa ) X maxa = s; X if ( *s != 0 && *s != r[1] ) X error( "clobber of a array, pos'n %d, by %d", s - a, r[1] ); X *s = r[1]; X } X pa[i] = n; X if ( adb > 1 ) X fprintf( ftable, "State %d: entry at %d\n", i, pa[i] ); X return; X Xnextn: X ; X } X X error( "Error; failure to place state %d\n", i ); X} X X SHAR_EOF if test 1373 -ne "`wc -c < 'ystin.c'`" then echo shar: error transmitting "'ystin.c'" '(should have been 1373 characters)' fi chmod 644 ystin.c fi if test -f 'system.h' then echo shar: will not over-write existing "'system.h'" else echo extracting "'system.h'" sed 's/^X//' >system.h <<'SHAR_EOF' X/* ********************* X * * S Y S T E M . H * X * ********************* X * X * This file replaces the original "files." header file. It defines, for X * the IBM PC/XT version, the target parser function source file, overriding X * file name string defines, and other system-specific definitions and X * parameters. X * X * Bob Denny 06-Dec-80 X * X * Edits: X * 18-Dec-80 ZAPFILE no longer used in Decus Yacc. X * Parser file renamed yypars.c X * X * 28-Aug-81 Temp files for RSX have specific version X * numbers of 1 to avoid multi-versions. Rename X * parser info file ".i". X * X * 12-Apr-83 Add FNAMESIZE & EX_xxx parameters. X * X *Scott Guthery 23-Dec-83 Adapt for the IBM PC/XT & DeSmet C compiler. X * X */ X X/* Define WORD32 if target machine is a 32 bitter */ X#define WORD32 X X/* X * Target parser source file X */ X# define PARSER "yypars.c" X X/* X * basic size of the Yacc implementation X */ X# define MEDIUM X X/* X * Table size for this Yacc X */ X# define HUGETAB YES X X/* X * Filespec definitions X */ X# define ACTNAME "yacc2.tmp" X# define TEMPNAME "yacc1.tmp" X# define FNAMESIZE 24 X X/* X * Exit status values X */ X#define EX_SUC 1 X#define EX_WAR 0 X#define EX_ERR 2 X#define EX_SEV 4 SHAR_EOF if test 1368 -ne "`wc -c < 'system.h'`" then echo shar: error transmitting "'system.h'" '(should have been 1368 characters)' fi chmod 644 system.h fi if test -f 'ysumry.c' then echo shar: will not over-write existing "'ysumry.c'" else echo extracting "'ysumry.c'" sed 's/^X//' >ysumry.c <<'SHAR_EOF' X#include "y1.h" X Xsummary() X{ X /* output the summary on the tty */ X X if ( foutput != NULL ) { X fprintf( foutput, "\n%d/%d terminals, %d/%d nonterminals\n", ntokens, NTERMS, X nnonter, NNONTERM ); X fprintf( foutput, "%d/%d grammar rules, %d/%d states\n", nprod, NPROD, nstate, NSTATES ); X fprintf( foutput, "%d shift/reduce, %d reduce/reduce conflicts reported\n", zzsrconf, zzrrconf ); X fprintf( foutput, "%d/%d working sets used\n", zzcwp - wsets, WSETSIZE ); X fprintf( foutput, "memory: states,etc. %d/%d, parser %d/%d\n", zzmemsz - mem0, MEMSIZE, X memp - amem, ACTSIZE ); X fprintf( foutput, "%d/%d distinct lookahead sets\n", nlset, LSETSIZE ); X fprintf( foutput, "%d extra closures\n", zzclose - 2 * nstate ); X fprintf( foutput, "%d shift entries, %d exceptions\n", zzacent, zzexcp ); X fprintf( foutput, "%d goto entries\n", zzgoent ); X fprintf( foutput, "%d entries saved by goto default\n", zzgobest ); X } X if ( zzsrconf != 0 || zzrrconf != 0 ) { X fprintf( stdout, "\nconflicts: "); X if ( zzsrconf ) X fprintf( stdout, "%d shift/reduce" , zzsrconf ); X if ( zzsrconf && zzrrconf ) X fprintf( stdout, ", " ); X if ( zzrrconf ) X fprintf( stdout, "%d reduce/reduce" , zzrrconf ); X fprintf( stdout, "\n" ); X } X X fclose( ftemp ); X if ( fdefine != NULL ) X fclose( fdefine ); X} X X SHAR_EOF if test 1307 -ne "`wc -c < 'ysumry.c'`" then echo shar: error transmitting "'ysumry.c'" '(should have been 1307 characters)' fi chmod 644 ysumry.c fi if test -f 'README' then echo shar: will not over-write existing "'README'" else echo extracting "'README'" sed 's/^X//' >README <<'SHAR_EOF' X Sun Feb 1 00:52:01 CST 1987 X X UNIX/MS-DOS YACC X X Here is a copy of a public domain version of YACC. This version X is a derivative of the DECUS yacc (at lease some where along the X it come from there anyways). When I got it it had been modified X to run under MS-DOS on IBM-PC's. I have modified it to, (once X again) run under UNIX, as well as PC-DOS. X X It runs fine under System V.2 on an Arete 1200, as well as PC-DOS X 3.1. I do not have access to a Berkley machine, so I have not X been able to test it in that environment. X X I will post updates and patches to this version of YACC as I work X with it more, and as I get comments from other people who use it. X If you have any enhancements, portability problems or comments, X please let me know and I will put them in. X X For those of you who have been wanting YACC on a PC, here it is. X X In order to install the package, look at the #defines in system.h X and dtxtrn.h and modify them to match you machine configuration X and needs/desires. Then type make. X X X Mark H. Colburn mark@ems.uucp X EMS/McGraw-Hill {rutgers|amdahl|ihnp4}!meccts!ems!mark X 9855 West 78th Street X Eden Prairie, MN 55344 (612) 829-8200 x235 SHAR_EOF if test 1277 -ne "`wc -c < 'README'`" then echo shar: error transmitting "'README'" '(should have been 1277 characters)' fi chmod 644 README fi if test -f 'yg2gen.c' then echo shar: will not over-write existing "'yg2gen.c'" else echo extracting "'yg2gen.c'" sed 's/^X//' >yg2gen.c <<'SHAR_EOF' X#include "y3.h" X X/* X * yg2gen.3c X * X * Modified to make debug code conditionally compile. X * 28-Aug-81 X * Bob Denny X */ X Xgo2gen(c) X X{ X /* output the gotos for nonterminal c */ X X int i, work, cc; X struct item *p, *q; X X X /* first, find nonterminals with gotos on c */ X X aryfil( temp1, nnonter + 1, 0 ); X temp1[c] = 1; X X work = 1; X while ( work ) { X X work = 0; X PLOOP(0, i) X X { X if ( (cc = prdptr[i][1] - NTBASE) >= 0 ) { X X /* cc is a nonterminal */ X if ( temp1[cc] != 0 ) { X X /* cc has a goto on c */ X cc = *prdptr[i] - NTBASE; /* thus, the left side of production i does too */ X if ( temp1[cc] == 0 ) { X X work = 1; X temp1[cc] = 1; X } X } X } X } X } X X /* now, we have temp1[c] = 1 if a goto on c in closure of cc */ X X#ifdef debug X if ( foutput != NULL ) { X X fprintf( foutput, "%s: gotos on ", nontrst[c].name ); X NTLOOP(i) if ( temp1[i] ) X fprintf( foutput, "%s ", nontrst[i].name); X fprintf( foutput, "\n"); X } X#endif X /* now, go through and put gotos into tystate */ X X aryfil( tystate, nstate, 0 ); X SLOOP(i) X X { X ITMLOOP(i, p, q) X X { X if ( (cc = *p->pitem) >= NTBASE ) { X X if ( temp1[cc -= NTBASE] ) { X X /* goto on c is possible */ X tystate[i] = amem[indgo[i]+c]; X break; X } X } X } X } X} X X SHAR_EOF if test 1263 -ne "`wc -c < 'yg2gen.c'`" then echo shar: error transmitting "'yg2gen.c'" '(should have been 1263 characters)' fi chmod 644 yg2gen.c fi if test -f 'y4.h' then echo shar: will not over-write existing "'y4.h'" else echo extracting "'y4.h'" sed 's/^X//' >y4.h <<'SHAR_EOF' X/*****************************************************************************/ X/* ************* */ X/* * Y 4 . H * */ X/* ************* */ X/* */ X/* This file contains the external declarations needed to hook Yacc modules */ X/* which were originally in Y4.C to their impure data in Y4IMP.4C. Also does */ X/* the include of the original data/external file DTXTRN.H. */ X/* */ X/*****************************************************************************/ X X# include "dtxtrn.h" X X# define a amem X# define pa indgo X# define yypact temp1 X# define greed tystate X X# define NOMORE -1000 X Xextern int *ggreed; Xextern int *pgo; Xextern int *yypgo; X Xextern int maxspr; /* maximum spread of any entry */ Xextern int maxoff; /* maximum offset into a array */ Xextern int *pmem; Xextern int *maxa; Xextern int nxdb; Xextern int adb; SHAR_EOF if test 1184 -ne "`wc -c < 'y4.h'`" then echo shar: error transmitting "'y4.h'" '(should have been 1184 characters)' fi chmod 644 y4.h fi if test -f 'ycpfir.c' then echo shar: will not over-write existing "'ycpfir.c'" else echo extracting "'ycpfir.c'" sed 's/^X//' >ycpfir.c <<'SHAR_EOF' X/* X * ycpfir.c - compute an array with the first of nonterminals X * X * HISTORY X * {1} 28-Aug-81 Bob Denny X * Modified to make debug code conditionally compile. X * X */ X X#include "y1.h" X X X Xint cpfir() X{ X /* compute an array with the first of nonterminals */ X register *p, **s, i, **t, ch, changes; X X zzcwp = &wsets[nnonter]; X NTLOOP(i) { X aryfil(wsets[i].ws.lset, tbitset, 0); X t = pres[i + 1]; X for (s = pres[i]; s < t; ++s) { X /* initially fill the sets */ X for (p = *s; (ch = *p) > 0; ++p) { X if (ch < NTBASE) { X SETBIT(wsets[i].ws.lset, ch); X break; X } else if (!pempty[ch - NTBASE]) X break; X } X } X } X X /* now, reflect transitivity */ X X changes = 1; X while (changes) { X changes = 0; X NTLOOP(i) { X t = pres[i + 1]; X for (s = pres[i]; s < t; ++s) { X for (p = *s; (ch = (*p - NTBASE)) >= 0; ++p) { X changes |= setunion(wsets[i].ws.lset, wsets[ch].ws.lset); X if (!pempty[ch]) X break; X } X } X } X } X X NTLOOP(i) pfirst[i] = flset(&wsets[i].ws); X#ifdef debug X if ((foutput != NULL)) { X NTLOOP(i) { X fprintf(foutput, "\n%s: ", nontrst[i].name); X prlook(pfirst[i]); X fprintf(foutput, " %d\n", pempty[i]); X } X } X#endif X} X X SHAR_EOF if test 1180 -ne "`wc -c < 'ycpfir.c'`" then echo shar: error transmitting "'ycpfir.c'" '(should have been 1180 characters)' fi chmod 644 ycpfir.c fi if test -f 'yg2out.c' then echo shar: will not over-write existing "'yg2out.c'" else echo extracting "'yg2out.c'" sed 's/^X//' >yg2out.c <<'SHAR_EOF' X#include "y3.h" X Xgo2out() X{ X /* output the gotos for the nontermninals */ X int i, j, k, best, count, cbest, times; X X fprintf( ftemp, "$\n" ); /* mark begining of gotos */ X X for ( i = 1; i <= nnonter; ++i ) { X go2gen(i); X X /* find the best one to make default */ X X best = -1; X times = 0; X X for ( j = 0; j <= nstate; ++j ) { X /* is j the most frequent */ X if ( tystate[j] == 0 ) X continue; X if ( tystate[j] == best ) X continue; X X /* is tystate[j] the most frequent */ X X count = 0; X cbest = tystate[j]; X X for ( k = j; k <= nstate; ++k ) X if ( tystate[k] == cbest ) X ++count; X X if ( count > times ) { X best = cbest; X times = count; X } X } X X /* best is now the default entry */ X X zzgobest += (times - 1); X for ( j = 0; j <= nstate; ++j ) { X if ( tystate[j] != 0 && tystate[j] != best ) { X fprintf( ftemp, "%d,%d,", j, tystate[j] ); X zzgoent += 1; X } X } X X /* now, the default */ X X zzgoent += 1; X fprintf( ftemp, "%d\n", best ); X X } X} X X SHAR_EOF if test 994 -ne "`wc -c < 'yg2out.c'`" then echo shar: error transmitting "'yg2out.c'" '(should have been 994 characters)' fi chmod 644 yg2out.c fi if test -f 'ycpres.c' then echo shar: will not over-write existing "'ycpres.c'" else echo extracting "'ycpres.c'" sed 's/^X//' >ycpres.c <<'SHAR_EOF' X/* X * ycpres.c - compute an array with the beginnings of productions X * X * compute an array with the beginnings of productions yielding given X * nonterminals The array pres points to these lists the array pyield has X * the lists: the total size is only NPROD+1 X * X * HISTORY X * {1} 12-Apr-83 Bob Denny X * Add symbol exit status. X * X */ X X#include "y1.h" X X Xextern int *pyield[NPROD]; X X Xint cpres() X{ X register **pmem; X register c, j, i; X X pmem = pyield; X X NTLOOP(i) { X c = i + NTBASE; X pres[i] = pmem; X fatfl = 0; /* make undefined symbols nonfatal */ X PLOOP(0, j) { X if (*prdptr[j] == c) X *pmem++ = prdptr[j] + 1; X } X if (pres[i] == pmem) { X error("nonterminal %s not defined!", nontrst[i].name); X } X } X pres[i] = pmem; X fatfl = 1; X if (nerrors) { X summary(); X exit(EX_ERR); X } X if (pmem != &pyield[nprod]) X error("internal Yacc error: pyield %d", pmem - &pyield[nprod]); X} X X SHAR_EOF if test 905 -ne "`wc -c < 'ycpres.c'`" then echo shar: error transmitting "'ycpres.c'" '(should have been 905 characters)' fi chmod 644 ycpres.c fi if test -f 'y3.h' then echo shar: will not over-write existing "'y3.h'" else echo extracting "'y3.h'" sed 's/^X//' >y3.h <<'SHAR_EOF' X/*****************************************************************************/ X/* ************* */ X/* * Y 3 . H * */ X/* ************* */ X/* */ X/* This file contains the external declarations needed to hook Yacc modules */ X/* which were originally in Y3.C to their impure data in Y3IMP.3C. Also does */ X/* the include of the original data/external file DTXTRN.H. */ X/* */ X/*****************************************************************************/ X X#include "dtxtrn.h" X Xextern int lastred; /* the number of the last reduction of a state */ SHAR_EOF if test 894 -ne "`wc -c < 'y3.h'`" then echo shar: error transmitting "'y3.h'" '(should have been 894 characters)' fi chmod 644 y3.h fi if test -f 'ygin.c' then echo shar: will not over-write existing "'ygin.c'" else echo extracting "'ygin.c'" sed 's/^X//' >ygin.c <<'SHAR_EOF' X#include "y4.h" X Xgin(i) X{ X X register *p, *r, *s, *q1, *q2; X X /* enter gotos on nonterminal i into array a */ X X ggreed[i] = 0; X X q2 = mem0 + yypgo[i+1] - 1; X q1 = mem0 + yypgo[i]; X X /* now, find a place for it */ X X for ( p = a; p < &a[ACTSIZE]; ++p ) { X if ( *p ) X continue; X for ( r = q1; r < q2; r += 2 ) { X s = p + *r + 1; X if ( *s ) X goto nextgp; X if ( s > maxa ) { X if ( (maxa = s) > &a[ACTSIZE] ) X error( "a array overflow" ); X } X } X /* we have found a spot */ X X *p = *q2; X if ( p > maxa ) { X if ( (maxa = p) > &a[ACTSIZE] ) X error( "a array overflow" ); X } X for ( r = q1; r < q2; r += 2 ) { X s = p + *r + 1; X *s = r[1]; X } X X pgo[i] = p - a; X if ( adb > 1 ) X fprintf( ftable, "Nonterminal %d, entry at %d\n" , i, pgo[i] ); X goto nextgi; X Xnextgp: X ; X } X X error( "cannot place goto %d\n", i ); X Xnextgi: X ; X} X X SHAR_EOF if test 862 -ne "`wc -c < 'ygin.c'`" then echo shar: error transmitting "'ygin.c'" '(should have been 862 characters)' fi chmod 644 ygin.c fi if test -f 'ymain.c' then echo shar: will not over-write existing "'ymain.c'" else echo extracting "'ymain.c'" sed 's/^X//' >ymain.c <<'SHAR_EOF' X#include "y1.h" X/* X * 12-Apr-83 (RBD) Add symbolic exit status X */ Xmain(argc, argv) Xint argc; Xchar *argv[]; X X{ X X puts("Setup..."); X setup(argc, argv); /* initialize and read productions */ X puts("cpres ..."); X tbitset = NWORDS(ntokens); X cpres(); /* make table of which productions yield a given nonterminal */ X puts("cempty ..."); X cempty(); /* make a table of which nonterminals can match the empty string */ X puts("cpfir ..."); X cpfir(); /* make a table of firsts of nonterminals */ X puts("stagen ..."); X stagen(); /* generate the states */ X puts("output ..."); X output(); /* write the states and the tables */ X puts("go2out ..."); X go2out(); X puts("hideprod ..."); X hideprod(); X puts("summary ..."); X summary(); X puts("callopt ..."); X callopt(); X puts("others ..."); X others(); X puts("DONE !!!"); X exit(EX_SUC); X} X X SHAR_EOF if test 822 -ne "`wc -c < 'ymain.c'`" then echo shar: error transmitting "'ymain.c'" '(should have been 822 characters)' fi chmod 644 ymain.c fi if test -f 'yprcft.c' then echo shar: will not over-write existing "'yprcft.c'" else echo extracting "'yprcft.c'" sed 's/^X//' >yprcft.c <<'SHAR_EOF' X#include "y3.h" X Xprecftn(r, t, s) X{ X /* decide a shift/reduce conflict by precedence.*/ X /* r is a rule number, t a token number */ X /* the conflict is in state s */ X /* temp1[t] is changed to reflect the action */ X X int lp, lt, action; X X lp = levprd[r]; X lt = toklev[t]; X if ( PLEVEL(lt) == 0 || PLEVEL(lp) == 0 ) { X /* conflict */ X if ( foutput != NULL ) X fprintf( foutput, "\n%d: shift/reduce conflict (shift %d, red'n %d) on %s", X s, temp1[t], r, symnam(t) ); X ++zzsrconf; X return; X } X if ( PLEVEL(lt) == PLEVEL(lp) ) X action = ASSOC(lt); X else if ( PLEVEL(lt) > PLEVEL(lp) ) X action = RASC; /* shift */ X else X action = LASC; /* reduce */ X X switch ( action ) { X X case BASC: /* error action */ X temp1[t] = ERRCODE; X return; X X case LASC: /* reduce */ X temp1[t] = -r; X return; X X } X} X X SHAR_EOF if test 813 -ne "`wc -c < 'yprcft.c'`" then echo shar: error transmitting "'yprcft.c'" '(should have been 813 characters)' fi chmod 644 yprcft.c fi if test -f 'ycpuni.c' then echo shar: will not over-write existing "'ycpuni.c'" else echo extracting "'ycpuni.c'" sed 's/^X//' >ycpuni.c <<'SHAR_EOF' X/* X * ycpuni.c - copy the union declaration & define file (if present) to output X * X * HISTORY X */ X X#include "y2.h" X Xint cpyunion() X{ X int level, c; X fprintf(ftable, "\n# line %d\n", lineno); X fprintf(ftable, "\n#define UNION 1\n"); X fprintf(ftable, "typedef union "); X if (fdefine) X fprintf(fdefine, "\ntypedef union "); X X level = 0; X for (; ; ) { X if ((c = unix_getc(finput)) < 0) X error("EOF encountered while processing %%union"); X putc(c, ftable); X if (fdefine) X putc(c, fdefine); X X switch (c) { X X case '\n': X ++lineno; X break; X X case '{': X ++level; X break; X X case '}': X --level; X if (level == 0) { X /* we are finished copying */ X fprintf(ftable, " YYSTYPE;\n"); X if (fdefine) X fprintf(fdefine, " YYSTYPE;\nextern YYSTYPE yylval;\n"); X return; X } X } X } X} X X SHAR_EOF if test 805 -ne "`wc -c < 'ycpuni.c'`" then echo shar: error transmitting "'ycpuni.c'" '(should have been 805 characters)' fi chmod 644 ycpuni.c fi if test -f 'ydfout.c' then echo shar: will not over-write existing "'ydfout.c'" else echo extracting "'ydfout.c'" sed 's/^X//' >ydfout.c <<'SHAR_EOF' X/* X * ydfout.c - X * X * HISTORY X */ X X#include <ctype.h> X#include "y2.h" X Xint defout() X{ X /* write out the defines (at the end of the declaration section) */ X X register int i, c; X register char *cp; X X for (i = ndefout; i <= ntokens; ++i) { X X cp = tokset[i].name; X if (*cp == ' ') X ++cp; /* literals */ X X for (; (c = *cp) != '\0'; ++cp) { X X if (islower(c) || isupper(c) || isdigit(c) || c == '_') X ; /* VOID */ X else X goto nodef; X } X X fprintf(ftable, "# define %s %d\n", tokset[i].name, tokset[i].value); X if (fdefine != NULL) X fprintf(fdefine, "# define %s %d\n", tokset[i].name, tokset[i].value); X Xnodef: X ; X } X X ndefout = ntokens + 1; X X} X X SHAR_EOF if test 661 -ne "`wc -c < 'ydfout.c'`" then echo shar: error transmitting "'ydfout.c'" '(should have been 661 characters)' fi chmod 644 ydfout.c fi if test -f 'ywritm.c' then echo shar: will not over-write existing "'ywritm.c'" else echo extracting "'ywritm.c'" sed 's/^X//' >ywritm.c <<'SHAR_EOF' X/* X * ywritm.c - X * X * HISTORY X */ X X#include "y1.h" X Xextern char sarr[ISIZE]; X Xchar *chcopy(); X Xchar *writem(pp) Xint *pp; X{ X /* creates output string for item pointed to by pp */ X int i, *p; X char *q; X X for (p = pp; *p > 0; ++p) X ; X p = prdptr[-*p]; X q = chcopy(sarr, nontrst[*p - NTBASE].name); X q = chcopy(q, " : "); X X for (; ; ) { X *q++ = ++p == pp ? '_' : ' '; X *q = '\0'; X if ((i = *p) <= 0) X break; X q = chcopy(q, symnam(i)); X if (q > &sarr[ISIZE - 30]) X error("item too big"); X } X X if ((i = *pp) < 0) { X /* an item calling for a reduction */ X q = chcopy(q, " ("); X sprintf(q, "%d)", -i); X } X return (sarr); X} X X SHAR_EOF if test 634 -ne "`wc -c < 'ywritm.c'`" then echo shar: error transmitting "'ywritm.c'" '(should have been 634 characters)' fi chmod 644 ywritm.c fi if test -f 'yflset.c' then echo shar: will not over-write existing "'yflset.c'" else echo extracting "'yflset.c'" sed 's/^X//' >yflset.c <<'SHAR_EOF' X#include "y1.h" X Xstruct looksets *flset( p ) Xstruct looksets *p; X X{ X /* decide if the lookahead set pointed to by p is known */ X /* return pointer to a perminent location for the set */ X X register struct looksets *q; X int j, *w; X register *u, *v; X X for ( q = &lkst[nlset]; q-- > lkst; ) { X u = p->lset; X v = q->lset; X w = &v[tbitset]; X while ( v < w) X if ( *u++ != *v++) X goto more; X /* we have matched */ X return( q ); Xmore: X ; X } X /* add a new one */ X q = &lkst[nlset++]; X if ( nlset >= LSETSIZE ) X error("too many lookahead sets" ); X SETLOOP(j) X { X q->lset[j] = p->lset[j]; X } X return( q ); X} X X SHAR_EOF if test 618 -ne "`wc -c < 'yflset.c'`" then echo shar: error transmitting "'yflset.c'" '(should have been 618 characters)' fi chmod 644 yflset.c fi if test -f 'yhdprd.c' then echo shar: will not over-write existing "'yhdprd.c'" else echo extracting "'yhdprd.c'" sed 's/^X//' >yhdprd.c <<'SHAR_EOF' X#include "y3.h" X Xhideprod() X{ X /* in order to free up the mem and amem arrays for the optimizer, X /* and still be able to output yyr1, etc., after the sizes of X /* the action array is known, we hide the nonterminals X /* derived by productions in levprd. X */ X X register i, j; X X j = 0; X levprd[0] = 0; X PLOOP(1, i) X { X if ( !(levprd[i] & REDFLAG) ) { X ++j; X if ( foutput != NULL ) { X fprintf( foutput, "Rule not reduced: %s\n", writem( prdptr[i] ) ); X } X } X levprd[i] = *prdptr[i] - NTBASE; X } X if ( j ) X fprintf( stdout, "%d rules never reduced\n", j ); X} X X SHAR_EOF if test 602 -ne "`wc -c < 'yhdprd.c'`" then echo shar: error transmitting "'yhdprd.c'" '(should have been 602 characters)' fi chmod 644 yhdprd.c fi if test -f 'yptitm.c' then echo shar: will not over-write existing "'yptitm.c'" else echo extracting "'yptitm.c'" sed 's/^X//' >yptitm.c <<'SHAR_EOF' X#include "y1.h" X X/* X * yptitm.1c X * X * Modified to make debug code conditionally compile. X * 28-Aug-81 X * Bob Denny X */ X Xputitem( ptr, lptr ) Xint *ptr; Xstruct looksets *lptr; X X X{ X register struct item *j; X X#ifdef debug X if ( foutput != NULL ) { X X fprintf( foutput, "putitem(%s), state %d\n", writem(ptr), nstate ); X } X#endif X j = pstate[nstate+1]; X j->pitem = ptr; X if ( !nolook ) X j->look = flset( lptr ); X pstate[nstate+1] = ++j; X if ( (int *)j > zzmemsz ) { X X zzmemsz = (int *)j; X if ( zzmemsz >= &mem0[MEMSIZE] ) X error( "out of state space" ); X } X} X X SHAR_EOF if test 567 -ne "`wc -c < 'yptitm.c'`" then echo shar: error transmitting "'yptitm.c'" '(should have been 567 characters)' fi chmod 644 yptitm.c fi if test -f 'ycpycd.c' then echo shar: will not over-write existing "'ycpycd.c'" else echo extracting "'ycpycd.c'" sed 's/^X//' >ycpycd.c <<'SHAR_EOF' X/* X * ycpycd.c - copies code between \{ and \} X * X * HISTORY X */ X X#include "y2.h" X X Xint cpycode() X{ X int c; X X c = unix_getc(finput); X if (c == '\n') { X c = unix_getc(finput); X lineno++; X } X fprintf(ftable, "\n# line %d\n", lineno); X while (c >= 0) { X if (c == '\\') X if ((c = unix_getc(finput)) == '}') X return; X else X putc('\\', ftable); X if (c == '%') X if ((c = unix_getc(finput)) == '}') X return; X else X putc('%', ftable); X putc(c, ftable); X if (c == '\n') X ++lineno; X c = unix_getc(finput); X } X error("eof before %%}"); X} X X SHAR_EOF if test 557 -ne "`wc -c < 'ycpycd.c'`" then echo shar: error transmitting "'ycpycd.c'" '(should have been 557 characters)' fi chmod 644 ycpycd.c fi if test -f 'ygtnm.c' then echo shar: will not over-write existing "'ygtnm.c'" else echo extracting "'ygtnm.c'" sed 's/^X//' >ygtnm.c <<'SHAR_EOF' X/* X * ygtnm.c - X * X * HISTORY X */ X X#include <ctype.h> X#include "y4.h" X Xint gtnm() X{ X X register s, val, c; X X /* read and convert an integer from the standard input */ X /* return the terminating character */ X /* blanks, tabs, and newlines are ignored */ X X s = 1; X val = 0; X X while ((c = unix_getc(finput)) != EOF) { X if (isdigit(c)) { X val = val * 10 + c - '0'; X } else if (c == '-') X s = -1; X else if (c == '\r') X continue; X else X break; X } X *pmem++ = s * val; X if (pmem > &mem0[MEMSIZE]) X error("out of space"); X return (c); X} X X SHAR_EOF if test 542 -ne "`wc -c < 'ygtnm.c'`" then echo shar: error transmitting "'ygtnm.c'" '(should have been 542 characters)' fi chmod 644 ygtnm.c fi if test -f 'yskpcm.c' then echo shar: will not over-write existing "'yskpcm.c'" else echo extracting "'yskpcm.c'" sed 's/^X//' >yskpcm.c <<'SHAR_EOF' X#include "y2.h" X Xskipcom() X{ X /* skip over comments */ X register c, i; /* i is the number of lines skipped */ X i = 0; /*01*/ X /* skipcom is called after reading a / */ X X if ( unix_getc(finput) != '*' ) X error( "illegal comment" ); X c = unix_getc(finput); X while ( c != EOF ) { X while ( c == '*' ) { X if ( (c = unix_getc(finput)) == '/' ) X return( i ); X } X if ( c == '\n' ) X ++i; X c = unix_getc(finput); X } X error( "EOF inside comment" ); X /* NOTREACHED */ X} X X SHAR_EOF if test 532 -ne "`wc -c < 'yskpcm.c'`" then echo shar: error transmitting "'yskpcm.c'" '(should have been 532 characters)' fi chmod 644 yskpcm.c fi if test -f 'yosmry.c' then echo shar: will not over-write existing "'yosmry.c'" else echo extracting "'yosmry.c'" sed 's/^X//' >yosmry.c <<'SHAR_EOF' X#include "y4.h" X X/* X * Write summary. X */ X Xosummary() X X{ X register int i, *p; X X if (foutput == NULL) X return; X X i = 0; X for (p = maxa; p >= a; --p) { X X if (*p == 0) X ++i; X } X fprintf(foutput, "Optimizer space used: input %d/%d, output %d/%d\n", X pmem - mem0 + 1, MEMSIZE, maxa - a + 1, ACTSIZE); X fprintf(foutput, "%d table entries, %d zero\n", (maxa - a) + 1, i); X fprintf(foutput, "maximum spread: %d, maximum offset: %d\n", maxspr, maxoff); X fclose(foutput); X} X X SHAR_EOF if test 476 -ne "`wc -c < 'yosmry.c'`" then echo shar: error transmitting "'yosmry.c'" '(should have been 476 characters)' fi chmod 644 yosmry.c fi if test -f 'y4imp.c' then echo shar: will not over-write existing "'y4imp.c'" else echo extracting "'y4imp.c'" sed 's/^X//' >y4imp.c <<'SHAR_EOF' X/* X * y4imp.c - impure data from y4.c modules X * X * HISTORY X */ X X# include "dtxtrn.h" X X# define a amem X# define pa indgo X# define yypact temp1 X# define greed tystate X X# define NOMORE -1000 X Xint *ggreed = lkst[0].lset; Xint *pgo = wsets[0].ws.lset; Xint *yypgo = &nontrst[0].tvalue; X Xint maxspr = 0; /* maximum spread of any entry */ Xint maxoff = 0; /* maximum offset into a array */ Xint *pmem = mem0; Xint *maxa; Xint nxdb = 0; Xint adb = 0; SHAR_EOF if test 440 -ne "`wc -c < 'y4imp.c'`" then echo shar: error transmitting "'y4imp.c'" '(should have been 440 characters)' fi chmod 644 y4imp.c fi if test -f 'ynxti.c' then echo shar: will not over-write existing "'ynxti.c'" else echo extracting "'ynxti.c'" sed 's/^X//' >ynxti.c <<'SHAR_EOF' X#include "y4.h" X Xnxti() X{ X /* finds the next i */ X register i, max, maxi; X X max = 0; X X for ( i = 1; i <= nnonter; ++i ) X if ( ggreed[i] >= max ) { X max = ggreed[i]; X maxi = -i; X } X X for ( i = 0; i < nstate; ++i ) X if ( greed[i] >= max ) { X max = greed[i]; X maxi = i; X } X X if ( nxdb ) X fprintf( ftable, "nxti = %d, max = %d\n", maxi, max ); X if ( max == 0 ) X return( NOMORE ); X else X return( maxi ); X} X X SHAR_EOF if test 423 -ne "`wc -c < 'ynxti.c'`" then echo shar: error transmitting "'ynxti.c'" '(should have been 423 characters)' fi chmod 644 ynxti.c fi if test -f 'ychfnd.c' then echo shar: will not over-write existing "'ychfnd.c'" else echo extracting "'ychfnd.c'" sed 's/^X//' >ychfnd.c <<'SHAR_EOF' X/* X * ychfnd.c - X * X * HISTORY X */ X X#include "y2.h" X X Xint chfind( t, s ) Xregister char *s; X{ X int i; X X if (s[0] == ' ') X t = 0; X TLOOP(i) { X if (!strcmp(s, tokset[i].name)) { X return (i); X } X } X NTLOOP(i) { X if (!strcmp(s, nontrst[i].name)) { X return (i + NTBASE); X } X } X /* cannot find name */ X if (t > 1) X error("%s should have been defined earlier", s); X return (defin(t, s)); X} X X SHAR_EOF if test 394 -ne "`wc -c < 'ychfnd.c'`" then echo shar: error transmitting "'ychfnd.c'" '(should have been 394 characters)' fi chmod 644 ychfnd.c fi if test -f 'yyless.c' then echo shar: will not over-write existing "'yyless.c'" else echo extracting "'yyless.c'" sed 's/^X//' >yyless.c <<'SHAR_EOF' Xyyless(x) X X{ X extern char yytext[]; X register char *lastch, *ptr; X extern int yyleng; X extern int yyprevious; X lastch = yytext + yyleng; X if (x >= 0 && x <= yyleng) X ptr = x + yytext; X else X ptr = x; X while (lastch > ptr) X yyunput(*--lastch); X *lastch = 0; X if (ptr > yytext) X yyprevious = *--lastch; X yyleng = ptr - yytext; X} X X SHAR_EOF if test 333 -ne "`wc -c < 'yyless.c'`" then echo shar: error transmitting "'yyless.c'" '(should have been 333 characters)' fi chmod 644 yyless.c fi if test -f 'yarout.c' then echo shar: will not over-write existing "'yarout.c'" else echo extracting "'yarout.c'" sed 's/^X//' >yarout.c <<'SHAR_EOF' X/* X * yarout.c - X * X * HISTORY X */ X X#include "y4.h" X Xint arout(s, v, n) Xchar *s; Xint *v, n; X{ X register i; X X fprintf(ftable, "short %s[]={\n", s); X for (i = 0; i < n; ) { X if (i % 10 == 0) X fprintf(ftable, "\n"); X fprintf(ftable, "%4d", v[i]); X if (++i == n) X fprintf(ftable, " };\n"); X else X fprintf(ftable, ","); X } X} X X SHAR_EOF if test 333 -ne "`wc -c < 'yarout.c'`" then echo shar: error transmitting "'yarout.c'" '(should have been 333 characters)' fi chmod 644 yarout.c fi if test -f 'yerror.c' then echo shar: will not over-write existing "'yerror.c'" else echo extracting "'yerror.c'" sed 's/^X//' >yerror.c <<'SHAR_EOF' X#include "y1.h" X X/* X * 12-Apr-83 (RBD) Add symbolic exit status X */ X/* VARARGS1 */ Xerror(s, a1) Xchar *s; X X{ X /* write out error comment */ X X ++nerrors; X fprintf( stderr, "\n fatal error: "); X fprintf( stderr, s, a1); X fprintf( stderr, ", line %d\n", lineno ); X if ( !fatfl ) X return; X summary(); X exit(EX_ERR); X} X X SHAR_EOF if test 318 -ne "`wc -c < 'yerror.c'`" then echo shar: error transmitting "'yerror.c'" '(should have been 318 characters)' fi chmod 644 yerror.c fi if test -f 'ywarry.c' then echo shar: will not over-write existing "'ywarry.c'" else echo extracting "'ywarry.c'" sed 's/^X//' >ywarry.c <<'SHAR_EOF' X#include "y3.h" X Xwarray( s, v, n ) Xchar *s; Xint *v, n; X X{ X X register i; X X fprintf( ftable, "short %s[]={\n", s ); X for ( i = 0; i < n; ) { X if ( i % 10 == 0 ) X fprintf( ftable, "\n" ); X fprintf( ftable, "%4d", v[i] ); X if ( ++i == n ) X fprintf( ftable, " };\n" ); X else X fprintf( ftable, "," ); X } X} X X SHAR_EOF if test 316 -ne "`wc -c < 'ywarry.c'`" then echo shar: error transmitting "'ywarry.c'" '(should have been 316 characters)' fi chmod 644 ywarry.c fi if test -f 'yfdtyp.c' then echo shar: will not over-write existing "'yfdtyp.c'" else echo extracting "'yfdtyp.c'" sed 's/^X//' >yfdtyp.c <<'SHAR_EOF' X#include "y2.h" X Xfdtype( t ) X{ X /* determine the type of a symbol */ X register v; X if ( t >= NTBASE ) X v = nontrst[t-NTBASE].tvalue; X else X v = TYPE( toklev[t] ); X if ( v <= 0 ) X error( "must specify type for %s", (t >= NTBASE) ? nontrst[t-NTBASE].name : X tokset[t].name ); X return( v ); X} X X SHAR_EOF if test 304 -ne "`wc -c < 'yfdtyp.c'`" then echo shar: error transmitting "'yfdtyp.c'" '(should have been 304 characters)' fi chmod 644 yfdtyp.c fi if test -f 'yprlok.c' then echo shar: will not over-write existing "'yprlok.c'" else echo extracting "'yprlok.c'" sed 's/^X//' >yprlok.c <<'SHAR_EOF' X#include "y1.h" X Xprlook( p ) Xstruct looksets *p; X X{ X register j, *pp; X pp = p->lset; X if ( pp == 0 ) X fprintf( foutput, "\tNULL"); X else { X fprintf( foutput, " { " ); X TLOOP(j) X { X if ( BIT(pp, j) ) X fprintf( foutput, "%s ", symnam(j) ); X } X fprintf( foutput, "}" ); X } X} X X SHAR_EOF if test 296 -ne "`wc -c < 'yprlok.c'`" then echo shar: error transmitting "'yprlok.c'" '(should have been 296 characters)' fi chmod 644 yprlok.c fi if test -f 'ystuni.c' then echo shar: will not over-write existing "'ystuni.c'" else echo extracting "'ystuni.c'" sed 's/^X//' >ystuni.c <<'SHAR_EOF' X#include "y1.h" X Xsetunion( a, b ) Xregister *a, *b; X X{ X /* set a to the union of a and b */ X /* return 1 if b is not a subset of a, 0 otherwise */ X register i, x, sub; X X sub = 0; X SETLOOP(i) X { X *a = (x = *a) | *b++; X if ( *a++ != x ) X sub = 1; X } X return( sub ); X} X X SHAR_EOF if test 274 -ne "`wc -c < 'ystuni.c'`" then echo shar: error transmitting "'ystuni.c'" '(should have been 274 characters)' fi chmod 644 ystuni.c fi if test -f 'yaoput.c' then echo shar: will not over-write existing "'yaoput.c'" else echo extracting "'yaoput.c'" sed 's/^X//' >yaoput.c <<'SHAR_EOF' X/* X * yaoput.c - write out the optimized parser X * X * HISTORY X */ X X#include "y4.h" X Xint aoutput() X{ X fprintf(ftable, "# define YYLAST %d\n", maxa - a + 1); X arout("yyact", a, (maxa - a) + 1); X arout("yypact", pa, nstate); X arout("yypgo", pgo, nnonter + 1); X} X X SHAR_EOF if test 261 -ne "`wc -c < 'yaoput.c'`" then echo shar: error transmitting "'yaoput.c'" '(should have been 261 characters)' fi chmod 644 yaoput.c fi if test -f 'y3imp.c' then echo shar: will not over-write existing "'y3imp.c'" else echo extracting "'y3imp.c'" sed 's/^X//' >y3imp.c <<'SHAR_EOF' X/* X * y3imp.c - impure data from modules split from y3.c X * X * HISTORY X */ X X#define y3imp YES X X#include "dtxtrn.h" X Xint lastred; /* the number of the last reduction of a state */ X Xint defact[NSTATES]; /* the default actions of states */ SHAR_EOF if test 253 -ne "`wc -c < 'y3imp.c'`" then echo shar: error transmitting "'y3imp.c'" '(should have been 253 characters)' fi chmod 644 y3imp.c fi if test -f 'ycstsh.c' then echo shar: will not over-write existing "'ycstsh.c'" else echo extracting "'ycstsh.c'" sed 's/^X//' >ycstsh.c <<'SHAR_EOF' X#include "y2.h" Xchar * Xcstash( s ) Xregister char *s; X X{ X char *temp; X X temp = cnamp; X do X { X if ( cnamp >= &cnames[cnamsz] ) X error("too many characters in id's and literals" ); X else X *cnamp++ = *s; X } while ( *s++); X return( temp ); X} X X SHAR_EOF if test 250 -ne "`wc -c < 'ycstsh.c'`" then echo shar: error transmitting "'ycstsh.c'" '(should have been 250 characters)' fi chmod 644 ycstsh.c fi if test -f 'ysmnam.c' then echo shar: will not over-write existing "'ysmnam.c'" else echo extracting "'ysmnam.c'" sed 's/^X//' >ysmnam.c <<'SHAR_EOF' X#include "y1.h" X Xchar *symnam(i) X{ X /* return a pointer to the name of symbol i */ X char *cp; X X cp = (i >= NTBASE) ? nontrst[i-NTBASE].name : tokset[i].name ; X if ( *cp == ' ' ) X ++cp; X return( cp ); X} X X SHAR_EOF if test 206 -ne "`wc -c < 'ysmnam.c'`" then echo shar: error transmitting "'ysmnam.c'" '(should have been 206 characters)' fi chmod 644 ysmnam.c fi if test -f 'yaryfl.c' then echo shar: will not over-write existing "'yaryfl.c'" else echo extracting "'yaryfl.c'" sed 's/^X//' >yaryfl.c <<'SHAR_EOF' X/* X * yaryfl.c - set elements 0 through n-1 to c X * X * HISTORY X */ X X#include "y1.h" X X Xint aryfil(v, n, c) Xint *v, n, c; X{ X register int i; X X for (i = 0; i < n; ++i) X v[i] = c; X} X X SHAR_EOF if test 182 -ne "`wc -c < 'yaryfl.c'`" then echo shar: error transmitting "'yaryfl.c'" '(should have been 182 characters)' fi chmod 644 yaryfl.c fi if test -f 'ychcpy.c' then echo shar: will not over-write existing "'ychcpy.c'" else echo extracting "'ychcpy.c'" sed 's/^X//' >ychcpy.c <<'SHAR_EOF' X/* X * ychcpy.c - copies string q into p, return next free char ptr X * X * HISTORY X */ X X#include "y1.h" X Xchar *chcopy(p, q) Xchar *p, *q; X{ X while (*p = *q++) X ++p; X return (p); X} X X SHAR_EOF if test 180 -ne "`wc -c < 'ychcpy.c'`" then echo shar: error transmitting "'ychcpy.c'" '(should have been 180 characters)' fi chmod 644 ychcpy.c fi if test -f 'yfnact.c' then echo shar: will not over-write existing "'yfnact.c'" else echo extracting "'yfnact.c'" sed 's/^X//' >yfnact.c <<'SHAR_EOF' X#include "y2.h" X Xfinact() X{ X /* finish action routine */ X X fclose(faction); X X fprintf( ftable, "# define YYERRCODE %d\n", tokset[2].value ); X X} X X SHAR_EOF if test 146 -ne "`wc -c < 'yfnact.c'`" then echo shar: error transmitting "'yfnact.c'" '(should have been 146 characters)' fi chmod 644 yfnact.c fi # end of shell archive exit 0