From 963ff14ed025eeb5d6785dbcd4c073251ef7a9e9 Mon Sep 17 00:00:00 2001 From: Ivan Molodetskikh Date: Mon, 10 Feb 2025 13:11:50 +0300 Subject: Store hit type in PointContents --- src/input/mod.rs | 4 ++-- src/niri.rs | 6 ++++-- 2 files changed, 6 insertions(+), 4 deletions(-) (limited to 'src') diff --git a/src/input/mod.rs b/src/input/mod.rs index 8abccd67..96e17bc2 100644 --- a/src/input/mod.rs +++ b/src/input/mod.rs @@ -2451,7 +2451,7 @@ impl State { if let Some(pos) = self.niri.tablet_cursor_location { let under = self.niri.contents_under(pos); - if let Some(window) = under.window { + if let Some((window, _)) = under.window { self.niri.layout.activate_window(&window); // FIXME: granular. @@ -2823,7 +2823,7 @@ impl State { let under = self.niri.contents_under(touch_location); if !handle.is_grabbed() { - if let Some(window) = under.window { + if let Some((window, _)) = under.window { self.niri.layout.activate_window(&window); // Check if we need to start an interactive move. diff --git a/src/niri.rs b/src/niri.rs index 96d52686..8710493c 100644 --- a/src/niri.rs +++ b/src/niri.rs @@ -455,7 +455,7 @@ pub struct PointContents { // border around the window. pub surface: Option<(WlSurface, Point)>, // If surface belongs to a window, this is that window. - pub window: Option, + pub window: Option<(Window, HitType)>, // If surface belongs to a layer surface, this is that layer surface. pub layer: Option, } @@ -2720,7 +2720,7 @@ impl Niri { } else { None }; - (surface_and_pos, (Some(window.clone()), None)) + (surface_and_pos, (Some((window.clone(), hit)), None)) }) }; @@ -5060,6 +5060,8 @@ impl Niri { if let Some(window) = &new_focus.window { if current_focus.window.as_ref() != Some(window) { + let (window, _) = window; + if !self.layout.should_trigger_focus_follows_mouse_on(window) { return; } -- cgit