X-Git-Url: https://ncurses.scripts.mit.edu/?p=ncurses.git;a=blobdiff_plain;f=ncurses%2Fbase%2Flib_delwin.c;h=4bb536ca86adc82319f39549d4c6833937832498;hp=e16f7878b6ce93649cbe2bf6f6d087bef00e3218;hb=119b5a6788c26bf7dcc99fcfd54e072946352a93;hpb=9378ce0407e95f6b1e2c20ec5035f0916d278944 diff --git a/ncurses/base/lib_delwin.c b/ncurses/base/lib_delwin.c index e16f7878..4bb536ca 100644 --- a/ncurses/base/lib_delwin.c +++ b/ncurses/base/lib_delwin.c @@ -1,5 +1,5 @@ /**************************************************************************** - * Copyright (c) 1998-2001,2007 Free Software Foundation, Inc. * + * Copyright (c) 1998-2008,2009 Free Software Foundation, Inc. * * * * Permission is hereby granted, free of charge, to any person obtaining a * * copy of this software and associated documentation files (the * @@ -29,6 +29,8 @@ /**************************************************************************** * Author: Zeyd M. Ben-Halim 1992,1995 * * and: Eric S. Raymond * + * and: Thomas E. Dickey 1996-on * + * and: Juergen Pfeifer 2008 * ****************************************************************************/ /* @@ -40,15 +42,18 @@ #include -MODULE_ID("$Id: lib_delwin.c,v 1.14 2007/11/03 20:24:15 tom Exp $") +MODULE_ID("$Id: lib_delwin.c,v 1.20 2009/10/24 22:02:14 tom Exp $") static bool cannot_delete(WINDOW *win) { WINDOWLIST *p; bool result = TRUE; +#ifdef USE_SP_WINDOWLIST + SCREEN *sp = _nc_screen_of(win); +#endif - for (p = _nc_windows; p != 0; p = p->next) { + for (each_window(SP_PARM, p)) { if (&(p->win) == win) { result = FALSE; } else if ((p->win._flags & _SUBWIN) != 0 @@ -65,21 +70,24 @@ delwin(WINDOW *win) { int result = ERR; - T((T_CALLED("delwin(%p)"), win)); + T((T_CALLED("delwin(%p)"), (void *) win)); - _nc_lock_global(windowlist); - if (win == 0 - || cannot_delete(win)) { - result = ERR; - } else { + if (_nc_try_global(curses) == 0) { + if (win == 0 + || cannot_delete(win)) { + result = ERR; + } else { +#if NCURSES_SP_FUNCS + SCREEN *sp = _nc_screen_of(win); +#endif + if (win->_flags & _SUBWIN) + touchwin(win->_parent); + else if (CurScreen(SP_PARM) != 0) + touchwin(CurScreen(SP_PARM)); - if (win->_flags & _SUBWIN) - touchwin(win->_parent); - else if (curscr != 0) - touchwin(curscr); - - result = _nc_freewin(win); + result = _nc_freewin(win); + } + _nc_unlock_global(curses); } - _nc_unlock_global(windowlist); returnCode(result); }