Annotation of 43BSDReno/lib/libcurses/overlay.c, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 1981 Regents of the University of California.
        !             3:  * All rights reserved.
        !             4:  *
        !             5:  * Redistribution and use in source and binary forms are permitted
        !             6:  * provided that: (1) source distributions retain this entire copyright
        !             7:  * notice and comment, and (2) distributions including binaries display
        !             8:  * the following acknowledgement:  ``This product includes software
        !             9:  * developed by the University of California, Berkeley and its contributors''
        !            10:  * in the documentation or other materials provided with the distribution
        !            11:  * and in all advertising materials mentioning features or use of this
        !            12:  * software. Neither the name of the University nor the names of its
        !            13:  * contributors may be used to endorse or promote products derived
        !            14:  * from this software without specific prior written permission.
        !            15:  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
        !            16:  * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
        !            17:  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
        !            18:  */
        !            19: 
        !            20: #ifndef lint
        !            21: static char sccsid[] = "@(#)overlay.c  5.6 (Berkeley) 6/1/90";
        !            22: #endif /* not lint */
        !            23: 
        !            24: # include      "curses.ext"
        !            25: # include      <ctype.h>
        !            26: 
        !            27: # define       min(a,b)        (a < b ? a : b)
        !            28: # define       max(a,b)        (a > b ? a : b)
        !            29: 
        !            30: /*
        !            31:  *     This routine writes win1 on win2 non-destructively.
        !            32:  *
        !            33:  */
        !            34: overlay(win1, win2)
        !            35: reg WINDOW     *win1, *win2; {
        !            36: 
        !            37:        reg char        *sp, *end;
        !            38:        reg int         x, y, endy, endx, starty, startx;
        !            39:        reg int         y1,y2;
        !            40: 
        !            41: # ifdef DEBUG
        !            42:        fprintf(outf, "OVERLAY(%0.2o, %0.2o);\n", win1, win2);
        !            43: # endif
        !            44:        starty = max(win1->_begy, win2->_begy);
        !            45:        startx = max(win1->_begx, win2->_begx);
        !            46:        endy = min(win1->_maxy + win1->_begy, win2->_maxy + win2->_begx);
        !            47:        endx = min(win1->_maxx + win1->_begx, win2->_maxx + win2->_begx);
        !            48: # ifdef DEBUG
        !            49:        fprintf(outf, "OVERLAY:from (%d,%d) to (%d,%d)\n", starty, startx, endy, endx);
        !            50: # endif
        !            51:        if (starty >= endy || startx >= endx)
        !            52:                return;
        !            53:        y1 = starty - win1->_begy;
        !            54:        y2 = starty - win2->_begy;
        !            55:        for (y = starty; y < endy; y++, y1++, y2++) {
        !            56:                end = &win1->_y[y1][endx - win1->_begx];
        !            57:                x = startx - win2->_begx;
        !            58:                for (sp = &win1->_y[y1][startx - win1->_begx]; sp < end; sp++) {
        !            59:                        if (!isspace(*sp))
        !            60:                                mvwaddch(win2, y2, x, *sp);
        !            61:                        x++;
        !            62:                }
        !            63:        }
        !            64: }

unix.superglobalmegacorp.com

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