summaryrefslogtreecommitdiffstats
path: root/generic/tkWindow.c
diff options
context:
space:
mode:
authorpatthoyts <patthoyts@users.sourceforge.net>2009-02-27 22:59:30 (GMT)
committerpatthoyts <patthoyts@users.sourceforge.net>2009-02-27 22:59:30 (GMT)
commita072beb6c3788ba0416b47a505dddd7b73744535 (patch)
tree1b90e7279daa7800c2331ab6b2f939914cf68866 /generic/tkWindow.c
parent22aeecc3e7f01548116fdf9166c8865a1aa2f523 (diff)
downloadtk-a072beb6c3788ba0416b47a505dddd7b73744535.zip
tk-a072beb6c3788ba0416b47a505dddd7b73744535.tar.gz
tk-a072beb6c3788ba0416b47a505dddd7b73744535.tar.bz2
[Bug 2645457] check for dead windows after calling Tk_MakeWindowExist to avoid a crash when mapping dead windows.
Diffstat (limited to 'generic/tkWindow.c')
-rw-r--r--generic/tkWindow.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/generic/tkWindow.c b/generic/tkWindow.c
index 406eb7a..161cdcb 100644
--- a/generic/tkWindow.c
+++ b/generic/tkWindow.c
@@ -11,7 +11,7 @@
* See the file "license.terms" for information on usage and redistribution of
* this file, and for a DISCLAIMER OF ALL WARRANTIES.
*
- * RCS: @(#) $Id: tkWindow.c,v 1.89.2.2 2008/04/07 23:14:07 hobbs Exp $
+ * RCS: @(#) $Id: tkWindow.c,v 1.89.2.3 2009/02/27 22:59:30 patthoyts Exp $
*/
#include "tkInt.h"
@@ -1640,6 +1640,13 @@ Tk_MapWindow(
if (winPtr->window == None) {
Tk_MakeWindowExist(tkwin);
}
+ /*
+ * [Bug 2645457]: the previous call permits events to be processed and can
+ * lead to the destruction of the window under some conditions.
+ */
+ if (winPtr->flags & TK_ALREADY_DEAD) {
+ return;
+ }
if (winPtr->flags & TK_WIN_MANAGED) {
/*
* Lots of special processing has to be done for top-level windows.