From e6c77a1ddc0226e5893cc7403a5f6344032e07c2 Mon Sep 17 00:00:00 2001 From: Vlad Zahorodnii Date: Thu, 30 Sep 2021 14:46:01 +0300 Subject: [PATCH] Clear should_get_focus in Workspace::focusToNull() On X11, there are four input models. With some input models, it's okay if the window manager calls XSetInputFocus(), with others, the wm has to ask the client to make a XSetInputFocus() request. If kwin wants a client to take input focus, kwin will add the client to the should_get_focus list, which contains all the windows that are about to get input focus. Clients are popped from the list upon receiving FOCUS_IN events. A client will be added to the should_get_focus list even if kwin thinks that the client already has input focus because communication between the wm and xorg is async, anything can happen with input focus in meanwhile. On the other hand, the wm may sometimes focus the null window if no window should contain the input focus. The issue is that the should_get_focus list is not cleaned up in that case, which can lead to Workspace::mostRecentlyActivatedClient() returning wrong client and possibly other async related issues. We don't have such madness on Wayland as the compositor is in charge of handling input focus. This change makes Workspace::focusToNull() clear the should_get_focus, which is reasonable. We need to deactivate "in-flight" focus requests. This also fixes the bug where fullscreen Wayland windows don't go above docks and panels due to Workspace::mostRecentlyActivatedClient() returning bad client. BUG: 439405 BUG: 395919 --- src/workspace.cpp | 1 + 1 file changed, 1 insertion(+) diff --git a/src/workspace.cpp b/src/workspace.cpp index cd9b16a01d..c3d56bae5e 100644 --- a/src/workspace.cpp +++ b/src/workspace.cpp @@ -1376,6 +1376,7 @@ bool Workspace::checkStartupNotification(xcb_window_t w, KStartupInfoId &id, KSt void Workspace::focusToNull() { if (m_nullFocus) { + should_get_focus.clear(); m_nullFocus->focus(); } }