123954Sjaap #ifndef lint
2*24091Sjaap static char sccsid[] = "@(#)print.c	3.1 (CWI) 85/07/30";
323954Sjaap #endif lint
4*24091Sjaap 
523954Sjaap #include	<stdio.h>
623954Sjaap #include	"pic.h"
723954Sjaap #include	"y.tab.h"
print()823954Sjaap print()
923954Sjaap {
1024020Sjaap 	obj *p;
1124020Sjaap 	int i, j, k, m;
1223954Sjaap 	float x0, y0, x1, y1, ox, oy, dx, dy, ndx, ndy;
1323954Sjaap 
1423954Sjaap 	for (i = 0; i < nobj; i++) {
1523954Sjaap 		p = objlist[i];
1623954Sjaap 		ox = p->o_x;
1723954Sjaap 		oy = p->o_y;
1823954Sjaap 		if (p->o_count >= 1)
1923954Sjaap 			x1 = p->o_val[0];
2023954Sjaap 		if (p->o_count >= 2)
2123954Sjaap 			y1 = p->o_val[1];
2223954Sjaap 		m = p->o_mode;
2323954Sjaap 		switch (p->o_type) {
2423954Sjaap 		case TROFF:
2523954Sjaap 			troff(text[p->o_nt1].t_val);
2623954Sjaap 			break;
2723954Sjaap 		case BOX:
2823954Sjaap 		case BLOCK:
2923954Sjaap 			move(ox, oy);
3023954Sjaap 			dotext(p);	/* if there are any text strings */
3123954Sjaap 			x0 = ox - x1 / 2;
3223954Sjaap 			y0 = oy - y1 / 2;
3323954Sjaap 			x1 = ox + x1 / 2;
3423954Sjaap 			y1 = oy + y1 / 2;
3523954Sjaap 			if (p->o_attr & INVIS || p->o_type == BLOCK)
3623954Sjaap 				;	/* nothing at all */
3724020Sjaap 			else if (p->o_attr & (DOTBIT|DASHBIT))
3824020Sjaap 				dotbox(x0, y0, x1, y1, p->o_attr, p->o_ddval);
3924020Sjaap 			else
4023954Sjaap 				box(x0, y0, x1, y1);
4123954Sjaap 			if (ishor(m))
4223954Sjaap 				move(isright(m) ? x1 : x0, oy);	/* right side */
4323954Sjaap 			else
4423954Sjaap 				move(ox, isdown(m) ? y0 : y1);	/* bottom */
4523954Sjaap 			break;
4623954Sjaap 		case BLOCKEND:
4723954Sjaap 			break;
4823954Sjaap 		case CIRCLE:
4923954Sjaap 			move(ox, oy);
5023954Sjaap 			dotext(p);
5123954Sjaap 			if ((p->o_attr & INVIS) == 0)
5223954Sjaap 				circle(ox, oy, x1);
5323954Sjaap 			if (ishor(m))
5423954Sjaap 				move(ox + isright(m) ? x1 : -x1, oy);
5523954Sjaap 			else
5623954Sjaap 				move(ox, oy + isup(m) ? x1 : -x1);
5723954Sjaap 			break;
5823954Sjaap 		case ELLIPSE:
5923954Sjaap 			move(ox, oy);
6023954Sjaap 			dotext(p);
6123954Sjaap 			if ((p->o_attr & INVIS) == 0)
6223954Sjaap 				ellipse(ox, oy, x1, y1);
6323954Sjaap 			if (ishor(m))
6423954Sjaap 				move(ox + isright(m) ? x1 : -x1, oy);
6523954Sjaap 			else
6623954Sjaap 				move(ox, oy - isdown(m) ? y1 : -y1);
6723954Sjaap 			break;
6823954Sjaap 		case ARC:
6923954Sjaap 			move(ox, oy);
7023954Sjaap 			dotext(p);
7123954Sjaap 			if (p->o_attr & HEAD1)
7223954Sjaap 				arrow(x1 - (y1 - oy), y1 + (x1 - ox),
7324020Sjaap 				      x1, y1, p->o_val[4], p->o_val[5], p->o_val[5]/p->o_val[6]/2, p->o_nhead);
7423954Sjaap                         if (p->o_attr & INVIS)
7523954Sjaap                                 /* probably wrong when it's cw */
7623954Sjaap                                 move(x1, y1);
7723954Sjaap                         else
7824020Sjaap 				arc(ox, oy, x1, y1, p->o_val[2], p->o_val[3]);
7923954Sjaap 			if (p->o_attr & HEAD2)
8023954Sjaap 				arrow(p->o_val[2] + p->o_val[3] - oy, p->o_val[3] - (p->o_val[2] - ox),
8124020Sjaap 				      p->o_val[2], p->o_val[3], p->o_val[4], p->o_val[5], -p->o_val[5]/p->o_val[6]/2, p->o_nhead);
8223954Sjaap 			if (p->o_attr & CW_ARC)
8323954Sjaap 				move(x1, y1);	/* because drawn backwards */
8423954Sjaap 			break;
8523954Sjaap 		case LINE:
8623954Sjaap 		case ARROW:
8723954Sjaap 		case SPLINE:
8823954Sjaap 			move((ox + x1)/2, (oy + y1)/2);	/* center */
8923954Sjaap 			dotext(p);
9023954Sjaap 			if (p->o_attr & HEAD1)
9124020Sjaap 				arrow(ox + p->o_val[5], oy + p->o_val[6], ox, oy, p->o_val[2], p->o_val[3], 0.0, p->o_nhead);
9223954Sjaap                         if (p->o_attr & INVIS)
9323954Sjaap                                 move(x1, y1);
9423954Sjaap 			else if (p->o_type == SPLINE)
95*24091Sjaap 				spline(ox, oy, p->o_val[4], &p->o_val[5], p->o_attr & (DOTBIT|DASHBIT), p->o_ddval);
9623954Sjaap 			else {
9723954Sjaap 				dx = ox;
9823954Sjaap 				dy = oy;
9924020Sjaap 				for (k=0, j=5; k < p->o_val[4]; k++, j += 2) {
10023954Sjaap 					ndx = dx + p->o_val[j];
10123954Sjaap 					ndy = dy + p->o_val[j+1];
10224020Sjaap 					if (p->o_attr & (DOTBIT|DASHBIT))
10324020Sjaap 						dotline(dx, dy, ndx, ndy, p->o_attr, p->o_ddval);
10424020Sjaap 					else
10523954Sjaap 						line(dx, dy, ndx, ndy);
10623954Sjaap 					dx = ndx;
10723954Sjaap 					dy = ndy;
10823954Sjaap 				}
10923954Sjaap 			}
11023954Sjaap 			if (p->o_attr & HEAD2) {
11123954Sjaap 				dx = ox;
11223954Sjaap 				dy = oy;
11324020Sjaap 				for (k = 0, j = 5; k < p->o_val[4] - 1; k++, j += 2) {
11423954Sjaap 					dx += p->o_val[j];
11523954Sjaap 					dy += p->o_val[j+1];
11623954Sjaap 				}
11724020Sjaap 				arrow(dx, dy, x1, y1, p->o_val[2], p->o_val[3], 0.0, p->o_nhead);
11823954Sjaap 			}
11923954Sjaap 			break;
12023954Sjaap 		case MOVE:
12124020Sjaap 		case TEXT:
12223954Sjaap 			move(ox, oy);
12323954Sjaap 			dotext(p);
12423954Sjaap 			break;
12523954Sjaap 		}
12623954Sjaap 	}
12723954Sjaap }
12823954Sjaap 
dotline(x0,y0,x1,y1,ddtype,ddval)12923954Sjaap dotline(x0, y0, x1, y1, ddtype, ddval) /* dotted line */
13023954Sjaap 	float x0, y0, x1, y1;
13123954Sjaap 	int ddtype;
13223954Sjaap 	float ddval;
13323954Sjaap {
13423954Sjaap 	static float prevval = 0.05;	/* 20 per inch by default */
13523954Sjaap 	int i, numdots;
13623954Sjaap 	double a, b, sqrt(), dx, dy;
13723954Sjaap 
13823954Sjaap 	if (ddval == 0)
13923954Sjaap 		ddval = prevval;
14023954Sjaap 	prevval = ddval;
14123954Sjaap 	/* don't save dot/dash value */
14223954Sjaap 	dx = x1 - x0;
14323954Sjaap 	dy = y1 - y0;
14424020Sjaap 	if (ddtype & DOTBIT) {
14523954Sjaap 		numdots = sqrt(dx*dx + dy*dy) / prevval + 0.5;
14623954Sjaap 		if (numdots > 0)
14723954Sjaap 			for (i = 0; i <= numdots; i++) {
14823954Sjaap 				a = (float) i / (float) numdots;
14923954Sjaap 				move(x0 + (a * dx), y0 + (a * dy));
15023954Sjaap 				dot();
15123954Sjaap 			}
15224020Sjaap 	} else if (ddtype & DASHBIT) {
15323954Sjaap 		double d, dashsize, spacesize;
15423954Sjaap 		d = sqrt(dx*dx + dy*dy);
15523954Sjaap 		if (d <= 2 * prevval) {
15623954Sjaap 			line(x0, y0, x1, y1);
15723954Sjaap 			return;
15823954Sjaap 		}
15923954Sjaap 		numdots = d / (2 * prevval) + 1;	/* ceiling */
16023954Sjaap 		dashsize = prevval;
16123954Sjaap 		spacesize = (d - numdots * dashsize) / (numdots - 1);
16223954Sjaap 		for (i = 0; i < numdots-1; i++) {
16323954Sjaap 			a = i * (dashsize + spacesize) / d;
16423954Sjaap 			b = a + dashsize / d;
16523954Sjaap 			line(x0 + (a*dx), y0 + (a*dy), x0 + (b*dx), y0 + (b*dy));
16623954Sjaap 			a = b;
16723954Sjaap 			b = a + spacesize / d;
16823954Sjaap 			move(x0 + (a*dx), y0 + (a*dy));
16923954Sjaap 		}
17023954Sjaap 		line(x0 + (b * dx), y0 + (b * dy), x1, y1);
17123954Sjaap 	}
17223954Sjaap 	prevval = 0.05;
17323954Sjaap }
17423954Sjaap 
dotbox(x0,y0,x1,y1,ddtype,ddval)17523954Sjaap dotbox(x0, y0, x1, y1, ddtype, ddval)	/* dotted or dashed box */
17623954Sjaap 	float x0, y0, x1, y1;
17723954Sjaap 	int ddtype;
17823954Sjaap 	float ddval;
17923954Sjaap {
18023954Sjaap 	dotline(x0, y0, x1, y0, ddtype, ddval);
18123954Sjaap 	dotline(x1, y0, x1, y1, ddtype, ddval);
18223954Sjaap 	dotline(x1, y1, x0, y1, ddtype, ddval);
18323954Sjaap 	dotline(x0, y1, x0, y0, ddtype, ddval);
18423954Sjaap }
18523954Sjaap 
dotext(p)18623954Sjaap dotext(p)	/* print text strings of p in proper vertical spacing */
18724020Sjaap 	obj *p;
18823954Sjaap {
18923954Sjaap 	int i, nhalf;
19023954Sjaap 
19123954Sjaap 	nhalf = p->o_nt2 - p->o_nt1 - 1;
19223954Sjaap 	for (i = p->o_nt1; i < p->o_nt2; i++) {
19323954Sjaap 		label(text[i].t_val, text[i].t_type, nhalf);
19423954Sjaap 		nhalf -= 2;
19523954Sjaap 	}
19623954Sjaap }
197