Annotation of 43BSDTahoe/usr.bin/eqn/common_source/pile.c, revision 1.1

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

unix.superglobalmegacorp.com

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