1*7c478bd9Sstevel@tonic-gate /*
2*7c478bd9Sstevel@tonic-gate * Copyright 2001 Sun Microsystems, Inc. All rights reserved.
3*7c478bd9Sstevel@tonic-gate * Use is subject to license terms.
4*7c478bd9Sstevel@tonic-gate */
5*7c478bd9Sstevel@tonic-gate
6*7c478bd9Sstevel@tonic-gate /* Copyright (c) 1983, 1984, 1985, 1986, 1987, 1988, 1989 AT&T */
7*7c478bd9Sstevel@tonic-gate /* All Rights Reserved */
8*7c478bd9Sstevel@tonic-gate
9*7c478bd9Sstevel@tonic-gate /*
10*7c478bd9Sstevel@tonic-gate * Copyright (c) 1980 Regents of the University of California.
11*7c478bd9Sstevel@tonic-gate * All rights reserved. The Berkeley software License Agreement
12*7c478bd9Sstevel@tonic-gate * specifies the terms and conditions for redistribution.
13*7c478bd9Sstevel@tonic-gate */
14*7c478bd9Sstevel@tonic-gate
15*7c478bd9Sstevel@tonic-gate #pragma ident "%Z%%M% %I% %E% SMI"
16*7c478bd9Sstevel@tonic-gate
17*7c478bd9Sstevel@tonic-gate /*LINTLIBRARY*/
18*7c478bd9Sstevel@tonic-gate
19*7c478bd9Sstevel@tonic-gate #ifndef lint
20*7c478bd9Sstevel@tonic-gate static char
21*7c478bd9Sstevel@tonic-gate sccsid[] = "@(#)delwin.c 1.6 88/02/08 SMI"; /* from UCB 5.1 85/06/07 */
22*7c478bd9Sstevel@tonic-gate #endif /* not lint */
23*7c478bd9Sstevel@tonic-gate
24*7c478bd9Sstevel@tonic-gate #include "curses.ext"
25*7c478bd9Sstevel@tonic-gate #include <malloc.h>
26*7c478bd9Sstevel@tonic-gate
27*7c478bd9Sstevel@tonic-gate /*
28*7c478bd9Sstevel@tonic-gate * This routine deletes a window and releases it back to the system.
29*7c478bd9Sstevel@tonic-gate */
30*7c478bd9Sstevel@tonic-gate
31*7c478bd9Sstevel@tonic-gate int
delwin(WINDOW * win)32*7c478bd9Sstevel@tonic-gate delwin(WINDOW *win)
33*7c478bd9Sstevel@tonic-gate {
34*7c478bd9Sstevel@tonic-gate int i;
35*7c478bd9Sstevel@tonic-gate WINDOW *wp, *np;
36*7c478bd9Sstevel@tonic-gate
37*7c478bd9Sstevel@tonic-gate if (win->_orig == NULL) {
38*7c478bd9Sstevel@tonic-gate /*
39*7c478bd9Sstevel@tonic-gate * If we are the original window, delete the space for
40*7c478bd9Sstevel@tonic-gate * all the subwindows, and the array of space as well.
41*7c478bd9Sstevel@tonic-gate */
42*7c478bd9Sstevel@tonic-gate for (i = 0; i < win->_maxy && win->_y[i]; i++)
43*7c478bd9Sstevel@tonic-gate free(win->_y[i]);
44*7c478bd9Sstevel@tonic-gate free(win->_firstch);
45*7c478bd9Sstevel@tonic-gate free(win->_lastch);
46*7c478bd9Sstevel@tonic-gate wp = win->_nextp;
47*7c478bd9Sstevel@tonic-gate while (wp != win) {
48*7c478bd9Sstevel@tonic-gate np = wp->_nextp;
49*7c478bd9Sstevel@tonic-gate (void) delwin(wp);
50*7c478bd9Sstevel@tonic-gate wp = np;
51*7c478bd9Sstevel@tonic-gate }
52*7c478bd9Sstevel@tonic-gate } else {
53*7c478bd9Sstevel@tonic-gate /*
54*7c478bd9Sstevel@tonic-gate * If we are a subwindow, take ourselves out of the
55*7c478bd9Sstevel@tonic-gate * list. NOTE: if we are a subwindow, the minimum list
56*7c478bd9Sstevel@tonic-gate * is orig followed by this subwindow, so there are
57*7c478bd9Sstevel@tonic-gate * always at least two windows in the list.
58*7c478bd9Sstevel@tonic-gate */
59*7c478bd9Sstevel@tonic-gate for (wp = win->_nextp; wp->_nextp != win; wp = wp->_nextp)
60*7c478bd9Sstevel@tonic-gate continue;
61*7c478bd9Sstevel@tonic-gate wp->_nextp = win->_nextp;
62*7c478bd9Sstevel@tonic-gate }
63*7c478bd9Sstevel@tonic-gate free(win->_y);
64*7c478bd9Sstevel@tonic-gate free(win);
65*7c478bd9Sstevel@tonic-gate
66*7c478bd9Sstevel@tonic-gate return (OK);
67*7c478bd9Sstevel@tonic-gate }
68