From bd19aba00a3a080c7c469e5602c53e1532aed573 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20Bernon?= Date: Wed, 22 Mar 2023 14:24:56 +0100 Subject: [PATCH] Use last event time when calling XSetInputFocus This fixes a race condition when WM_TAKE_FOCUS message is sent to client windows, with the last event time as time parameter. The client might react to the WM_TAKE_FOCUS message with a XSetInputFocus call, and is expected to pass the message time as time parameter. As fvwm concurrently calls XSetInputFocus with CurrentTime, it causes a race condition and sometimes the X server gives focus to fvwm window, stealing the focus from the client window. --- fvwm/focus.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/fvwm/focus.c b/fvwm/focus.c index b63dc65cf..3271233bb 100644 --- a/fvwm/focus.c +++ b/fvwm/focus.c @@ -80,7 +80,7 @@ static FvwmWindow *LastScreenFocus = NULL; void _focus_set(Window w, FvwmWindow *fw) { Scr.focus_in_requested_window = fw; - XSetInputFocus(dpy, w, RevertToParent, CurrentTime); + XSetInputFocus(dpy, w, RevertToParent, fev_get_evtime()); return; } @@ -88,7 +88,7 @@ void _focus_set(Window w, FvwmWindow *fw) void _focus_reset(void) { Scr.focus_in_requested_window = NULL; - XSetInputFocus(dpy, PointerRoot, RevertToPointerRoot, CurrentTime); + XSetInputFocus(dpy, PointerRoot, RevertToPointerRoot, fev_get_evtime()); return; }