Files
Arquivotheca.Solaris-2.5/ucblib/libcurses/delwin.c
seta75D 7c4988eac0 Init
2021-10-11 19:38:01 -03:00

84 lines
2.1 KiB
C
Executable File

/* Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T */
/* All Rights Reserved */
/* THIS IS UNPUBLISHED PROPRIETARY SOURCE CODE OF AT&T */
/* The copyright notice above does not evidence any */
/* actual or intended publication of such source code. */
#ident "@(#)delwin.c 1.1 90/04/27 SMI" /* SVr4.0 1.1 */
/*******************************************************************
PROPRIETARY NOTICE (Combined)
This source code is unpublished proprietary information
constituting, or derived under license from AT&T's UNIX(r) System V.
In addition, portions of such source code were derived from Berkeley
4.3 BSD under license from the Regents of the University of
California.
Copyright Notice
Notice of copyright on this source code product does not indicate
publication.
(c) 1986,1987,1988,1989 Sun Microsystems, Inc
(c) 1983,1984,1985,1986,1987,1988,1989 AT&T.
All rights reserved.
********************************************************************/
/*
* Copyright (c) 1980 Regents of the University of California.
* All rights reserved. The Berkeley software License Agreement
* specifies the terms and conditions for redistribution.
*/
#ifndef lint
static char sccsid[] = "@(#)delwin.c 1.6 88/02/08 SMI"; /* from UCB 5.1 85/06/07 */
#endif not lint
# include "curses.ext"
/*
* This routine deletes a window and releases it back to the system.
*
*/
delwin(win)
reg WINDOW *win; {
reg int i;
reg WINDOW *wp, *np;
if (win->_orig == NULL) {
/*
* If we are the original window, delete the space for
* all the subwindows, and the array of space as well.
*/
for (i = 0; i < win->_maxy && win->_y[i]; i++)
free(win->_y[i]);
free(win->_firstch);
free(win->_lastch);
wp = win->_nextp;
while (wp != win) {
np = wp->_nextp;
delwin(wp);
wp = np;
}
}
else {
/*
* If we are a subwindow, take ourselves out of the
* list. NOTE: if we are a subwindow, the minimum list
* is orig followed by this subwindow, so there are
* always at least two windows in the list.
*/
for (wp = win->_nextp; wp->_nextp != win; wp = wp->_nextp)
continue;
wp->_nextp = win->_nextp;
}
free(win->_y);
free(win);
}