Annotation of 43BSDReno/usr.bin/eqn/common_source/diacrit.c, revision 1.1.1.1

1.1       root        1: #ifndef lint
                      2: static char sccsid[] = "@(#)diacrit.c  4.3 8/11/83";
                      3: #endif
                      4: 
                      5: # include "e.h"
                      6: # include "e.def"
                      7: 
                      8: diacrit(p1, type) int p1, type; {
                      9:        int c, t;
                     10: #ifndef NEQN
                     11:        int effps;
                     12: #endif NEQN
                     13: 
                     14:        c = oalloc();
                     15:        t = oalloc();
                     16: #ifdef NEQN
                     17:        nrwid(p1, ps, p1);
                     18:        printf(".nr 10 %du\n", max(eht[p1]-ebase[p1]-VERT(2),0));
                     19: #else NEQN
                     20:        effps = EFFPS(ps);
                     21:        nrwid(p1, effps, p1);
                     22:        printf(".nr 10 %du\n", VERT(max(eht[p1]-ebase[p1]-6*ps,0)));    /* vertical shift if high */
                     23:        printf(".if \\n(ct>1 .nr 10 \\n(10+\\s%d.25m\\s0\n", effps);
                     24:        printf(".nr %d \\s%d.1m\\s0\n", t, effps);      /* horiz shift if high */
                     25:        printf(".if \\n(ct>1 .nr %d \\s%d.15m\\s0\n", t, effps);
                     26: #endif NEQN
                     27:        switch(type) {
                     28:                case VEC:       /* vec */
                     29: #ifndef NEQN
                     30:                        printf(".ds %d \\v'-.4m'\\s%d\\(->\\s0\\v'.4m'\n",
                     31:                            c, max(effps-3, 6));
                     32:                        break;
                     33: #endif NEQN
                     34:                case DYAD:      /* dyad */
                     35: #ifdef NEQN
                     36:                        printf(".ds %d \\v'-1'_\\v'1'\n", c);
                     37: #else NEQN
                     38:                        printf(".ds %d \\v'-.4m'\\s%d\\z\\(<-\\(->\\s0\\v'.4m'\n",
                     39:                            c, max(effps-3, 6));
                     40: #endif NEQN
                     41:                        break;
                     42:                case HAT:
                     43:                        printf(".ds %d ^\n", c);
                     44:                        break;
                     45:                case TILDE:
                     46:                        printf(".ds %d ~\n", c);
                     47:                        break;
                     48:                case DOT:
                     49: #ifndef NEQN
                     50:                        printf(".ds %d \\s%d\\v'-.67m'.\\v'.67m'\\s0\n", c, effps);
                     51: #else NEQN
                     52:                        printf(".ds %d \\v'-1'.\\v'1'\n", c);
                     53: #endif NEQN
                     54:                        break;
                     55:                case DOTDOT:
                     56: #ifndef NEQN
                     57:                        printf(".ds %d \\s%d\\v'-.67m'..\\v'.67m\\s0'\n", c, effps);
                     58: #else NEQN
                     59:                        printf(".ds %d \\v'-1'..\\v'1'\n", c);
                     60: #endif NEQN
                     61:                        break;
                     62:                case BAR:
                     63: #ifndef NEQN
                     64:                        printf(".ds %d \\s%d\\v'.18m'\\h'.05m'\\l'\\n(%du-.1m\\(rn'\\h'.05m'\\v'-.18m'\\s0\n",
                     65:                                c, effps, p1);
                     66: #else NEQN
                     67:                        printf(".ds %d \\v'-1'\\l'\\n(%du'\\v'1'\n", 
                     68:                                c, p1);
                     69: #endif NEQN
                     70:                        break;
                     71:                case UNDER:
                     72: #ifndef NEQN
                     73:                        printf(".ds %d \\l'\\n(%du\\(ul'\n", c, p1);
                     74:                        printf(".nr %d 0\n", t);
                     75:                        printf(".nr 10 0-%d\n", ebase[p1]);
                     76: #else NEQN
                     77:                        printf(".ds %d \\l'\\n(%du'\n", c, p1);
                     78: #endif NEQN
                     79:                        break;
                     80:                }
                     81:        nrwid(c, ps, c);
                     82: #ifndef NEQN
                     83:        if (lfont[p1] != ITAL)
                     84:                printf(".nr %d 0\n", t);
                     85:        printf(".as %d \\h'-\\n(%du-\\n(%du/2u+\\n(%du'\\v'0-\\n(10u'\\*(%d", 
                     86:                p1, p1, c, t, c);
                     87:        printf("\\v'\\n(10u'\\h'-\\n(%du+\\n(%du/2u-\\n(%du'\n", c, p1, t);
                     88:        /* BUG - should go to right end of widest */
                     89: #else NEQN
                     90:        printf(".as %d \\h'-\\n(%du-\\n(%du/2u'\\v'0-\\n(10u'\\*(%d", 
                     91:                p1, p1, c, c);
                     92:        printf("\\v'\\n(10u'\\h'-\\n(%du+\\n(%du/2u'\n", c, p1);
                     93: #endif NEQN
                     94: #ifndef NEQN
                     95:        if (type != UNDER)
                     96:                eht[p1] += VERT( (6*ps*15) / 100);      /* 0.15m */
                     97:        if(dbg)printf(".\tdiacrit: %c over S%d, lf=%c, rf=%c, h=%d,b=%d\n",
                     98:                type, p1, lfont[p1], rfont[p1], eht[p1], ebase[p1]);
                     99: #else NEQN
                    100:        if (type != UNDER)
                    101:                eht[p1] += VERT(1);
                    102:        if (dbg) printf(".\tdiacrit: %c over S%d, h=%d, b=%d\n", type, p1, eht[p1], ebase[p1]);
                    103: #endif NEQN
                    104:        ofree(c); ofree(t);
                    105: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.