From ab0c4c5a531827e4c8585dcba1be8e57a09c39fc Mon Sep 17 00:00:00 2001 From: Bijay Shrestha Date: Wed, 25 Sep 2024 18:10:55 +0000 Subject: [PATCH] fix: mouse click on KeyboardSwap crashes --- src/input/mod.rs | 53 ++++++++++++++++++++++++++++-------------------- 1 file changed, 31 insertions(+), 22 deletions(-) diff --git a/src/input/mod.rs b/src/input/mod.rs index 3bcb3036..04c68e7b 100644 --- a/src/input/mod.rs +++ b/src/input/mod.rs @@ -16,7 +16,7 @@ use crate::{ floating::ResizeGrabMarker, tiling::{NodeDesc, TilingLayout}, }, - SeatExt, Trigger, + OverviewMode, SeatExt, Trigger, }, utils::{prelude::*, quirks::workspace_overview_is_open}, wayland::{ @@ -665,27 +665,36 @@ impl State { match mouse_button { smithay::backend::input::MouseButton::Left => { supress_button(); - self.common.event_loop_handle.insert_idle( - move |state| { - let mut shell = - state.common.shell.write().unwrap(); - let res = shell.move_request( - &surface, - &seat_clone, - serial, - ReleaseMode::NoMouseButtons, - false, - &state.common.config, - &state.common.event_loop_handle, - &state.common.xdg_activation_state, - false, - ); - drop(shell); - dispatch_grab( - res, seat_clone, serial, state, - ); - }, - ); + // Mouse click in KeyboardSwap Overview Mode + // crashes compositor. Workspace Overview Mode + // needs mouse click. + if !matches!( + shell.overview_mode().0.trigger(), + Some(&Trigger::KeyboardSwap(_, _)) + ) { + self.common.event_loop_handle.insert_idle( + move |state| { + let mut shell = + state.common.shell.write().unwrap(); + + let res = shell.move_request( + &surface, + &seat_clone, + serial, + ReleaseMode::NoMouseButtons, + false, + &state.common.config, + &state.common.event_loop_handle, + &state.common.xdg_activation_state, + false, + ); + drop(shell); + dispatch_grab( + res, seat_clone, serial, state, + ); + }, + ); + } } smithay::backend::input::MouseButton::Right => { supress_button();