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