Annotation of 3BSD/cmd/neqn/pile.c, revision 1.1.1.1

1.1       root        1: # include "e.h"
                      2: 
                      3: lpile(type, p1, p2) int type, p1, p2; {
                      4:        int bi, hi, i, gap, h, b, nlist, nlist2, mid;
                      5:        yyval = oalloc();
                      6:        gap = VERT(1);
                      7:        if( type=='-' ) gap = 0;
                      8:        nlist = p2 - p1;
                      9:        nlist2 = (nlist+1)/2;
                     10:        mid = p1 + nlist2 -1;
                     11:        h = 0;
                     12:        for( i=p1; i<p2; i++ )
                     13:                h += eht[lp[i]];
                     14:        eht[yyval] = h + (nlist-1)*gap;
                     15:        b = 0;
                     16:        for( i=p2-1; i>mid; i-- )
                     17:                b += eht[lp[i]] + gap;
                     18:        ebase[yyval] = (nlist%2) ? b + ebase[lp[mid]]
                     19:                        : b - VERT(1) - gap;
                     20:        if(dbg) {
                     21:                printf(".\tS%d <- %c pile of:", yyval, type);
                     22:                for( i=p1; i<p2; i++)
                     23:                        printf(" S%d", lp[i]);
                     24:                printf(";h=%d b=%d\n", eht[yyval], ebase[yyval]);
                     25:        }
                     26:        nrwid(lp[p1], ps, lp[p1]);
                     27:        printf(".nr %d \\n(%d\n", yyval, lp[p1]);
                     28:        for( i = p1+1; i<p2; i++ ) {
                     29:                nrwid(lp[i], ps, lp[i]);
                     30:                printf(".if \\n(%d>\\n(%d .nr %d \\n(%d\n", 
                     31:                        lp[i], yyval, yyval, lp[i]);
                     32:        }
                     33:        printf(".ds %d \\v'%du'\\h'%du*\\n(%du'\\\n", yyval, ebase[yyval], 
                     34:                type=='R' ? 1 : 0, yyval);
                     35:        for(i = p2-1; i >=p1; i--) {
                     36:                hi = eht[lp[i]]; 
                     37:                bi = ebase[lp[i]];
                     38:        switch(type) {
                     39: 
                     40:        case 'L':
                     41:                printf("\\v'%du'\\*(%d\\h'-\\n(%du'\\v'0-%du'\\\n", 
                     42:                        -bi, lp[i], lp[i], hi-bi+gap);
                     43:                continue;
                     44:        case 'R':
                     45:                printf("\\v'%du'\\h'-\\n(%du'\\*(%d\\v'0-%du'\\\n", 
                     46:                        -bi, lp[i], lp[i], hi-bi+gap);
                     47:                continue;
                     48:        case 'C':
                     49:        case '-':
                     50:                printf("\\v'%du'\\h'\\n(%du-\\n(%du/2u'\\*(%d", 
                     51:                        -bi, yyval, lp[i], lp[i]);
                     52:                printf("\\h'-\\n(%du-\\n(%du/2u'\\v'0-%du'\\\n", 
                     53:                        yyval, lp[i], hi-bi+gap);
                     54:                continue;
                     55:                }
                     56:        }
                     57:        printf("\\v'%du'\\h'%du*\\n(%du'\n", eht[yyval]-ebase[yyval]+gap, 
                     58:                type!='R' ? 1 : 0, yyval);
                     59:        for( i=p1; i<p2; i++ )
                     60:                ofree(lp[i]);
                     61:        lfont[yyval] = rfont[yyval] = 0;
                     62: }

unix.superglobalmegacorp.com

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