mirror of
https://github.com/pinnacle-comp/pinnacle.git
synced 2025-01-13 08:01:05 +01:00
Fiddle with stuff
This commit is contained in:
parent
d813d429bf
commit
824595637b
5 changed files with 17 additions and 8 deletions
|
@ -99,6 +99,8 @@ function pinnacle.setup(config_func)
|
||||||
local msg_len_bytes, err_msg, err_num = read_exact(socket_fd, 4)
|
local msg_len_bytes, err_msg, err_num = read_exact(socket_fd, 4)
|
||||||
assert(msg_len_bytes)
|
assert(msg_len_bytes)
|
||||||
|
|
||||||
|
-- TODO: break here if error in read_exact
|
||||||
|
|
||||||
---@type integer
|
---@type integer
|
||||||
local msg_len = string.unpack("=I4", msg_len_bytes)
|
local msg_len = string.unpack("=I4", msg_len_bytes)
|
||||||
|
|
||||||
|
|
|
@ -17,6 +17,7 @@ impl FocusState {
|
||||||
Default::default()
|
Default::default()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: how does this work with unmapped windows?
|
||||||
/// Get the currently focused window. If there is none, the previous focus is returned.
|
/// Get the currently focused window. If there is none, the previous focus is returned.
|
||||||
pub fn current_focus(&mut self) -> Option<Window> {
|
pub fn current_focus(&mut self) -> Option<Window> {
|
||||||
while let Some(window) = self.focus_stack.last() {
|
while let Some(window) = self.focus_stack.last() {
|
||||||
|
|
|
@ -96,6 +96,8 @@ impl<B: Backend> CompositorHandler for State<B> {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn commit(&mut self, surface: &WlSurface) {
|
fn commit(&mut self, surface: &WlSurface) {
|
||||||
|
tracing::debug!("commit");
|
||||||
|
|
||||||
utils::on_commit_buffer_handler::<Self>(surface);
|
utils::on_commit_buffer_handler::<Self>(surface);
|
||||||
|
|
||||||
if !compositor::is_sync_subsurface(surface) {
|
if !compositor::is_sync_subsurface(surface) {
|
||||||
|
@ -147,7 +149,7 @@ fn ensure_initial_configure<B: Backend>(surface: &WlSurface, state: &mut State<B
|
||||||
// println!("initial_configure_sent is {}", initial_configure_sent);
|
// println!("initial_configure_sent is {}", initial_configure_sent);
|
||||||
|
|
||||||
if !initial_configure_sent {
|
if !initial_configure_sent {
|
||||||
tracing::info!("Initial configure");
|
tracing::debug!("Initial configure");
|
||||||
window.toplevel().send_configure();
|
window.toplevel().send_configure();
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
|
@ -257,7 +259,7 @@ impl<B: Backend> XdgShellHandler for State<B> {
|
||||||
let windows: Vec<Window> = self.space.elements().cloned().collect();
|
let windows: Vec<Window> = self.space.elements().cloned().collect();
|
||||||
|
|
||||||
self.loop_handle.insert_idle(|data| {
|
self.loop_handle.insert_idle(|data| {
|
||||||
tracing::info!("Layout master_stack");
|
tracing::debug!("Layout master_stack");
|
||||||
Layout::master_stack(&mut data.state, windows, crate::layout::Direction::Left);
|
Layout::master_stack(&mut data.state, windows, crate::layout::Direction::Left);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -389,11 +391,13 @@ impl<B: Backend> XdgShellHandler for State<B> {
|
||||||
// | mapping the element in commit, this means that the window won't reappear on a tag
|
// | mapping the element in commit, this means that the window won't reappear on a tag
|
||||||
// | change. The code below is a workaround until I can figure it out.
|
// | change. The code below is a workaround until I can figure it out.
|
||||||
if !self.space.elements().any(|win| win == &window) {
|
if !self.space.elements().any(|win| win == &window) {
|
||||||
tracing::debug!("remapping window");
|
|
||||||
WindowState::with_state(&window, |state| {
|
WindowState::with_state(&window, |state| {
|
||||||
if let WindowResizeState::WaitingForCommit(new_loc) = state.resize_state {
|
if let WindowResizeState::WaitingForCommit(new_loc) = state.resize_state {
|
||||||
self.space.map_element(window.clone(), new_loc, false);
|
tracing::debug!("remapping window");
|
||||||
state.resize_state = WindowResizeState::Idle;
|
let win = window.clone();
|
||||||
|
self.loop_handle.insert_idle(move |data| {
|
||||||
|
data.state.space.map_element(win, new_loc, false);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -263,10 +263,8 @@ impl<B: Backend> State<B> {
|
||||||
move_mode = false;
|
move_mode = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
FilterResult::Forward
|
|
||||||
} else {
|
|
||||||
FilterResult::Forward
|
|
||||||
}
|
}
|
||||||
|
FilterResult::Forward
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
|
@ -49,6 +49,7 @@ impl Layout {
|
||||||
|
|
||||||
window.toplevel().with_pending_state(|tl_state| {
|
window.toplevel().with_pending_state(|tl_state| {
|
||||||
tl_state.size = Some(state.space.output_geometry(output).unwrap().size);
|
tl_state.size = Some(state.space.output_geometry(output).unwrap().size);
|
||||||
|
tracing::debug!("only size is {:?}", tl_state.size);
|
||||||
});
|
});
|
||||||
|
|
||||||
let initial_configure_sent =
|
let initial_configure_sent =
|
||||||
|
@ -83,6 +84,7 @@ impl Layout {
|
||||||
let mut size = state.space.output_geometry(output).unwrap().size;
|
let mut size = state.space.output_geometry(output).unwrap().size;
|
||||||
size.w /= 2;
|
size.w /= 2;
|
||||||
tl_state.size = Some(size);
|
tl_state.size = Some(size);
|
||||||
|
tracing::debug!("first size is {:?}", tl_state.size);
|
||||||
});
|
});
|
||||||
|
|
||||||
let initial_configure_sent =
|
let initial_configure_sent =
|
||||||
|
@ -97,6 +99,7 @@ impl Layout {
|
||||||
});
|
});
|
||||||
if initial_configure_sent {
|
if initial_configure_sent {
|
||||||
WindowState::with_state(first_window, |state| {
|
WindowState::with_state(first_window, |state| {
|
||||||
|
tracing::debug!("sending resize state");
|
||||||
state.resize_state = WindowResizeState::WaitingForAck(
|
state.resize_state = WindowResizeState::WaitingForAck(
|
||||||
first_window.toplevel().send_configure(),
|
first_window.toplevel().send_configure(),
|
||||||
output.current_location(),
|
output.current_location(),
|
||||||
|
@ -122,6 +125,7 @@ impl Layout {
|
||||||
// | this is set too low.
|
// | this is set too low.
|
||||||
new_size.h = new_size.h.clamp(40, i32::MAX);
|
new_size.h = new_size.h.clamp(40, i32::MAX);
|
||||||
state.size = Some(new_size);
|
state.size = Some(new_size);
|
||||||
|
tracing::debug!("size is {:?}", state.size);
|
||||||
});
|
});
|
||||||
|
|
||||||
let mut new_loc = output.current_location();
|
let mut new_loc = output.current_location();
|
||||||
|
|
Loading…
Reference in a new issue