-
- Downloads
Bug 1904424 [Linux/X11] Don't steal focus on X11 r=emilio a=RyanVM
The patch comes from https://gitlab.com/redhat/centos-stream/rpms/firefox/-/merge_requests/94 Firefox isn't currently handling window focusing right on X11... There's a few problems: If no startup id is provided, it tries to get user time from g_get_monotonic_time when there's no guarantee that timestamp is synchronized or even in a compatible unit. This merge request addressed that by dropping the code that uses g_get_monotonic_time entirely, and instead adding a heuristic to synthesize a startup id based on the time of the last user interaction on the display. This makes an assumption that firefox was started as a result of user interaction, which might not always hold true, but it's more likely than not, and is basically the same assumption firefox is already making by trying to use a timestamp of "now" (g_get_monotonic_time) when focusing the window. If a startup id is provided, it fails to tell gtk to use it when focusing the window because it calls gtk_window_present_with_time with some other random timestamp instead of passing GDK_CURRENT_TIME (which is the magic value that means "use startup id for timestamp"). This commit tries to detect when a startup id is available, and the display is X11, and if so use a timestamp of GDK_CURRENT_TIME. Differential Revision: https://phabricator.services.mozilla.com/D217174
Showing
- toolkit/components/remote/nsDBusRemoteServer.cpp 1 addition, 5 deletionstoolkit/components/remote/nsDBusRemoteServer.cpp
- toolkit/xre/nsAppRunner.cpp 5 additions, 1 deletiontoolkit/xre/nsAppRunner.cpp
- widget/gtk/WidgetUtilsGtk.cpp 71 additions, 0 deletionswidget/gtk/WidgetUtilsGtk.cpp
- widget/gtk/WidgetUtilsGtk.h 7 additions, 1 deletionwidget/gtk/WidgetUtilsGtk.h
- widget/gtk/nsWindow.cpp 12 additions, 0 deletionswidget/gtk/nsWindow.cpp
Loading
Please register or sign in to comment