From e7e33093dfa9f46069dbc7fa53dcdb2330cbdc57 Mon Sep 17 00:00:00 2001 From: Sebastian Lackner Date: Fri, 22 Nov 2013 18:54:18 +0100 Subject: winex11: Enable/disable windows when they are (un)mapped by foreign applications --- dlls/winex11.drv/event.c | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/dlls/winex11.drv/event.c b/dlls/winex11.drv/event.c index d81ff2e..c8ce8ad 100644 --- a/dlls/winex11.drv/event.c +++ b/dlls/winex11.drv/event.c @@ -929,6 +929,7 @@ static BOOL X11DRV_Expose( HWND hwnd, XEvent *xev ) static BOOL X11DRV_MapNotify( HWND hwnd, XEvent *event ) { struct x11drv_win_data *data; + BOOL is_embedded; if (event->xany.window == x11drv_thread_data()->clip_window) { @@ -943,7 +944,12 @@ static BOOL X11DRV_MapNotify( HWND hwnd, XEvent *event ) if (hwndFocus && IsChild( hwnd, hwndFocus )) set_input_focus( data ); } + + is_embedded = data->embedded; release_win_data( data ); + + if (is_embedded) + EnableWindow( hwnd, TRUE ); return TRUE; } @@ -953,8 +959,19 @@ static BOOL X11DRV_MapNotify( HWND hwnd, XEvent *event ) */ static BOOL X11DRV_UnmapNotify( HWND hwnd, XEvent *event ) { + struct x11drv_win_data *data; + BOOL is_embedded; + if (event->xany.window == x11drv_thread_data()->clip_window) clipping_cursor = FALSE; + + if (!(data = get_win_data( hwnd ))) return FALSE; + + is_embedded = data->embedded; + release_win_data( data ); + + if (is_embedded) + EnableWindow( hwnd, FALSE ); return TRUE; } -- 2.9.0