tinywl: fix crash when previously focused surface is not a toplevel

It can be e.g. a popup.

Closes: https://gitlab.freedesktop.org/wlroots/wlroots/-/issues/3754
This commit is contained in:
Simon Ser 2023-11-13 10:32:03 +01:00
parent 319e4125ab
commit 9e5d0f95f8

View file

@ -120,11 +120,10 @@ static void focus_view(struct tinywl_view *view, struct wlr_surface *surface) {
* it no longer has focus and the client will repaint accordingly, e.g. * it no longer has focus and the client will repaint accordingly, e.g.
* stop displaying a caret. * stop displaying a caret.
*/ */
struct wlr_xdg_surface *previous = struct wlr_xdg_toplevel *prev_toplevel =
wlr_xdg_surface_try_from_wlr_surface(seat->keyboard_state.focused_surface); wlr_xdg_toplevel_try_from_wlr_surface(prev_surface);
assert(previous != NULL && previous->role == WLR_XDG_SURFACE_ROLE_TOPLEVEL); if (prev_toplevel != NULL) {
if (previous->toplevel != NULL) { wlr_xdg_toplevel_set_activated(prev_toplevel, false);
wlr_xdg_toplevel_set_activated(previous->toplevel, false);
} }
} }
struct wlr_keyboard *keyboard = wlr_seat_get_keyboard(seat); struct wlr_keyboard *keyboard = wlr_seat_get_keyboard(seat);