#include "tdef.h"
#include "tw.h"
#include "ext.h"
#include <ctype.h>
int bdtab[NFONT+1] ={ 0, 0, 0, 3, 3, 0, };
int sbold = 0;
int fontlab[NFONT+1] = { 0, 'R', 'I', 'B', PAIR('B','I'), 'S', 0 };
extern int nchtab;
int
width(j)
tchar j;
{
int i, k;
if (j & (ZBIT|MOT)) {
if (iszbit(j))
return(0);
if (isvmot(j))
return(0);
k = absmot(j);
if (isnmot(j))
k = -k;
return(k);
}
i = cbits(j);
if (i < ' ') {
if (i == '\b')
return(-widthp);
if (i == PRESC)
i = eschar;
else if (iscontrol(i))
return(0);
}
if (i==ohc)
return(0);
#ifdef EUC
#ifdef NROFF
if (multi_locale) {
if ((j & MBMASK) || (j & CSMASK)) {
switch(j & MBMASK) {
case BYTE_CHR:
case LASTOFMB:
k = t.Char * csi_width[cs(j)];
break;
default:
k = 0;
break;
}
widthp = k;
return(k);
}
}
i &= 0x1ff;
#endif
#endif
i = trtab[i];
if (i < 32)
return(0);
k = t.width[i] * t.Char;
widthp = k;
return(k);
}
tchar setch()
{
int j;
char temp[10];
char *s;
s = temp;
if ((*s++ = getach()) == 0 || (*s++ = getach()) == 0)
return(0);
*s = '\0';
if ((j = findch(temp)) > 0)
return j | chbits;
else
return 0;
}
tchar setabs()
{
int i, n, nf;
getch();
n = 0;
n = inumb(&n);
getch();
if (nonumb)
return 0;
return n + nchtab + _SPECCHAR_ST;
}
int
findft(i)
int i;
{
int k;
if ((k = i - '0') >= 0 && k <= nfonts && k < smnt)
return(k);
for (k = 0; fontlab[k] != i; k++)
if (k > nfonts)
return(-1);
return(k);
}
int
caseps()
{
return (0);
}
int
mchbits()
{
chbits = 0;
setfbits(chbits, font);
sps = width(' ' | chbits);
return (0);
}
int
setps()
{
int i, j;
i = cbits(getch());
if (ischar(i) && isdigit(i)) {
i -= '0';
if (i == 0)
;
else if (i <= 3 && ischar(j = cbits(ch = getch())) &&
isdigit(j)) {
ch = 0;
}
} else if (i == '(') {
getch();
getch();
} else if (i == '+' || i == '-') {
j = cbits(getch());
if (ischar(j) && isdigit(j)) {
;
} else if (j == '(') {
getch();
getch();
}
}
return (0);
}
tchar setht()
{
tchar c;
getch();
(void) inumb(&apts);
getch();
return(0);
}
tchar setslant()
{
int n;
tchar c;
getch();
n = 0;
n = inumb(&n);
getch();
return(0);
}
int
caseft()
{
skip();
setfont(1);
return (0);
}
int
setfont(a)
int a;
{
int i, j;
if (a)
i = getrq();
else
i = getsn();
if (!i || i == 'P') {
j = font1;
goto s0;
}
if (i == 'S' || i == '0')
return (0);
if ((j = findft(i, fontlab)) == -1)
return (0);
s0:
font1 = font;
font = j;
mchbits();
return (0);
}
int
setwd()
{
int base, wid;
tchar i;
int delim, emsz, k;
int savhp, savapts, savapts1, savfont, savfont1, savpts, savpts1;
base = numtab[ST].val = wid = numtab[CT].val = 0;
if (ismot(i = getch()))
return (0);
delim = cbits(i);
savhp = numtab[HP].val;
numtab[HP].val = 0;
savapts = apts;
savapts1 = apts1;
savfont = font;
savfont1 = font1;
savpts = pts;
savpts1 = pts1;
setwdf++;
while (cbits(i = getch()) != delim && !nlflg) {
k = width(i);
wid += k;
numtab[HP].val += k;
if (!ismot(i)) {
emsz = (INCH * pts + 36) / 72;
} else if (isvmot(i)) {
k = absmot(i);
if (isnmot(i))
k = -k;
base -= k;
emsz = 0;
} else
continue;
if (base < numtab[SB].val)
numtab[SB].val = base;
if ((k = base + emsz) > numtab[ST].val)
numtab[ST].val = k;
}
setn1(wid, 0, (tchar) 0);
numtab[HP].val = savhp;
apts = savapts;
apts1 = savapts1;
font = savfont;
font1 = savfont1;
pts = savpts;
pts1 = savpts1;
mchbits();
setwdf = 0;
return (0);
}
tchar vmot()
{
dfact = lss;
vflag++;
return(mot());
}
tchar hmot()
{
dfact = EM;
return(mot());
}
tchar mot()
{
int j, n;
tchar i;
j = HOR;
getch();
if (n = atoi()) {
if (vflag)
j = VERT;
i = makem(quant(n, j));
} else
i = 0;
getch();
vflag = 0;
dfact = 1;
return(i);
}
tchar sethl(k)
int k;
{
int j;
tchar i;
j = t.Halfline;
if (k == 'u')
j = -j;
else if (k == 'r')
j = -2 * j;
vflag++;
i = makem(j);
vflag = 0;
return(i);
}
tchar makem(i)
int i;
{
tchar j;
if ((j = i) < 0)
j = -j;
j |= MOT;
if (i < 0)
j |= NMOT;
if (vflag)
j |= VMOT;
return(j);
}
tchar getlg(i)
tchar i;
{
return(i);
}
int
caselg()
{
return (0);
}
int
casefp()
{
int i, j;
skip();
if ((i = cbits(getch()) - '0') < 0 || i > nfonts)
return (0);
if (skip() || !(j = getrq()))
return (0);
fontlab[i] = j;
return (0);
}
int
casecs()
{
return (0);
}
int
casebd()
{
int i, j, k;
k = 0;
bd0:
if (skip() || !(i = getrq()) || (j = findft(i)) == -1) {
if (k)
goto bd1;
else
return (0);
}
if (j == smnt) {
k = smnt;
goto bd0;
}
if (k) {
sbold = j;
j = k;
}
bd1:
skip();
noscale++;
bdtab[j] = atoi();
noscale = 0;
return (0);
}
int
casevs()
{
int i;
skip();
vflag++;
dfact = INCH;
dfactd = 72;
res = VERT;
i = inumb(&lss);
if (nonumb)
i = lss1;
if (i < VERT)
i = VERT;
lss1 = lss;
lss = i;
return (0);
}
int
casess()
{
return (0);
}
tchar xlss()
{
int i;
getch();
dfact = lss;
i = quant(atoi(), VERT);
dfact = 1;
getch();
if (i >= 0)
*pbp++ = MOT | VMOT | i;
else
*pbp++ = MOT | VMOT | NMOT | -i;
return(HX);
}