diff options
author | Drew DeVault <sir@cmpwn.com> | 2018-07-29 10:49:29 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-07-29 10:49:29 -0400 |
commit | 5734d0530c7e320860013cb9465a2e15f5238fb6 (patch) | |
tree | 564e8c86293ac44fdebe523945502ea1782fad5c /include | |
parent | f572bc065ec82cc469a98e85158fa0fc9ed70c64 (diff) | |
parent | 81cc842f8f27461742710b4195443da64c7bfeef (diff) |
Merge pull request #1165 from Ongy/reintroduce_is_unmanaged
reintroduce xwayland is_unmanaged
Diffstat (limited to 'include')
-rw-r--r-- | include/wlr/xwayland.h | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/include/wlr/xwayland.h b/include/wlr/xwayland.h index 2b643ec9..e7f7a467 100644 --- a/include/wlr/xwayland.h +++ b/include/wlr/xwayland.h @@ -209,4 +209,29 @@ struct wlr_xwayland_surface *wlr_xwayland_surface_from_wlr_surface( void wlr_xwayland_surface_ping(struct wlr_xwayland_surface *surface); +/** Metric to guess if an OR window should "receive" focus + * + * In the pure X setups, window managers usually straight up ignore override + * redirect windows, and never touch them. (we have to handle them for mapping) + * + * When such a window wants to receive keyboard input (e.g. rofi/dzen) it will + * use mechanics we don't support (sniffing/grabbing input). + * [Sadly this is unrelated to xwayland-keyboard-grab] + * + * To still support these windows, while keeping general OR semantics as is, we + * need to hand a subset of windows focus. + * The dirty truth is, we need to hand focus to any Xwayland window, though + * pretending this window has focus makes it easier to handle unmap. + * + * This function provides a handy metric based on the window type to guess if + * the OR window wants focus. + * It's probably not perfect, nor exactly intended but works in practice. + * + * Returns: true if the window should receive focus + * false if it should be ignored + */ +bool wlr_xwayland_or_surface_wants_focus( + const struct wlr_xwayland_surface *surface); + + #endif |