Home | History | Annotate | Line # | Download | only in libcurses
mvwin.c revision 1.24.4.1
      1  1.24.4.1  perseant /*	$NetBSD: mvwin.c,v 1.24.4.1 2025/08/02 05:54:47 perseant Exp $	*/
      2       1.7     mikel 
      3       1.1       cgd /*
      4       1.6       cgd  * Copyright (c) 1981, 1993, 1994
      5       1.4       cgd  *	The Regents of the University of California.  All rights reserved.
      6       1.1       cgd  *
      7       1.1       cgd  * Redistribution and use in source and binary forms, with or without
      8       1.1       cgd  * modification, are permitted provided that the following conditions
      9       1.1       cgd  * are met:
     10       1.1       cgd  * 1. Redistributions of source code must retain the above copyright
     11       1.1       cgd  *    notice, this list of conditions and the following disclaimer.
     12       1.1       cgd  * 2. Redistributions in binary form must reproduce the above copyright
     13       1.1       cgd  *    notice, this list of conditions and the following disclaimer in the
     14       1.1       cgd  *    documentation and/or other materials provided with the distribution.
     15      1.15       agc  * 3. Neither the name of the University nor the names of its contributors
     16       1.1       cgd  *    may be used to endorse or promote products derived from this software
     17       1.1       cgd  *    without specific prior written permission.
     18       1.1       cgd  *
     19       1.1       cgd  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     20       1.1       cgd  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     21       1.1       cgd  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     22       1.1       cgd  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     23       1.1       cgd  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     24       1.1       cgd  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     25       1.1       cgd  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     26       1.1       cgd  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     27       1.1       cgd  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     28       1.1       cgd  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     29       1.1       cgd  * SUCH DAMAGE.
     30       1.1       cgd  */
     31       1.1       cgd 
     32       1.7     mikel #include <sys/cdefs.h>
     33       1.1       cgd #ifndef lint
     34       1.7     mikel #if 0
     35       1.6       cgd static char sccsid[] = "@(#)mvwin.c	8.2 (Berkeley) 5/4/94";
     36       1.7     mikel #else
     37  1.24.4.1  perseant __RCSID("$NetBSD: mvwin.c,v 1.24.4.1 2025/08/02 05:54:47 perseant Exp $");
     38       1.7     mikel #endif
     39       1.9       mrg #endif				/* not lint */
     40       1.1       cgd 
     41       1.6       cgd #include "curses.h"
     42      1.10     blymn #include "curses_private.h"
     43       1.1       cgd 
     44      1.12     blymn /*
     45      1.12     blymn  * mvderwin --
     46      1.16     blymn  *      Move a derived window.  This does not change the physical screen
     47      1.16     blymn  * coordinates of the subwin, rather maps the characters in the subwin
     48      1.16     blymn  * sized part of the parent window starting at dy, dx into the subwin.
     49      1.12     blymn  *
     50      1.12     blymn  */
     51      1.12     blymn int
     52      1.12     blymn mvderwin(WINDOW *win, int dy, int dx)
     53      1.12     blymn {
     54      1.12     blymn 	WINDOW *parent;
     55      1.18  christos 	int x, i;
     56      1.19     blymn 	__LINE *plp;
     57      1.13     blymn 
     58  1.24.4.1  perseant 	if (__predict_false(win == NULL))
     59      1.12     blymn 		return ERR;
     60      1.12     blymn 
     61      1.12     blymn 	parent = win->orig;
     62      1.12     blymn 
     63      1.12     blymn 	if (parent == NULL)
     64      1.12     blymn 		return ERR;
     65      1.12     blymn 
     66      1.16     blymn 	if (((win->maxx + dx) > parent->maxx) ||
     67      1.16     blymn 	    ((win->maxy + dy) > parent->maxy))
     68      1.16     blymn 		return ERR;
     69      1.16     blymn 
     70      1.19     blymn 	win->flags |= __ISDERWIN;
     71      1.19     blymn 	win->derx = dx;
     72      1.19     blymn 	win->dery = dy;
     73      1.19     blymn 
     74      1.17     blymn 	x = parent->begx + dx;
     75      1.16     blymn 
     76      1.19     blymn 	/*
     77      1.19     blymn 	 * Mark the source area for the derwin as changed so it will be
     78      1.19     blymn 	 * copied to the destination window on refresh.
     79      1.19     blymn 	 */
     80      1.19     blymn 	for (i = 0; i < win->maxy; i++) {
     81      1.19     blymn 		plp = parent->alines[i + dy];
     82      1.19     blymn 		plp->flags = __ISDIRTY;
     83      1.19     blymn 		if (*plp->firstchp > x)
     84      1.19     blymn 			*plp->firstchp = x;
     85      1.19     blymn 		if (*plp->lastchp < x + win->maxx)
     86      1.19     blymn 			*plp->lastchp = x + win->maxx;
     87      1.23       rin 		__CTRACE(__CTRACE_REFRESH,
     88      1.23       rin 		    "mvderwin: firstchp = %d, lastchp = %d\n",
     89      1.23       rin 		    *plp->firstchp, *plp->lastchp);
     90      1.17     blymn 	}
     91      1.16     blymn 
     92      1.16     blymn 	return OK;
     93      1.12     blymn }
     94      1.13     blymn 
     95       1.1       cgd /*
     96       1.3   mycroft  * mvwin --
     97       1.3   mycroft  *	Relocate the starting position of a window.
     98       1.1       cgd  */
     99       1.3   mycroft int
    100      1.11     blymn mvwin(WINDOW *win, int by, int bx)
    101       1.3   mycroft {
    102       1.8     perry 	WINDOW *orig;
    103       1.9       mrg 	int     dy, dx;
    104       1.1       cgd 
    105  1.24.4.1  perseant 	if (__predict_false(win == NULL))
    106  1.24.4.1  perseant 		return ERR;
    107  1.24.4.1  perseant 
    108      1.21       roy 	if (by < 0 || by + win->maxy > win->screen->LINES ||
    109      1.21       roy 	    bx < 0 || bx + win->maxx > win->screen->COLS)
    110      1.20       roy 		return ERR;
    111       1.4       cgd 	dy = by - win->begy;
    112       1.4       cgd 	dx = bx - win->begx;
    113       1.4       cgd 	orig = win->orig;
    114       1.1       cgd 	if (orig == NULL) {
    115       1.1       cgd 		orig = win;
    116       1.1       cgd 		do {
    117       1.4       cgd 			win->begy += dy;
    118       1.4       cgd 			win->begx += dx;
    119       1.3   mycroft 			__swflags(win);
    120       1.4       cgd 			win = win->nextp;
    121       1.1       cgd 		} while (win != orig);
    122       1.3   mycroft 	} else {
    123       1.4       cgd 		if (by < orig->begy || win->maxy + dy > orig->maxy)
    124      1.21       roy 			return ERR;
    125       1.4       cgd 		if (bx < orig->begx || win->maxx + dx > orig->maxx)
    126      1.21       roy 			return ERR;
    127       1.4       cgd 		win->begy = by;
    128       1.4       cgd 		win->begx = bx;
    129       1.3   mycroft 		__swflags(win);
    130       1.3   mycroft 		__set_subwin(orig, win);
    131       1.1       cgd 	}
    132      1.24     blymn 	__touchwin(win, 0);
    133      1.20       roy 	return OK;
    134       1.1       cgd }
    135