Home | History | Annotate | Line # | Download | only in libcurses
copywin.c revision 1.9.6.1
      1  1.9.6.1    snj /*	$NetBSD: copywin.c,v 1.9.6.1 2005/07/24 00:50:33 snj Exp $	*/
      2      1.1  blymn 
      3      1.1  blymn /*-
      4      1.1  blymn  * Copyright (c) 1998-1999 Brett Lymn
      5      1.1  blymn  *                         (blymn (at) baea.com.au, brett_lymn (at) yahoo.com.au)
      6      1.1  blymn  * All rights reserved.
      7      1.1  blymn  *
      8      1.1  blymn  * This code has been donated to The NetBSD Foundation by the Author.
      9      1.1  blymn  *
     10      1.1  blymn  * Redistribution and use in source and binary forms, with or without
     11      1.1  blymn  * modification, are permitted provided that the following conditions
     12      1.1  blymn  * are met:
     13      1.1  blymn  * 1. Redistributions of source code must retain the above copyright
     14      1.1  blymn  *    notice, this list of conditions and the following disclaimer.
     15      1.1  blymn  * 2. The name of the author may not be used to endorse or promote products
     16      1.7    wiz  *    derived from this software without specific prior written permission
     17      1.1  blymn  *
     18      1.1  blymn  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
     19      1.1  blymn  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     20      1.1  blymn  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     21      1.1  blymn  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
     22      1.1  blymn  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
     23      1.1  blymn  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
     24      1.1  blymn  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
     25      1.1  blymn  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
     26      1.1  blymn  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
     27      1.1  blymn  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     28      1.1  blymn  *
     29      1.1  blymn  *
     30      1.1  blymn  */
     31      1.5  blymn 
     32      1.5  blymn #include <sys/cdefs.h>
     33      1.5  blymn #ifndef lint
     34  1.9.6.1    snj __RCSID("$NetBSD: copywin.c,v 1.9.6.1 2005/07/24 00:50:33 snj Exp $");
     35      1.5  blymn #endif				/* not lint */
     36      1.1  blymn 
     37      1.1  blymn #include <ctype.h>
     38      1.2    jdc #include <string.h>
     39      1.1  blymn #include "curses.h"
     40      1.1  blymn #include "curses_private.h"
     41      1.1  blymn 
     42      1.1  blymn /*
     43      1.1  blymn  * copywin --
     44      1.1  blymn  *     Copy the box starting at (sminrow, smincol) with a size that
     45      1.1  blymn  *     matches the destination box (dminrow, dmincol) by (dmaxrow, dmaxcol)
     46      1.1  blymn  *     from the source window srcwin to the destination window dstwin.
     47  1.9.6.1    snj  *     All these coordindinates are relative to the relevant window.
     48      1.8  lukem  *     If dooverlay is true then the copy is nondestructive otherwise the
     49      1.1  blymn  *     copy is destructive.
     50      1.1  blymn  */
     51  1.9.6.1    snj int copywin(const WINDOW *srcwin, WINDOW *dstwin,
     52  1.9.6.1    snj 	    int sminrow, int smincol,
     53  1.9.6.1    snj 	    int dminrow, int dmincol, int dmaxrow, int dmaxcol, int dooverlay)
     54      1.1  blymn {
     55  1.9.6.1    snj 	int dcol;
     56      1.1  blymn 	__LDATA *sp, *end;
     57      1.9  blymn 
     58  1.9.6.1    snj 	/* overwrite() and overlay() can come here with -ve srcwin coords */
     59  1.9.6.1    snj 	if (sminrow < 0) {
     60  1.9.6.1    snj 		dminrow -= sminrow;
     61  1.9.6.1    snj 		sminrow = 0;
     62  1.9.6.1    snj 	}
     63  1.9.6.1    snj 	if (smincol < 0) {
     64  1.9.6.1    snj 		dmincol -= smincol;
     65  1.9.6.1    snj 		smincol = 0;
     66  1.9.6.1    snj 	}
     67      1.9  blymn 
     68  1.9.6.1    snj 	/* for symmetry allow dstwin coords to be -ve as well */
     69  1.9.6.1    snj 	if (dminrow < 0) {
     70  1.9.6.1    snj 		sminrow -= dminrow;
     71  1.9.6.1    snj 		dminrow = 0;
     72  1.9.6.1    snj 	}
     73  1.9.6.1    snj 	if (dmincol < 0) {
     74  1.9.6.1    snj 		smincol -= dmincol;
     75  1.9.6.1    snj 		dmincol = 0;
     76      1.4  blymn 	}
     77      1.9  blymn 
     78  1.9.6.1    snj 	/* Bound dmaxcol for both windows (should be ok for dstwin) */
     79  1.9.6.1    snj 	if (dmaxcol >= dstwin->maxx)
     80  1.9.6.1    snj 		dmaxcol = dstwin->maxx - 1;
     81  1.9.6.1    snj 	if (smincol + (dmaxcol - dmincol) >= srcwin->maxx)
     82  1.9.6.1    snj 		dmaxcol = srcwin->maxx + dmincol - smincol - 1;
     83  1.9.6.1    snj 	if (dmaxcol < dmincol)
     84  1.9.6.1    snj 		/* nothing in the intersection */
     85  1.9.6.1    snj 		return OK;
     86  1.9.6.1    snj 
     87  1.9.6.1    snj 	/* Bound dmaxrow for both windows (should be ok for dstwin) */
     88  1.9.6.1    snj 	if (dmaxrow >= dstwin->maxy)
     89  1.9.6.1    snj 		dmaxrow = dstwin->maxy - 1;
     90  1.9.6.1    snj 	if (sminrow + (dmaxrow - dminrow) >= srcwin->maxy)
     91  1.9.6.1    snj 		dmaxrow = srcwin->maxy + dminrow - sminrow - 1;
     92  1.9.6.1    snj 
     93  1.9.6.1    snj #ifdef DEBUG
     94  1.9.6.1    snj 	__CTRACE("copywin %s mode: from (%d,%d) to (%d,%d-%d,%d)\n",
     95  1.9.6.1    snj 		 dooverlay ? "overlay" : "overwrite",
     96  1.9.6.1    snj 		 sminrow, smincol, dminrow, dmincol, dmaxrow, dmaxcol);
     97      1.1  blymn #endif
     98  1.9.6.1    snj 
     99  1.9.6.1    snj 	for (; dminrow <= dmaxrow; sminrow++, dminrow++) {
    100  1.9.6.1    snj 		sp = &srcwin->lines[sminrow]->line[smincol];
    101  1.9.6.1    snj 		end = sp + dmaxcol - dmincol;
    102  1.9.6.1    snj 		if (dooverlay) {
    103  1.9.6.1    snj 			for (dcol = dmincol; sp <= end; dcol++, sp++) {
    104  1.9.6.1    snj 				/* XXX: Perhaps this should check for the
    105  1.9.6.1    snj 				 * background character
    106  1.9.6.1    snj 				 */
    107  1.9.6.1    snj 				if (!isspace(sp->ch)) {
    108  1.9.6.1    snj 					wmove(dstwin, dminrow, dcol);
    109  1.9.6.1    snj 					__waddch(dstwin, sp);
    110  1.9.6.1    snj 				}
    111  1.9.6.1    snj 			}
    112  1.9.6.1    snj 		} else {
    113  1.9.6.1    snj 			wmove(dstwin, dminrow, dmincol);
    114  1.9.6.1    snj 			for (; sp <= end; sp++) {
    115      1.4  blymn 				__waddch(dstwin, sp);
    116      1.4  blymn 			}
    117      1.1  blymn 		}
    118      1.1  blymn 	}
    119  1.9.6.1    snj 	return OK;
    120      1.1  blymn }
    121      1.1  blymn 
    122