Annotation of 42BSD/usr.lib/libcurses/overlay.c, revision 1.1.1.1

1.1       root        1: # include      "curses.ext"
                      2: # include      <ctype.h>
                      3: 
                      4: # define       min(a,b)        (a < b ? a : b)
                      5: # define       max(a,b)        (a > b ? a : b)
                      6: 
                      7: /*
                      8:  *     This routine writes win1 on win2 non-destructively.
                      9:  *
                     10:  * 11/5/82 (Berkeley) @(#)overlay.c    1.4
                     11:  */
                     12: overlay(win1, win2)
                     13: reg WINDOW     *win1, *win2; {
                     14: 
                     15:        reg char        *sp, *end;
                     16:        reg int         x, y, endy, endx, starty, startx;
                     17: 
                     18: # ifdef DEBUG
                     19:        fprintf(outf, "OVERLAY(%0.2o, %0.2o);\n", win1, win2);
                     20: # endif
                     21:        starty = max(win1->_begy, win2->_begy) - win1->_begy;
                     22:        startx = max(win1->_begx, win2->_begx) - win1->_begx;
                     23:        endy = min(win1->_maxy, win2->_maxy) - win1->_begy - 1;
                     24:        endx = min(win1->_maxx, win2->_maxx) - win1->_begx - 1;
                     25:        for (y = starty; y < endy; y++) {
                     26:                end = &win1->_y[y][endx];
                     27:                x = startx + win1->_begx;
                     28:                for (sp = &win1->_y[y][startx]; sp <= end; sp++) {
                     29:                        if (!isspace(*sp))
                     30:                                mvwaddch(win2, y + win1->_begy, x, *sp);
                     31:                        x++;
                     32:                }
                     33:        }
                     34: }

unix.superglobalmegacorp.com

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