1*23969Sjaap #ifndef lint
2*23969Sjaap static char sccsid[] = "@(#)label.c	1.1 (CWI) 85/07/19";
3*23969Sjaap #endif lint
4*23969Sjaap #include <stdio.h>
5*23969Sjaap #include "grap.h"
6*23969Sjaap #include "y.tab.h"
7*23969Sjaap 
8*23969Sjaap int	pointsize	= 10;	/* assumed pointsize to start */
9*23969Sjaap int	ps_set		= 0;	/* someone has set pointsize explicitly */
10*23969Sjaap 
11*23969Sjaap double	textht	= 1.0/6.0;	/* 6 lines/inch */
12*23969Sjaap double	textwid = 1;		/* width of text box for vertical */
13*23969Sjaap 
14*23969Sjaap double	lab_up	= 0.0;		/* extra motion for label */
15*23969Sjaap double	lab_rt	= 0.0;		/* extra motion for label */
16*23969Sjaap 
labelmove(dir,amt)17*23969Sjaap labelmove(dir, amt)	/* record direction & motion of position corr */
18*23969Sjaap 	int dir;
19*23969Sjaap 	double amt;
20*23969Sjaap {
21*23969Sjaap 	switch (dir) {
22*23969Sjaap 	case UP:	lab_up += amt; break;
23*23969Sjaap 	case DOWN:	lab_up -= amt; break;
24*23969Sjaap 	case LEFT:	lab_rt -= amt; break;
25*23969Sjaap 	case RIGHT:	lab_rt += amt; break;
26*23969Sjaap 	}
27*23969Sjaap }
28*23969Sjaap 
label(label_side,stringlist)29*23969Sjaap label(label_side, stringlist)	/* stick label on label_side */
30*23969Sjaap 	int label_side;
31*23969Sjaap 	Attr *stringlist;
32*23969Sjaap {
33*23969Sjaap 	int i, m;
34*23969Sjaap 	Attr *ap, *nap;
35*23969Sjaap 
36*23969Sjaap 	fprintf(tfd, "\ttextht = %g\n", textht);
37*23969Sjaap 	if (label_side == LEFT || label_side == RIGHT) {
38*23969Sjaap 		textwid = 0;
39*23969Sjaap 		for (ap = stringlist; ap != NULL; ap = ap->next)
40*23969Sjaap 			if ((m = strlen(ap->sval)) > textwid)
41*23969Sjaap 				textwid = m;
42*23969Sjaap 		textwid /= 15;	/* estimate width at 15 chars/inch */
43*23969Sjaap 		fprintf(tfd, "\ttextwid = %g\n", textwid);
44*23969Sjaap 	}
45*23969Sjaap 	fprintf(tfd, "Label:\t%s", slprint(stringlist));
46*23969Sjaap 	freeattr(stringlist);
47*23969Sjaap 	switch (label_side) {
48*23969Sjaap 	case BOT:
49*23969Sjaap 	case 0:
50*23969Sjaap 		fprintf(tfd, " with .n at Frame.s - (0,2 * textht)");
51*23969Sjaap 		break;
52*23969Sjaap 	case LEFT:
53*23969Sjaap 		fprintf(tfd, " wid textwid with .e at Frame.w - (0.2,0)");
54*23969Sjaap 		break;
55*23969Sjaap 	case RIGHT:
56*23969Sjaap 		fprintf(tfd, " wid textwid with .w at Frame.e + (0.2,0)");
57*23969Sjaap 		break;
58*23969Sjaap 	case TOP:
59*23969Sjaap 		fprintf(tfd, " with .s at Frame.n + (0,2 * textht)");
60*23969Sjaap 		break;
61*23969Sjaap 	}
62*23969Sjaap 	lab_adjust();
63*23969Sjaap 	fprintf(tfd, "\n");
64*23969Sjaap 	label_side = BOT;
65*23969Sjaap }
66*23969Sjaap 
lab_adjust()67*23969Sjaap lab_adjust()	/* add a string to adjust labels, ticks, etc. */
68*23969Sjaap {
69*23969Sjaap 	if (lab_up != 0.0 || lab_rt != 0.0)
70*23969Sjaap 		fprintf(tfd, " + (%g,%g)", lab_rt, lab_up);
71*23969Sjaap }
72*23969Sjaap 
sizeit(ap)73*23969Sjaap char *sizeit(ap)		/* add \s..\s to ap->sval */
74*23969Sjaap 	Attr *ap;
75*23969Sjaap {
76*23969Sjaap 	int n;
77*23969Sjaap 	static char buf[1000];
78*23969Sjaap 
79*23969Sjaap 	if (!ap->op) {	/* no explicit size command */
80*23969Sjaap 		if (ps_set) {
81*23969Sjaap 			sprintf(buf, "\\s%d%s\\s0", pointsize, ap->sval);
82*23969Sjaap 			return buf;
83*23969Sjaap 		} else
84*23969Sjaap 			return ap->sval;
85*23969Sjaap 	} else if (!ps_set) {	/* explicit size but no global size */
86*23969Sjaap 		n = (int) ap->fval;
87*23969Sjaap 		switch (ap->op) {
88*23969Sjaap 		case ' ':	/* absolute size */
89*23969Sjaap 			sprintf(buf, "\\s%d%s\\s0", n, ap->sval);
90*23969Sjaap 			break;
91*23969Sjaap 		case '+':	/* better be only one digit! */
92*23969Sjaap 			sprintf(buf, "\\s+%d%s\\s-%d", n, ap->sval, n);
93*23969Sjaap 			break;
94*23969Sjaap 		case '-':
95*23969Sjaap 			sprintf(buf, "\\s-%d%s\\s+%d", n, ap->sval, n);
96*23969Sjaap 			break;
97*23969Sjaap 		case '*':
98*23969Sjaap 		case '/':
99*23969Sjaap 			return ap->sval;	/* ignore for now */
100*23969Sjaap 		}
101*23969Sjaap 		return buf;
102*23969Sjaap 	} else {
103*23969Sjaap 		/* explicit size and a global background size */
104*23969Sjaap 		n = (int) ap->fval;
105*23969Sjaap 		switch (ap->op) {
106*23969Sjaap 		case ' ':	/* absolute size */
107*23969Sjaap 			sprintf(buf, "\\s%d%s\\s0", n, ap->sval);
108*23969Sjaap 			break;
109*23969Sjaap 		case '+':
110*23969Sjaap 			sprintf(buf, "\\s%d%s\\s0", pointsize+n, ap->sval);
111*23969Sjaap 			break;
112*23969Sjaap 		case '-':
113*23969Sjaap 			sprintf(buf, "\\s%d%s\\s0", pointsize-n, ap->sval);
114*23969Sjaap 			break;
115*23969Sjaap 		case '*':
116*23969Sjaap 		case '/':
117*23969Sjaap 			return ap->sval;	/* ignore for now */
118*23969Sjaap 		}
119*23969Sjaap 		return buf;
120*23969Sjaap 	}
121*23969Sjaap }
122