118169Sjaap #ifndef lint
2*30727Sjaap static char sccsid[] = "@(#)shift.c 2.2 (CWI) 87/04/01";
323926Sjaap #endif lint
423926Sjaap #include "e.h"
5*30727Sjaap #include "y.tab.h"
618169Sjaap
subsup(p1,p2,p3)723926Sjaap subsup(p1, p2, p3)
823926Sjaap int p1, p2, p3;
923926Sjaap {
1023926Sjaap if (p2 != 0 && p3 != 0)
1123926Sjaap shift2(p1, p2, p3);
1223926Sjaap else if (p2 != 0)
1323926Sjaap bshiftb(p1, SUB, p2);
1423926Sjaap else if (p3 != 0)
1523926Sjaap bshiftb(p1, SUP, p3);
1623926Sjaap }
1723926Sjaap
18*30727Sjaap extern float Subbase, Supshift;
19*30727Sjaap extern char *Sub1space, *Sup1space, *Sub2space;
20*30727Sjaap extern char *SS1space, *SS2space;
21*30727Sjaap
bshiftb(p1,dir,p2)2223926Sjaap bshiftb(p1, dir, p2)
2323926Sjaap int p1, dir, p2;
2423926Sjaap {
2523926Sjaap int subps;
2623926Sjaap float shval, d1, h1, b1, h2, b2;
2718169Sjaap char *sh1, *sh2;
2818169Sjaap
2918169Sjaap yyval = p1;
3018169Sjaap h1 = eht[p1];
3118169Sjaap b1 = ebase[p1];
3218169Sjaap h2 = eht[p2];
3318169Sjaap b2 = ebase[p2];
3423926Sjaap subps = ps;
3523926Sjaap ps += deltaps;
3618169Sjaap sh1 = sh2 = "";
3723926Sjaap if (dir == SUB) {
3823926Sjaap /* base .2m below bottom of main box */
39*30727Sjaap shval = b1 + EM(Subbase, ps);
4023926Sjaap ebase[yyval] = shval + b2;
4123926Sjaap eht[yyval] = max(h1-b1+shval+b2, h2);
4218169Sjaap if (rfont[p1] == ITAL && lfont[p2] == ROM)
43*30727Sjaap sh1 = Sub1space;
4418169Sjaap } else { /* superscript */
4518169Sjaap /* 4/10 up main box */
46*30727Sjaap d1 = EM(Subbase, subps);
4718169Sjaap ebase[yyval] = b1;
48*30727Sjaap shval = -(Supshift * (h1-b1)) - b2;
49*30727Sjaap if (Supshift*(h1-b1) + h2 < h1-b1) /* raise little super */
5018169Sjaap shval = -(h1-b1) + h2-b2 - d1;
51*30727Sjaap eht[yyval] = h1 + max(0, h2 - (1-Supshift)*(h1-b1));
5218169Sjaap if (rfont[p1] == ITAL)
53*30727Sjaap sh1 = Sup1space;
5418169Sjaap }
5523926Sjaap dprintf(".\tS%d <- %d shift %g %d; b=%g, h=%g, ps=%d, subps=%d\n",
5623926Sjaap yyval, p1, shval, p2, ebase[yyval], eht[yyval], ps, subps);
57*30727Sjaap sh2 = Sub2space;
5823926Sjaap printf(".as %d \\v'%gm'%s%s\\*(%d%s%s\\v'%gm'\n",
5923926Sjaap yyval, REL(shval,ps), DPS(ps,subps), sh1, p2,
6023926Sjaap DPS(subps,ps), sh2, REL(-shval,ps));
6123926Sjaap rfont[p1] = 0;
6223926Sjaap sfree(p2);
6318169Sjaap }
6418169Sjaap
shift2(p1,p2,p3)6523926Sjaap shift2(p1, p2, p3)
6623926Sjaap int p1, p2, p3;
6723926Sjaap {
6823926Sjaap int subps;
6923926Sjaap float h1, h2, h3, b1, b2, b3, subsh, d1, d2, supsh;
7023926Sjaap int treg;
7118169Sjaap
7223926Sjaap treg = salloc();
7318169Sjaap yyval = p1;
7423926Sjaap subps = ps; /* sub and sup at this size */
7523926Sjaap ps += deltaps; /* outer size */
7618169Sjaap h1 = eht[p1]; b1 = ebase[p1];
7718169Sjaap h2 = eht[p2]; b2 = ebase[p2];
7823926Sjaap h3 = eht[p3]; b3 = ebase[p3];
79*30727Sjaap subsh = EM(Subbase, ps);
8023926Sjaap if (b1 > b2 + subsh) /* move little sub down */
8123926Sjaap subsh += b1;
8223926Sjaap eht[yyval] = max(subsh+b2-b1+h1, h2);
83*30727Sjaap supsh = -Supshift*(h1-b1) - b3;
84*30727Sjaap d2 = EM(Subbase, subps);
85*30727Sjaap if (h3 < (1-Supshift)*(h1-b1))
8618169Sjaap supsh = -(h1-b1) + (h3-b3) - d2;
8723926Sjaap ebase[yyval] = subsh + b2 - b1;
88*30727Sjaap eht[yyval] = h1 + subsh+b2-b1 + max(0, h3-(1-Supshift)*(h1-b1));
8923926Sjaap dprintf(".\tS%d <- %d sub %d sup %d, ps=%d, subps=%d, h=%g, b=%g\n",
9023926Sjaap yyval, p1, p2, p3, ps, subps, eht[yyval], ebase[yyval]);
91*30727Sjaap printf(".ds %d %s\\*(%d\n", p2, SS1space, p2);
9223926Sjaap nrwid(p2, subps, p2);
93*30727Sjaap printf(".ds %d %s\\*(%d\n", p3, SS2space, p3);
9423926Sjaap nrwid(p3, subps, p3);
9518169Sjaap printf(".nr %d \\n(%d\n", treg, p3);
9618169Sjaap printf(".if \\n(%d>\\n(%d .nr %d \\n(%d\n", p2, treg, treg, p2);
97*30727Sjaap printf(".as %d %s\\v'%gm'\\*(%d\\v'%gm'\\h'-\\n(%du'\\\n",
98*30727Sjaap p1, DPS(ps,subps), REL(subsh,subps), p2, REL(-subsh,subps), p2);
99*30727Sjaap printf("\\v'%gm'\\*(%d\\v'%gm'\\h'-\\n(%du+\\n(%du'%s%s\n",
100*30727Sjaap REL(supsh,subps), p3, REL(-supsh,subps), p3, treg, DPS(subps,ps), Sub2space);
10118169Sjaap if (rfont[p2] == ITAL)
10218169Sjaap rfont[yyval] = 0; /* lie */
10323926Sjaap sfree(p2); sfree(p3); sfree(treg);
10418169Sjaap }
105