summaryrefslogtreecommitdiffstats
path: root/generic
diff options
context:
space:
mode:
authorfvogel <fvogel@noemail.net>2016-05-26 18:21:34 (GMT)
committerfvogel <fvogel@noemail.net>2016-05-26 18:21:34 (GMT)
commit66a3c8ac882b5957d44ffda2778f6417a39d8b73 (patch)
treee283869e669211ec1acc4dbb9689fdf0883dc8fa /generic
parentf7ea9a9691574a84c77bb596181e0fe013040108 (diff)
downloadtk-66a3c8ac882b5957d44ffda2778f6417a39d8b73.zip
tk-66a3c8ac882b5957d44ffda2778f6417a39d8b73.tar.gz
tk-66a3c8ac882b5957d44ffda2778f6417a39d8b73.tar.bz2
Fixed [79549a9134] - Mouse pointer warping crashes
FossilOrigin-Name: 3a4c49a560c6a14ca09490c64a03a3b6817c1066
Diffstat (limited to 'generic')
-rw-r--r--generic/tkBind.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/generic/tkBind.c b/generic/tkBind.c
index 9cd3b7b..81c768b 100644
--- a/generic/tkBind.c
+++ b/generic/tkBind.c
@@ -3535,8 +3535,16 @@ DoWarp(
{
TkDisplay *dispPtr = clientData;
- TkpWarpPointer(dispPtr);
- XForceScreenSaver(dispPtr->display, ScreenSaverReset);
+ /*
+ * DoWarp was scheduled only if the window was mapped. It needs to be
+ * still mapped at the time the present idle callback is executed. In
+ * particular, this guards against window destruction in the meantime.
+ */
+
+ if (Tk_IsMapped(dispPtr->warpWindow)) {
+ TkpWarpPointer(dispPtr);
+ XForceScreenSaver(dispPtr->display, ScreenSaverReset);
+ }
dispPtr->flags &= ~TK_DISPLAY_IN_WARP;
}