Merge pull request #20 from Ottatop/dev

Fix tiled windows overlapping when jerking mouse
This commit is contained in:
Ottatop 2023-07-18 12:58:48 -05:00 committed by GitHub
commit ffa847bf36
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -585,30 +585,6 @@ fn filter_windows(windows: &[Window], tags: Vec<Tag>) -> Vec<Window> {
impl<B: Backend> State<B> { impl<B: Backend> State<B> {
pub fn swap_window_positions(&mut self, win1: &Window, win2: &Window) { pub fn swap_window_positions(&mut self, win1: &Window, win2: &Window) {
// FIXME: moving the mouse quickly will break swapping
let win1_loc = self.space.element_location(win1).unwrap(); // TODO: handle unwraps
let win2_loc = self.space.element_location(win2).unwrap();
let win1_geo = win1.geometry();
let win2_geo = win2.geometry();
win1.toplevel().with_pending_state(|state| {
state.size = Some(win2_geo.size);
});
win2.toplevel().with_pending_state(|state| {
state.size = Some(win1_geo.size);
});
let serial = win1.toplevel().send_configure();
win1.with_state(|state| {
state.resize_state = WindowResizeState::Requested(serial, win2_loc);
});
let serial = win2.toplevel().send_configure();
win2.with_state(|state| {
state.resize_state = WindowResizeState::Requested(serial, win1_loc);
});
let mut elems = self let mut elems = self
.windows .windows
.iter_mut() .iter_mut()
@ -621,5 +597,8 @@ impl<B: Backend> State<B> {
std::mem::swap(first, second); std::mem::swap(first, second);
} }
} }
let output = self.focus_state.focused_output.clone().unwrap(); // FIXME: unwrap
self.re_layout(&output);
} }
} }