xref: /illumos-gate/usr/src/cmd/troff/nroff.d/n6.c (revision 62877672b62bfe1e971061803b2a9c64897c13c3)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License, Version 1.0 only
6  * (the "License").  You may not use this file except in compliance
7  * with the License.
8  *
9  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10  * or http://www.opensolaris.org/os/licensing.
11  * See the License for the specific language governing permissions
12  * and limitations under the License.
13  *
14  * When distributing Covered Code, include this CDDL HEADER in each
15  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16  * If applicable, add the following below this CDDL HEADER, with the
17  * fields enclosed by brackets "[]" replaced with your own identifying
18  * information: Portions Copyright [yyyy] [name of copyright owner]
19  *
20  * CDDL HEADER END
21  */
22 /*
23  * Copyright 2017 Gary Mills
24  * Copyright 2003 Sun Microsystems, Inc.  All rights reserved.
25  * Use is subject to license terms.
26  */
27 
28 /*	Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T	*/
29 /*	  All Rights Reserved  	*/
30 
31 /*
32  * University Copyright- Copyright (c) 1982, 1986, 1988
33  * The Regents of the University of California
34  * All Rights Reserved
35  *
36  * University Acknowledgment- Portions of this document are derived from
37  * software developed by the University of California, Berkeley, and its
38  * contributors.
39  */
40 
41 #include "tdef.h"
42 #include "tw.h"
43 #include "ext.h"
44 #include <ctype.h>
45 
46 /*
47  * n6.c -- width functions, sizes and fonts
48 */
49 
50 int	bdtab[NFONT+1] ={ 0, 0, 0, 3, 3, 0, };
51 int	sbold = 0;
52 int	fontlab[NFONT+1] = { 0, 'R', 'I', 'B', PAIR('B','I'), 'S', 0 };
53 
54 extern	int	nchtab;
55 
56 int
57 width(j)
58 tchar j;
59 {
60 	int	i, k;
61 
62 	if (j & (ZBIT|MOT)) {
63 		if (iszbit(j))
64 			return(0);
65 		if (isvmot(j))
66 			return(0);
67 		k = absmot(j);
68 		if (isnmot(j))
69 			k = -k;
70 		return(k);
71 	}
72 	i = cbits(j);
73 	if (i < ' ') {
74 		if (i == '\b')
75 			return(-widthp);
76 		if (i == PRESC)
77 			i = eschar;
78 		else if (iscontrol(i))
79 			return(0);
80 	}
81 	if (i==ohc)
82 		return(0);
83 #ifdef EUC
84 #ifdef NROFF
85 	if (multi_locale) {
86 		if ((j & MBMASK) || (j & CSMASK)) {
87 			switch(j & MBMASK) {
88 				case BYTE_CHR:
89 				case LASTOFMB:
90 					k = t.Char * csi_width[cs(j)];
91 					break;
92 				default:
93 					k = 0;
94 					break;
95 			}
96 			widthp = k;
97 			return(k);
98 		}
99 	}
100 	i &= 0x1ff;
101 #endif /* NROFF */
102 #endif /* EUC */
103 	i = trtab[i];
104 	if (i < 32)
105 		return(0);
106 	k = t.width[i] * t.Char;
107 	widthp = k;
108 	return(k);
109 }
110 
111 
112 tchar setch()
113 {
114 	int	j;
115 	char	temp[10];
116 	char	*s;
117 
118 	s = temp;
119 	if ((*s++ = getach()) == 0 || (*s++ = getach()) == 0)
120 		return(0);
121 	*s = '\0';
122 	if ((j = findch(temp)) > 0)
123 		return j | chbits;
124 	else
125 		return 0;
126 }
127 
128 tchar setabs()		/* set absolute char from \C'...' */
129 {			/* for now, a no-op */
130 	int i, n, nf;
131 
132 	getch();
133 	n = 0;
134 	n = inumb(&n);
135 	getch();
136 	if (nonumb)
137 		return 0;
138 	return n + nchtab + _SPECCHAR_ST;
139 }
140 
141 int
142 findft(i)
143 int	i;
144 {
145 	int	k;
146 
147 	if ((k = i - '0') >= 0 && k <= nfonts && k < smnt)
148 		return(k);
149 	for (k = 0; fontlab[k] != i; k++)
150 		if (k > nfonts)
151 			return(-1);
152 	return(k);
153 }
154 
155 int
156 caseps()
157 {
158 	return (0);
159 }
160 
161 int
162 mchbits()
163 {
164 	chbits = 0;
165 	setfbits(chbits, font);
166 	sps = width(' ' | chbits);
167 
168 	return (0);
169 }
170 
171 
172 int
173 setps()
174 {
175 	int	i, j;
176 
177 	i = cbits(getch());
178 	if (ischar(i) && isdigit(i)) {		/* \sd or \sdd */
179 		i -= '0';
180 		if (i == 0)		/* \s0 */
181 			;
182 		else if (i <= 3 && ischar(j = cbits(ch = getch())) &&
183 		    isdigit(j)) {	/* \sdd */
184 			ch = 0;
185 		}
186 	} else if (i == '(') {		/* \s(dd */
187 		getch();
188 		getch();
189 	} else if (i == '+' || i == '-') {	/* \s+, \s- */
190 		j = cbits(getch());
191 		if (ischar(j) && isdigit(j)) {		/* \s+d, \s-d */
192 			;
193 		} else if (j == '(') {		/* \s+(dd, \s-(dd */
194 			getch();
195 			getch();
196 		}
197 	}
198 
199 	return (0);
200 }
201 
202 
203 tchar setht()		/* set character height from \H'...' */
204 {
205 	tchar c;
206 
207 	getch();
208 	(void) inumb(&apts);
209 	getch();
210 	return(0);
211 }
212 
213 
214 tchar setslant()		/* set slant from \S'...' */
215 {
216 	int	n;
217 	tchar c;
218 
219 	getch();
220 	n = 0;
221 	n = inumb(&n);
222 	getch();
223 	return(0);
224 }
225 
226 
227 int
228 caseft()
229 {
230 	skip();
231 	setfont(1);
232 
233 	return (0);
234 }
235 
236 
237 int
238 setfont(a)
239 int	a;
240 {
241 	int	i, j;
242 
243 	if (a)
244 		i = getrq();
245 	else
246 		i = getsn();
247 	if (!i || i == 'P') {
248 		j = font1;
249 		goto s0;
250 	}
251 	if (i == 'S' || i == '0')
252 		return (0);
253 	if ((j = findft(i, fontlab)) == -1)
254 		return (0);
255 s0:
256 	font1 = font;
257 	font = j;
258 	mchbits();
259 
260 	return (0);
261 }
262 
263 
264 int
265 setwd()
266 {
267 	int	base, wid;
268 	tchar i;
269 	int	delim, emsz, k;
270 	int	savhp, savapts, savapts1, savfont, savfont1, savpts, savpts1;
271 
272 	base = numtab[ST].val = wid = numtab[CT].val = 0;
273 	if (ismot(i = getch()))
274 		return (0);
275 	delim = cbits(i);
276 	savhp = numtab[HP].val;
277 	numtab[HP].val = 0;
278 	savapts = apts;
279 	savapts1 = apts1;
280 	savfont = font;
281 	savfont1 = font1;
282 	savpts = pts;
283 	savpts1 = pts1;
284 	setwdf++;
285 	while (cbits(i = getch()) != delim && !nlflg) {
286 		k = width(i);
287 		wid += k;
288 		numtab[HP].val += k;
289 		if (!ismot(i)) {
290 			emsz = (INCH * pts + 36) / 72;
291 		} else if (isvmot(i)) {
292 			k = absmot(i);
293 			if (isnmot(i))
294 				k = -k;
295 			base -= k;
296 			emsz = 0;
297 		} else
298 			continue;
299 		if (base < numtab[SB].val)
300 			numtab[SB].val = base;
301 		if ((k = base + emsz) > numtab[ST].val)
302 			numtab[ST].val = k;
303 	}
304 	setn1(wid, 0, (tchar) 0);
305 	numtab[HP].val = savhp;
306 	apts = savapts;
307 	apts1 = savapts1;
308 	font = savfont;
309 	font1 = savfont1;
310 	pts = savpts;
311 	pts1 = savpts1;
312 	mchbits();
313 	setwdf = 0;
314 
315 	return (0);
316 }
317 
318 
319 tchar vmot()
320 {
321 	dfact = lss;
322 	vflag++;
323 	return(mot());
324 }
325 
326 
327 tchar hmot()
328 {
329 	dfact = EM;
330 	return(mot());
331 }
332 
333 
334 tchar mot()
335 {
336 	int j, n;
337 	tchar i;
338 
339 	j = HOR;
340 	getch(); /*eat delim*/
341 	if (n = atoi()) {
342 		if (vflag)
343 			j = VERT;
344 		i = makem(quant(n, j));
345 	} else
346 		i = 0;
347 	getch();
348 	vflag = 0;
349 	dfact = 1;
350 	return(i);
351 }
352 
353 
354 tchar sethl(k)
355 int	k;
356 {
357 	int	j;
358 	tchar i;
359 
360 	j = t.Halfline;
361 	if (k == 'u')
362 		j = -j;
363 	else if (k == 'r')
364 		j = -2 * j;
365 	vflag++;
366 	i = makem(j);
367 	vflag = 0;
368 	return(i);
369 }
370 
371 
372 tchar makem(i)
373 int	i;
374 {
375 	tchar j;
376 
377 	if ((j = i) < 0)
378 		j = -j;
379 	j |= MOT;
380 	if (i < 0)
381 		j |= NMOT;
382 	if (vflag)
383 		j |= VMOT;
384 	return(j);
385 }
386 
387 
388 tchar getlg(i)
389 tchar	i;
390 {
391 	return(i);
392 }
393 
394 
395 int
396 caselg()
397 {
398 	return (0);
399 }
400 
401 
402 int
403 casefp()
404 {
405 	int	i, j;
406 
407 	skip();
408 	if ((i = cbits(getch()) - '0') < 0 || i > nfonts)
409 		return (0);
410 	if (skip() || !(j = getrq()))
411 		return (0);
412 	fontlab[i] = j;
413 
414 	return (0);
415 }
416 
417 
418 int
419 casecs()
420 {
421 	return (0);
422 }
423 
424 
425 int
426 casebd()
427 {
428 	int	i, j, k;
429 
430 	k = 0;
431 bd0:
432 	if (skip() || !(i = getrq()) || (j = findft(i)) == -1) {
433 		if (k)
434 			goto bd1;
435 		else
436 			return (0);
437 	}
438 	if (j == smnt) {
439 		k = smnt;
440 		goto bd0;
441 	}
442 	if (k) {
443 		sbold = j;
444 		j = k;
445 	}
446 bd1:
447 	skip();
448 	noscale++;
449 	bdtab[j] = atoi();
450 	noscale = 0;
451 
452 	return (0);
453 }
454 
455 
456 int
457 casevs()
458 {
459 	int	i;
460 
461 	skip();
462 	vflag++;
463 	dfact = INCH; /*default scaling is points!*/
464 	dfactd = 72;
465 	res = VERT;
466 	i = inumb(&lss);
467 	if (nonumb)
468 		i = lss1;
469 	if (i < VERT)
470 		i = VERT;	/* was VERT */
471 	lss1 = lss;
472 	lss = i;
473 
474 	return (0);
475 }
476 
477 
478 
479 int
480 casess()
481 {
482 	return (0);
483 }
484 
485 
486 tchar xlss()
487 {
488 	/* stores \x'...' into
489 	 * two successive tchars.
490 	 * the first contains HX, the second the value,
491 	 * encoded as a vertical motion.
492 	 * decoding is done in n2.c by pchar().
493 	 */
494 	int	i;
495 
496 	getch();
497 	dfact = lss;
498 	i = quant(atoi(), VERT);
499 	dfact = 1;
500 	getch();
501 	if (i >= 0)
502 		*pbp++ = MOT | VMOT | i;
503 	else
504 		*pbp++ = MOT | VMOT | NMOT | -i;
505 	return(HX);
506 }
507