123890Sjaap #ifndef lint
245477Skarels /*
338595Sjaap static char sccsid[] = "@(#)t10.c	2.4 (CWI) 89/08/14";
445477Skarels */
5*58242Ssklower static char sccsid[] = "@(#)t10.c	2.7 (Berkeley) 02/25/93";
623890Sjaap #endif lint
723890Sjaap #include "tdef.h"
823911Sjaap #include <sgtty.h>
923911Sjaap #include <ctype.h>
1023911Sjaap #include "ext.h"
1123890Sjaap /*
1223911Sjaap  * troff10.c
1323911Sjaap  *
1423911Sjaap  * typesetter interface
1523911Sjaap  */
1623890Sjaap 
1723890Sjaap int	vpos	 = 0;	/* absolute vertical position on page */
1823890Sjaap int	hpos	 = 0;	/* ditto horizontal */
1923890Sjaap 
2023890Sjaap short	*chtab;
2123890Sjaap char	*chname;
2223890Sjaap char	*fontab[NFONT+1];
2323890Sjaap char	*kerntab[NFONT+1];
2423890Sjaap char	*fitab[NFONT+1];
2523911Sjaap char	*codetab[NFONT+1];
2623890Sjaap 
2723890Sjaap int	Inch;
2823890Sjaap int	Hor;
2923890Sjaap int	Vert;
3023890Sjaap int	Unitwidth;
3145479Skarels int	nfonts;		/* highest font num. in fontab */
3245479Skarels int	physfonts;	/* highest font num. known to printer */
3345479Skarels int	zfont;		/* internal font num. mapped to 0 on printer */
3423890Sjaap int	nsizes;
3523890Sjaap int	nchtab;
3638595Sjaap int	nstips;
37*58242Ssklower int	xstip	= ~STIP;
3838595Sjaap tchar	*stiplab;
3923890Sjaap 
4023890Sjaap /* these characters are used as various signals or values
4123890Sjaap /* in miscellaneous places.
4223890Sjaap /* values are set in specnames in t10.c
4323890Sjaap */
4423890Sjaap 
4523890Sjaap int	c_hyphen;
4623890Sjaap int	c_emdash;
4723890Sjaap int	c_rule;
4823890Sjaap int	c_minus;
4923890Sjaap int	c_fi;
5023890Sjaap int	c_fl;
5123890Sjaap int	c_ff;
5223890Sjaap int	c_ffi;
5323890Sjaap int	c_ffl;
5423890Sjaap int	c_acute;
5523890Sjaap int	c_grave;
5623890Sjaap int	c_under;
5723890Sjaap int	c_rooten;
5823890Sjaap int	c_boxrule;
5923890Sjaap int	c_lefthand;
6023911Sjaap int	c_dagger;
6123890Sjaap 
6223890Sjaap #include "dev.h"
6323890Sjaap struct dev dev;
6423911Sjaap struct Font *fontbase[NFONT+1];
6523890Sjaap 
6623890Sjaap 
ptinit()6723890Sjaap ptinit()
6823890Sjaap {
6923890Sjaap 	int	i, fin, nw;
7045477Skarels 	char	*filebase, *p;
7123890Sjaap 
7223890Sjaap 	/* open table for device,
7323890Sjaap 	/* read in resolution, size info, font info, etc.
7423890Sjaap 	/* and set params
7523890Sjaap 	*/
7623890Sjaap 	strcat(termtab, "/dev");
7723890Sjaap 	strcat(termtab, devname);
7823890Sjaap 	strcat(termtab, "/DESC.out");	/* makes "..../devXXX/DESC.out" */
7923890Sjaap 	if ((fin = open(termtab, 0)) < 0) {
8023911Sjaap 		errprint("can't open tables for %s", termtab);
8123890Sjaap 		done3(1);
8223890Sjaap 	}
8345479Skarels 	if (read(fin, (char *) &dev, sizeof(struct dev)) < sizeof(struct dev)) {
8445479Skarels 		errprint("short read on %s", termtab);
8545479Skarels 		done3(1);
8645479Skarels 	}
8723890Sjaap 	Inch = dev.res;
8823890Sjaap 	Hor = dev.hor;
8923890Sjaap 	Vert = dev.vert;
9023890Sjaap 	Unitwidth = dev.unitwidth;
9145479Skarels 	physfonts = nfonts = dev.nfonts;
9223890Sjaap 	nsizes = dev.nsizes;
9323890Sjaap 	nchtab = dev.nchtab;
9445479Skarels 	nstips = dev.nstip;
9545477Skarels 	stiplab = (tchar *) malloc((nstips + 1) * sizeof(tchar));
9645479Skarels 	filebase = malloc(dev.filesize + EXTRAFONT);
9745479Skarels 	if (read(fin, filebase, dev.filesize) < dev.filesize) {
9845479Skarels 		errprint("short read on %s", termtab);
9945479Skarels 		done3(1);
10045479Skarels 	}
10123890Sjaap 	pstab = (short *) filebase;
10223890Sjaap 	chtab = pstab + nsizes + 1;
10323890Sjaap 	chname = (char *) (chtab + dev.nchtab);
10423890Sjaap 	p = chname + dev.lchname;
10523890Sjaap 	for (i = 1; i <= nfonts; i++) {
10623911Sjaap 		fontbase[i] = (struct Font *) p;
10723911Sjaap 		nw = *p & BYTEMASK;	/* 1st thing is width count */
10823890Sjaap 		fontlab[i] = PAIR(fontbase[i]->namefont[0], fontbase[i]->namefont[1]);
10923890Sjaap 		/* for now, still 2 char names */
11023890Sjaap 		if (smnt == 0 && fontbase[i]->specfont == 1)
11123890Sjaap 			smnt = i;	/* first special font */
11223911Sjaap 		p += sizeof(struct Font);	/* that's what's on the beginning */
11323890Sjaap 		fontab[i] = p;
11423890Sjaap 		kerntab[i] = p + nw;
11523911Sjaap 		codetab[i] = p + 2 * nw;
11623890Sjaap 		fitab[i] = p + 3 * nw;	/* skip width, kern, code */
11723890Sjaap 		p += 3 * nw + dev.nchtab + 128 - 32;
11823890Sjaap 	}
11938595Sjaap 	for (i = 1; i <= nstips; i++) {		/* make stipple names tchars */
12038595Sjaap 		stiplab[i] = PAIR(*p, *(p+1));
12138595Sjaap 		while (*(p++));
12238595Sjaap 	}
12323911Sjaap 	fontbase[0] = (struct Font *) p;	/* the last shall be first */
12423890Sjaap 	fontbase[0]->nwfont = MAXCHARS;
12523911Sjaap 	fontab[0] = p + sizeof (struct Font);
12623890Sjaap 	close(fin);
12723890Sjaap 	/* there are a lot of things that used to be constant
12823890Sjaap 	/* that now require code to be executed.
12923890Sjaap 	*/
13023890Sjaap 	sps = SPS;
13123890Sjaap 	ics = ICS;
13223890Sjaap 	for (i = 0; i < 16; i++)
13323890Sjaap 		tabtab[i] = DTAB * (i + 1);
13423890Sjaap 	pl = 11 * INCH;
13523890Sjaap 	po = PO;
13623890Sjaap 	spacesz = SS;
13723890Sjaap 	lss = lss1 = VS;
13823890Sjaap 	ll = ll1 = lt = lt1 = LL;
13923890Sjaap 	specnames();	/* install names like "hyphen", etc. */
14023890Sjaap 	if (ascii)
14123890Sjaap 		return;
14223911Sjaap 	fdprintf(ptid, "x T %s\n", devname);
14323911Sjaap 	fdprintf(ptid, "x res %d %d %d\n", Inch, Hor, Vert);
14423911Sjaap 	fdprintf(ptid, "x init\n");	/* do initialization for particular device */
14545477Skarels #ifdef notdef
14623890Sjaap 	for (i = 1; i <= nfonts; i++)
14723911Sjaap 		fdprintf(ptid, "x font %d %s\n", i, fontbase[i]->namefont);
14823911Sjaap 	fdprintf(ptid, "x xxx fonts=%d sizes=%d unit=%d\n", nfonts, nsizes, Unitwidth);
14923911Sjaap 	fdprintf(ptid, "x xxx nchtab=%d lchname=%d nfitab=%d\n",
15023890Sjaap 		dev.nchtab, dev.lchname, dev.nchtab+128-32);
15123911Sjaap 	fdprintf(ptid, "x xxx sizes:\nx xxx ");
15223890Sjaap 	for (i = 0; i < nsizes; i++)
15323911Sjaap 		fdprintf(ptid, " %d", pstab[i]);
15423911Sjaap 	fdprintf(ptid, "\nx xxx chars:\nx xxx ");
15523890Sjaap 	for (i = 0; i < dev.nchtab; i++)
15623911Sjaap 		fdprintf(ptid, " %s", &chname[chtab[i]]);
15723911Sjaap 	fdprintf(ptid, "\nx xxx\n");
15845477Skarels #endif
15923890Sjaap }
16023890Sjaap 
specnames()16123890Sjaap specnames()
16223890Sjaap {
16323890Sjaap 	static struct {
16423890Sjaap 		int	*n;
16523890Sjaap 		char	*v;
16623890Sjaap 	} spnames[] = {
16723890Sjaap 		&c_hyphen, "hy",
16823890Sjaap 		&c_emdash, "em",
16923890Sjaap 		&c_rule, "ru",
17023890Sjaap 		&c_minus, "\\-",
17123890Sjaap 		&c_fi, "fi",
17223890Sjaap 		&c_fl, "fl",
17323890Sjaap 		&c_ff, "ff",
17423890Sjaap 		&c_ffi, "Fi",
17523890Sjaap 		&c_ffl, "Fl",
17623890Sjaap 		&c_acute, "aa",
17723890Sjaap 		&c_grave, "ga",
17823890Sjaap 		&c_under, "ul",
17923890Sjaap 		&c_rooten, "rn",
18023890Sjaap 		&c_boxrule, "br",
18123890Sjaap 		&c_lefthand, "lh",
18223911Sjaap 		&c_dagger, "dg",
18323890Sjaap 		0, 0
18423890Sjaap 	};
18523890Sjaap 	int	i;
18623890Sjaap 
18723890Sjaap 	for (i = 0; spnames[i].n; i++)
18823890Sjaap 		*spnames[i].n = findch(spnames[i].v);
18923890Sjaap }
19023890Sjaap 
findch(s)19123890Sjaap findch(s)	/* find char s in chname */
19223890Sjaap register char	*s;
19323890Sjaap {
19423890Sjaap 	register int	i;
19523890Sjaap 
19623890Sjaap 	for (i = 0; i < nchtab; i++)
19723890Sjaap 		if (strcmp(s, &chname[chtab[i]]) == 0)
19823890Sjaap 			return(i + 128);
19923890Sjaap 	return(0);
20023890Sjaap }
20123890Sjaap 
ptout(i)20223890Sjaap ptout(i)
20323911Sjaap register tchar	i;
20423890Sjaap {
20523911Sjaap 	register dv;
20623890Sjaap 	register tchar	*k;
20723911Sjaap 	int temp, a, b;
20823890Sjaap 
20923890Sjaap 	if (cbits(i) != '\n') {
21023890Sjaap 		*olinep++ = i;
21123890Sjaap 		return;
21223890Sjaap 	}
21323890Sjaap 	if (olinep == oline) {
21423890Sjaap 		lead += lss;
21523890Sjaap 		return;
21623890Sjaap 	}
21723890Sjaap 
21823890Sjaap 	hpos = po;	/* ??? */
21923890Sjaap 	esc = 0;	/* ??? */
22023890Sjaap 	ptesc();	/* the problem is to get back to the left end of the line */
22123890Sjaap 	dv = 0;
22223890Sjaap 	for (k = oline; k < olinep; k++) {
22323890Sjaap 		if (ismot(*k) && isvmot(*k)) {
22423890Sjaap 			temp = absmot(*k);
22523890Sjaap 			if (isnmot(*k))
22623890Sjaap 				temp = -temp;
22723890Sjaap 			dv += temp;
22823890Sjaap 		}
22923890Sjaap 	}
23023890Sjaap 	if (dv) {
23123890Sjaap 		vflag++;
23223890Sjaap 		*olinep++ = makem(-dv);
23323890Sjaap 		vflag = 0;
23423890Sjaap 	}
23523890Sjaap 
23623890Sjaap 	b = dip->blss + lss;
23723890Sjaap 	lead += dip->blss + lss;
23823890Sjaap 	dip->blss = 0;
23923890Sjaap 	for (k = oline; k < olinep; )
24023890Sjaap 		k += ptout0(k);	/* now passing a pointer! */
24123890Sjaap 	olinep = oline;
24223890Sjaap 	lead += dip->alss;
24323890Sjaap 	a = dip->alss;
24423890Sjaap 	dip->alss = 0;
24523890Sjaap 	/*
24623911Sjaap 	fdprintf(ptid, "x xxx end of line: hpos=%d, vpos=%d\n", hpos, vpos);
24723890Sjaap */
24823911Sjaap 	fdprintf(ptid, "n%d %d\n", b, a);	/* be nice to chuck */
24923890Sjaap }
25023890Sjaap 
ptout0(pi)25123890Sjaap ptout0(pi)
25223890Sjaap tchar	*pi;
25323890Sjaap {
25423890Sjaap 	register short j, k, w;
25523890Sjaap 	short	z, dx, dy, dx2, dy2, n;
25623911Sjaap 	register tchar	i;
25723890Sjaap 	int outsize;	/* size of object being printed */
25823890Sjaap 
25923890Sjaap 	outsize = 1;	/* default */
26023890Sjaap 	i = *pi;
26123890Sjaap 	k = cbits(i);
26223890Sjaap 	if (ismot(i)) {
26323890Sjaap 		j = absmot(i);
26423890Sjaap 		if (isnmot(i))
26523890Sjaap 			j = -j;
26623890Sjaap 		if (isvmot(i))
26723890Sjaap 			lead += j;
26823890Sjaap 		else
26923890Sjaap 			esc += j;
27023890Sjaap 		return(outsize);
27123890Sjaap 	}
27223911Sjaap 	if (k == XON) {
27323911Sjaap 		int c;
27423911Sjaap 		if (xfont != mfont)
27523911Sjaap 			ptfont();
27623911Sjaap 		if (xpts != mpts)
27723911Sjaap 			ptps();
27823911Sjaap 		if (lead)
27923911Sjaap 			ptlead();
28033696Sjaap 		if (esc)	/* for psfig ???*/
28133696Sjaap 			ptesc();
28223911Sjaap 		fdprintf(ptid, "x X ");
28323911Sjaap 		for (j = 1; (c=cbits(pi[j])) != XOFF; j++)
28423911Sjaap 			outascii(pi[j]);
28523911Sjaap 		oput('\n');
28623911Sjaap 		return j+1;
28723911Sjaap 	}
28823911Sjaap 			;
28923890Sjaap 	if (k == CHARHT) {
29023890Sjaap 		if (xpts != mpts)
29123890Sjaap 			ptps();
29223911Sjaap 		fdprintf(ptid, "x H %d\n", sbits(i));
29323890Sjaap 		return(outsize);
29423890Sjaap 	}
29523890Sjaap 	if (k == SLANT) {
29623911Sjaap 		fdprintf(ptid, "x S %d\n", sfbits(i)-180);
29723890Sjaap 		return(outsize);
29823890Sjaap 	}
29923890Sjaap 	if (k == WORDSP) {
30023890Sjaap 		oput('w');
30123890Sjaap 		return(outsize);
30223890Sjaap 	}
30323890Sjaap 	if (sfbits(i) == oldbits) {
30423890Sjaap 		xfont = pfont;
30523890Sjaap 		xpts = ppts;
30623890Sjaap 	} else
30723911Sjaap 		xbits(i, 2);
30823890Sjaap 	if (k < 040 && k != DRAWFCN)
30923890Sjaap 		return(outsize);
31033753Sjaap 	/*
31133753Sjaap 	 * Bug fix, if k == DRAWFCN, thewidcache gets a negative index.
31233753Sjaap 	 * This worked by magic on the vax and tahoe, but caused somtimes
31333753Sjaap 	 * a segment violaton on the suns.
31433753Sjaap 	 *
31533753Sjaap 	 * The code was plainly wrong (jna).
31633753Sjaap 	 */
31733753Sjaap 	if ( k != DRAWFCN) {
31833753Sjaap 		if (widcache[k-32].fontpts == (xfont<<8) + xpts  && !setwdf) {
31933753Sjaap 			w = widcache[k-32].width;
32033753Sjaap 			bd = 0;
32133753Sjaap 			cs = 0;
32233753Sjaap 		} else
32333753Sjaap 			w = getcw(k-32);
32433753Sjaap 	}
32523890Sjaap 	j = z = 0;
32623890Sjaap 	if (k != DRAWFCN) {
32723890Sjaap 		if (cs) {
32823890Sjaap 			if (bd)
32923890Sjaap 				w += (bd - 1) * HOR;
33023890Sjaap 			j = (cs - w) / 2;
33123890Sjaap 			w = cs - j;
33223890Sjaap 			if (bd)
33323890Sjaap 				w -= (bd - 1) * HOR;
33423890Sjaap 		}
33523890Sjaap 		if (iszbit(i)) {
33623890Sjaap 			if (cs)
33723890Sjaap 				w = -j;
33823890Sjaap 			else
33923890Sjaap 				w = 0;
34023890Sjaap 			z = 1;
34123890Sjaap 		}
34223890Sjaap 	}
34323890Sjaap 	esc += j;
34423890Sjaap 	if (xfont != mfont)
34523890Sjaap 		ptfont();
34623890Sjaap 	if (xpts != mpts)
34723890Sjaap 		ptps();
34823890Sjaap 	if (lead)
34923890Sjaap 		ptlead();
35023890Sjaap 	/* put out the real character here */
35123890Sjaap 	if (k == DRAWFCN) {
35223890Sjaap 		if (esc)
35323890Sjaap 			ptesc();
354*58242Ssklower 		dx = absmot(pi[2]);
355*58242Ssklower 		if (isnmot(pi[2]))
356*58242Ssklower 			dx = -dx;
357*58242Ssklower 		dy = absmot(pi[3]);
35823890Sjaap 		if (isnmot(pi[3]))
35923890Sjaap 			dy = -dy;
360*58242Ssklower 		w = 0;
36123890Sjaap 		switch (cbits(pi[1])) {
36223890Sjaap 		case DRAWCIRCLE:	/* circle */
36323890Sjaap 			hpos += dx;
364*58242Ssklower 				/* FALLTHROUGH */
365*58242Ssklower 		case DRAWTHICK:
366*58242Ssklower 		case DRAWSTYLE:
367*58242Ssklower 			fdprintf(ptid, "D%c %d\n", cbits(pi[1]), dx);	/* dx is diameter */
36823890Sjaap 			break;
36923890Sjaap 		case DRAWELLIPSE:
37023911Sjaap 			fdprintf(ptid, "D%c %d %d\n", DRAWELLIPSE, dx, dy);
37123890Sjaap 			hpos += dx;
37223890Sjaap 			break;
37323890Sjaap 		case DRAWLINE:	/* line */
374*58242Ssklower 			fdprintf(ptid, "D%c %d %d\n", DRAWLINE, dx, dy);
37523890Sjaap 			hpos += dx;
37623890Sjaap 			vpos += dy;
37723890Sjaap 			break;
37823890Sjaap 		case DRAWARC:	/* arc */
379*58242Ssklower 			dx2 = absmot(pi[4]);
380*58242Ssklower 			if (isnmot(pi[4]))
381*58242Ssklower 				dx2 = -dx2;
382*58242Ssklower 			dy2 = absmot(pi[5]);
38323890Sjaap 			if (isnmot(pi[5]))
38423890Sjaap 				dy2 = -dy2;
38523911Sjaap 			fdprintf(ptid, "D%c %d %d %d %d\n", DRAWARC,
38623890Sjaap 				dx, dy, dx2, dy2);
38723890Sjaap 			hpos += dx + dx2;
38823890Sjaap 			vpos += dy + dy2;
38923890Sjaap 			break;
39023911Sjaap 		case DRAWSPLINE:	/* spline */
391*58242Ssklower 		/* case DRAWWIG:	/* wiggly line */
392*58242Ssklower 		case DRAWCURVE:	/* gremlin-style curve */
39323911Sjaap 		default:	/* something else; copy it like spline */
39423911Sjaap 			fdprintf(ptid, "D%c %d %d", cbits(pi[1]), dx, dy);
39523890Sjaap 			hpos += dx;
39623890Sjaap 			vpos += dy;
397*58242Ssklower writecoords:
398*58242Ssklower 			for (n = 4; cbits(pi[n]) != '.'; n += 2) {
39923890Sjaap 				dx = absmot(pi[n]);
40023890Sjaap 				if (isnmot(pi[n]))
40123890Sjaap 					dx = -dx;
40223890Sjaap 				dy = absmot(pi[n+1]);
40323890Sjaap 				if (isnmot(pi[n+1]))
40423890Sjaap 					dy = -dy;
40523911Sjaap 				fdprintf(ptid, " %d %d", dx, dy);
40623890Sjaap 				hpos += dx;
40723890Sjaap 				vpos += dy;
40823890Sjaap 			}
40923911Sjaap 			fdprintf(ptid, "\n");
41023890Sjaap 			break;
411*58242Ssklower 
412*58242Ssklower 		case DRAWPOLY:	/* polygon with stipple */
413*58242Ssklower 		case DRAWUBPOLY:/* polygon, stipple, no border */
414*58242Ssklower 			if (xstip != stip) ptstip();
415*58242Ssklower 			fdprintf(ptid, "D%c %d", cbits(pi[1]), dx);
416*58242Ssklower 			goto writecoords;
41723890Sjaap 		}
418*58242Ssklower 		for (n = 2; cbits(pi[n]) != '.'; n++)
41923890Sjaap 			;
42023890Sjaap 		outsize = n + 1;
42123890Sjaap 	} else if (k < 128) {
42223890Sjaap 		/* try to go faster and compress output */
42323890Sjaap 		/* by printing nnc for small positive motion followed by c */
42423890Sjaap 		/* kludgery; have to make sure set all the vars too */
42523890Sjaap 		if (esc > 0 && esc < 100) {
42623890Sjaap 			oput(esc / 10 + '0');
42723890Sjaap 			oput(esc % 10 + '0');
42823890Sjaap 			oput(k);
42923890Sjaap 			hpos += esc;
43023890Sjaap 			esc = 0;
43123890Sjaap 		} else {
43223890Sjaap 			if (esc)
43323890Sjaap 				ptesc();
43423911Sjaap 			oput('c');
43523911Sjaap 			oput(k);
43623911Sjaap 			oput('\n');
43723890Sjaap 		}
43823890Sjaap 	} else {
43923890Sjaap 		if (esc)
44023890Sjaap 			ptesc();
44123911Sjaap 		if (k >= nchtab + 128)
44223911Sjaap 			fdprintf(ptid, "N%d\n", k - (nchtab+128));
44323911Sjaap 		else
44423911Sjaap 			fdprintf(ptid, "C%s\n", &chname[chtab[k - 128]]);
44523890Sjaap 	}
44623890Sjaap 	if (bd) {
44723890Sjaap 		bd -= HOR;
44823890Sjaap 		if (esc += bd)
44923890Sjaap 			ptesc();
45023890Sjaap 		if (k < 128) {
45123911Sjaap 			fdprintf(ptid, "c%c\n", k);
45223911Sjaap 		} else if (k >= nchtab + 128) {
45323911Sjaap 			fdprintf(ptid, "N%d\n", k - (nchtab+128));
45423890Sjaap 		} else
45523911Sjaap 			fdprintf(ptid, "C%s\n", &chname[chtab[k - 128]]);
45623890Sjaap 		if (z)
45723890Sjaap 			esc -= bd;
45823890Sjaap 	}
45923890Sjaap 	esc += w;
46023890Sjaap 	return(outsize);
46123890Sjaap }
46223890Sjaap 
ptps()46323890Sjaap ptps()
46423890Sjaap {
46523890Sjaap 	register i, j, k;
46623890Sjaap 
46723890Sjaap 	i = xpts;
46823890Sjaap 	for (j = 0; i > (k = pstab[j]); j++)
46923890Sjaap 		if (!k) {
47023890Sjaap 			k = pstab[--j];
47123890Sjaap 			break;
47223890Sjaap 		}
47323911Sjaap 	fdprintf(ptid, "s%d\n", k);	/* really should put out string rep of size */
47423890Sjaap 	mpts = i;
47523890Sjaap }
47623890Sjaap 
ptstip()477*58242Ssklower ptstip()
478*58242Ssklower {
479*58242Ssklower 	xstip = stip;
480*58242Ssklower 	fdprintf(ptid, "i%d\n", xstip);
481*58242Ssklower }
482*58242Ssklower 
483*58242Ssklower 
ptfont()48423890Sjaap ptfont()
48523890Sjaap {
48623911Sjaap 	extern char *unpair();
48723890Sjaap 	mfont = xfont;
48845479Skarels 	if( xfont > physfonts) {
48945479Skarels 		if (xfont != zfont) {
49045479Skarels 			register char *temp = unpair(fontlab[xfont]);
49145479Skarels 			ptfpcmd(0, temp);	/* Put the desired font in the
49245479Skarels 						 * fontcache of the filter */
49345479Skarels 		}
49423911Sjaap 		fdprintf(ptid, "f0\n");	/* make sure that it gets noticed */
49545479Skarels 		zfont = xfont;
49623890Sjaap 	} else
49723911Sjaap 		fdprintf(ptid, "f%d\n", xfont);
49823890Sjaap }
49923890Sjaap 
ptfpcmd(f,s)50023890Sjaap ptfpcmd(f, s)
50123890Sjaap int	f;
50223890Sjaap char	*s;
50323890Sjaap {
50423890Sjaap 	if (ascii)
50523890Sjaap 		return;
50623911Sjaap 	fdprintf(ptid, "x font %d %s\n", f, s);
50723890Sjaap }
50823890Sjaap 
ptlead()50923890Sjaap ptlead()
51023890Sjaap {
51123890Sjaap 	vpos += lead;
51223890Sjaap 	if (!ascii)
51323911Sjaap 		fdprintf(ptid, "V%d\n", vpos);
51423890Sjaap 	lead = 0;
51523890Sjaap }
51623890Sjaap 
ptesc()51723890Sjaap ptesc()
51823890Sjaap {
51923890Sjaap 	hpos += esc;
52023911Sjaap 	if (esc > 0) {
52123911Sjaap 		oput('h');
52223911Sjaap 		if (esc>=10 && esc<100) {
52323911Sjaap 			oput(esc/10 + '0');
52423911Sjaap 			oput(esc%10 + '0');
52523911Sjaap 		} else
52623911Sjaap 			fdprintf(ptid, "%d", esc);
52723911Sjaap 	} else
52823911Sjaap 		fdprintf(ptid, "H%d\n", hpos);
52923890Sjaap 	esc = 0;
53023890Sjaap }
53123890Sjaap 
newpage(n)53223890Sjaap newpage(n)	/* called at end of each output page (we hope) */
53323890Sjaap {
53423911Sjaap 	int i;
53523911Sjaap 
53623890Sjaap 	ptlead();
53723890Sjaap 	vpos = 0;
53823890Sjaap 	if (ascii)
53923890Sjaap 		return;
54023911Sjaap 	fdprintf(ptid, "p%d\n", n);	/* new page */
54145479Skarels 	if (fontbase[zfont]->namefont && fontbase[zfont]->namefont[0])
54245479Skarels 		fdprintf(ptid, "x font 0 %s\n", fontbase[zfont]->namefont);
54345479Skarels 	for (i = 1; i <= physfonts; i++)
54423911Sjaap 		if (fontbase[i]->namefont && fontbase[i]->namefont[0])
54523911Sjaap 			fdprintf(ptid, "x font %d %s\n", i, fontbase[i]->namefont);
54623890Sjaap 	ptps();
54723890Sjaap 	ptfont();
54823890Sjaap }
54923890Sjaap 
pttrailer()55023890Sjaap pttrailer()
55123890Sjaap {
55223911Sjaap 	fdprintf(ptid, "x trailer\n");
55323890Sjaap }
55423890Sjaap 
ptstop()55523890Sjaap ptstop()
55623890Sjaap {
55723911Sjaap 	fdprintf(ptid, "x stop\n");
55823890Sjaap }
55923890Sjaap 
dostop()56023890Sjaap dostop()
56123890Sjaap {
56223890Sjaap 	if (ascii)
56323890Sjaap 		return;
56423890Sjaap 	ptlead();
56523890Sjaap 	vpos = 0;
56623911Sjaap 	/* fdprintf(ptid, "x xxx end of page\n");*/
56723890Sjaap 	if (!nofeed)
56823890Sjaap 		pttrailer();
56923890Sjaap 	ptlead();
57023911Sjaap 	fdprintf(ptid, "x pause\n");
57123890Sjaap 	flusho();
57223890Sjaap 	mpts = mfont = 0;
57323890Sjaap 	ptesc();
57423890Sjaap 	esc = po;
57523890Sjaap 	hpos = vpos = 0;	/* probably in wrong place */
57623890Sjaap }
577