Annotation of researchv9/jerq/src/lib/mj/eldisc.c, revision 1.1

1.1     ! root        1: #ifndef        MUX
        !             2: #define        Jcursinhibit()  cursinhibit()
        !             3: #define        Jcursallow()    cursallow()
        !             4: #define        lrectf(l, r, f) rectf(l, r, f)
        !             5: #define        lsegment(l, p, q, f)    segment(l, p, q, f)
        !             6: #endif
        !             7: 
        !             8: #include       <jerq.h>
        !             9: #define        DB              ((Word *)0x700000)
        !            10: #define        ONSCREEN(b)     (b->base>=DB && b->base<DB+XMAX/WORDSIZE*YMAX)
        !            11: #define        ONSCREEN(b)     (b->base>=DB && b->base<DB+XMAX/WORDSIZE*YMAX)
        !            12: 
        !            13: static int yaxis;
        !            14: static int xaxis;
        !            15: static Point lp;
        !            16: 
        !            17: static void
        !            18: scan(bp, p, f)
        !            19:        Bitmap *bp;
        !            20:        Point p;
        !            21:        Code f;
        !            22: {
        !            23:        register x, y;
        !            24: 
        !            25:        if((p.y != lp.y) && (lp.y != -1))
        !            26:        {
        !            27:                x = xaxis - lp.x;
        !            28:                y = yaxis - lp.y;
        !            29:                lrectf(bp, Rect(lp.x, lp.y, x+1, lp.y+1), f);
        !            30:                lrectf(bp, Rect(lp.x, y, x+1, y+1), f);
        !            31:        }
        !            32:        lp = p;
        !            33: }
        !            34: eldisc(bp, p, a, b, f)
        !            35:        Bitmap *bp;
        !            36:        Point p;
        !            37:        int a, b;
        !            38:        Code f;
        !            39: {
        !            40:        short inhibited;
        !            41:        register x0 = p.x;
        !            42:        register y0 = p.y;
        !            43: 
        !            44:        yaxis = 2*p.y;
        !            45:        xaxis = 2*p.x;
        !            46:        lp.y = -1;
        !            47:        inhibited=0;
        !            48:        if(f!=F_XOR && ONSCREEN(bp)){
        !            49:                Jcursinhibit();
        !            50:                inhibited=1;
        !            51:        }
        !            52:        if(a==0 || b==0)
        !            53:                lsegment(bp, Pt(x0-a,y0-b), Pt(x0+a,y0+b), f);
        !            54:        else
        !            55:        {
        !            56:                lrectf(bp, Rect(p.x-a, p.y, p.x+a+1, p.y+1), f);
        !            57:                ellip1(bp, p, a, b, scan, Pt(0, -b), Pt(-a, 0), f);
        !            58:                scan(bp, Pt(0, -1), f);
        !            59:        }
        !            60:        if(inhibited)
        !            61:                Jcursallow();
        !            62: }

unix.superglobalmegacorp.com

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