diff options
| author | Ivan Molodetskikh <yalterz@gmail.com> | 2025-02-10 13:11:50 +0300 |
|---|---|---|
| committer | Ivan Molodetskikh <yalterz@gmail.com> | 2025-02-10 07:29:33 -0800 |
| commit | 963ff14ed025eeb5d6785dbcd4c073251ef7a9e9 (patch) | |
| tree | e4d2c85b4d3c77dc46f1a20cce8feb462484e439 | |
| parent | 96a3ded2ec74954e9432f4b84bc8e125851dfb9e (diff) | |
| download | niri-963ff14ed025eeb5d6785dbcd4c073251ef7a9e9.tar.gz niri-963ff14ed025eeb5d6785dbcd4c073251ef7a9e9.tar.bz2 niri-963ff14ed025eeb5d6785dbcd4c073251ef7a9e9.zip | |
Store hit type in PointContents
| -rw-r--r-- | src/input/mod.rs | 4 | ||||
| -rw-r--r-- | src/niri.rs | 6 |
2 files changed, 6 insertions, 4 deletions
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<f64, Logical>)>, // If surface belongs to a window, this is that window. - pub window: Option<Window>, + pub window: Option<(Window, HitType)>, // If surface belongs to a layer surface, this is that layer surface. pub layer: Option<LayerSurface>, } @@ -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; } |
