mirror of
https://github.com/pinnacle-comp/pinnacle.git
synced 2025-01-18 22:26:12 +01:00
Update Smithay
This commit is contained in:
parent
49908df38b
commit
16fff3f7e3
14 changed files with 268 additions and 131 deletions
8
Cargo.lock
generated
8
Cargo.lock
generated
|
@ -831,9 +831,9 @@ dependencies = [
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "gbm"
|
name = "gbm"
|
||||||
version = "0.14.1"
|
version = "0.14.2"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "f177420f6650dcd50042121adf7ff7ab265abdaf4862fe2624066e36e3a9ef34"
|
checksum = "313702b30cdeb83ddc72bc14dcee67803cd0ae2d12282ea06e368c25a900c844"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bitflags 1.3.2",
|
"bitflags 1.3.2",
|
||||||
"drm",
|
"drm",
|
||||||
|
@ -2053,7 +2053,7 @@ checksum = "e6ecd384b10a64542d77071bd64bd7b231f4ed5940fba55e98c3de13824cf3d7"
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "smithay"
|
name = "smithay"
|
||||||
version = "0.3.0"
|
version = "0.3.0"
|
||||||
source = "git+https://github.com/Smithay/smithay?rev=1074914#1074914492783b25a4c2c49ce49a126d39994596"
|
source = "git+https://github.com/Smithay/smithay?rev=418190e#418190e4992ce642e6bac873307d4fc4fa9a1e89"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"appendlist",
|
"appendlist",
|
||||||
"ash",
|
"ash",
|
||||||
|
@ -2128,7 +2128,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "smithay-drm-extras"
|
name = "smithay-drm-extras"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/Smithay/smithay?rev=1074914#1074914492783b25a4c2c49ce49a126d39994596"
|
source = "git+https://github.com/Smithay/smithay?rev=418190e#418190e4992ce642e6bac873307d4fc4fa9a1e89"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"drm",
|
"drm",
|
||||||
"edid-rs",
|
"edid-rs",
|
||||||
|
|
|
@ -34,8 +34,8 @@ repository.workspace = true
|
||||||
keywords = ["wayland", "compositor", "smithay", "lua"]
|
keywords = ["wayland", "compositor", "smithay", "lua"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
smithay = { git = "https://github.com/Smithay/smithay", rev = "1074914", default-features = false, features = ["desktop", "wayland_frontend"] }
|
smithay = { git = "https://github.com/Smithay/smithay", rev = "418190e", default-features = false, features = ["desktop", "wayland_frontend"] }
|
||||||
smithay-drm-extras = { git = "https://github.com/Smithay/smithay", rev = "1074914" }
|
smithay-drm-extras = { git = "https://github.com/Smithay/smithay", rev = "418190e" }
|
||||||
|
|
||||||
tracing = "0.1.40"
|
tracing = "0.1.40"
|
||||||
tracing-subscriber = { version = "0.3.18", features = ["env-filter", "registry"] }
|
tracing-subscriber = { version = "0.3.18", features = ["env-filter", "registry"] }
|
||||||
|
|
|
@ -1123,7 +1123,9 @@ impl window_service_server::WindowService for WindowService {
|
||||||
let Some(window) = window_id.window(state) else { return };
|
let Some(window) = window_id.window(state) else { return };
|
||||||
|
|
||||||
match window {
|
match window {
|
||||||
WindowElement::Wayland(window) => window.toplevel().send_close(),
|
WindowElement::Wayland(window) => {
|
||||||
|
window.toplevel().expect("in wayland enum").send_close()
|
||||||
|
}
|
||||||
WindowElement::X11(surface) => surface.close().expect("failed to close x11 win"),
|
WindowElement::X11(surface) => surface.close().expect("failed to close x11 win"),
|
||||||
WindowElement::X11OverrideRedirect(_) => {
|
WindowElement::X11OverrideRedirect(_) => {
|
||||||
tracing::warn!("tried to close override redirect window");
|
tracing::warn!("tried to close override redirect window");
|
||||||
|
@ -1431,7 +1433,7 @@ impl window_service_server::WindowService for WindowService {
|
||||||
|
|
||||||
for window in state.space.elements() {
|
for window in state.space.elements() {
|
||||||
if let WindowElement::Wayland(window) = window {
|
if let WindowElement::Wayland(window) = window {
|
||||||
window.toplevel().send_configure();
|
window.toplevel().expect("in wayland enum").send_configure();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -91,8 +91,12 @@ const SUPPORTED_FORMATS: &[Fourcc] = &[
|
||||||
const SUPPORTED_FORMATS_8BIT_ONLY: &[Fourcc] = &[Fourcc::Abgr8888, Fourcc::Argb8888];
|
const SUPPORTED_FORMATS_8BIT_ONLY: &[Fourcc] = &[Fourcc::Abgr8888, Fourcc::Argb8888];
|
||||||
|
|
||||||
/// A [`MultiRenderer`] that uses the [`GbmGlesBackend`].
|
/// A [`MultiRenderer`] that uses the [`GbmGlesBackend`].
|
||||||
type UdevRenderer<'a, 'b> =
|
type UdevRenderer<'a> = MultiRenderer<
|
||||||
MultiRenderer<'a, 'a, 'b, GbmGlesBackend<GlesRenderer>, GbmGlesBackend<GlesRenderer>>;
|
'a,
|
||||||
|
'a,
|
||||||
|
GbmGlesBackend<GlesRenderer, DrmDeviceFd>,
|
||||||
|
GbmGlesBackend<GlesRenderer, DrmDeviceFd>,
|
||||||
|
>;
|
||||||
|
|
||||||
/// Udev state attached to each [`Output`].
|
/// Udev state attached to each [`Output`].
|
||||||
#[derive(Debug, PartialEq)]
|
#[derive(Debug, PartialEq)]
|
||||||
|
@ -110,7 +114,7 @@ pub struct Udev {
|
||||||
pub(super) dmabuf_state: Option<(DmabufState, DmabufGlobal)>,
|
pub(super) dmabuf_state: Option<(DmabufState, DmabufGlobal)>,
|
||||||
pub(super) primary_gpu: DrmNode,
|
pub(super) primary_gpu: DrmNode,
|
||||||
allocator: Option<Box<dyn Allocator<Buffer = Dmabuf, Error = AnyError>>>,
|
allocator: Option<Box<dyn Allocator<Buffer = Dmabuf, Error = AnyError>>>,
|
||||||
pub(super) gpu_manager: GpuManager<GbmGlesBackend<GlesRenderer>>,
|
pub(super) gpu_manager: GpuManager<GbmGlesBackend<GlesRenderer, DrmDeviceFd>>,
|
||||||
backends: HashMap<DrmNode, UdevBackendData>,
|
backends: HashMap<DrmNode, UdevBackendData>,
|
||||||
pointer_images: Vec<(xcursor::parser::Image, TextureBuffer<MultiTexture>)>,
|
pointer_images: Vec<(xcursor::parser::Image, TextureBuffer<MultiTexture>)>,
|
||||||
pointer_element: PointerElement<MultiTexture>,
|
pointer_element: PointerElement<MultiTexture>,
|
||||||
|
@ -226,10 +230,7 @@ impl BackendData for Udev {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn early_import(&mut self, surface: &WlSurface) {
|
fn early_import(&mut self, surface: &WlSurface) {
|
||||||
if let Err(err) =
|
if let Err(err) = self.gpu_manager.early_import(self.primary_gpu, surface) {
|
||||||
self.gpu_manager
|
|
||||||
.early_import(Some(self.primary_gpu), self.primary_gpu, surface)
|
|
||||||
{
|
|
||||||
tracing::warn!("early buffer import failed: {}", err);
|
tracing::warn!("early buffer import failed: {}", err);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -556,7 +557,7 @@ enum DeviceAddError {
|
||||||
fn get_surface_dmabuf_feedback(
|
fn get_surface_dmabuf_feedback(
|
||||||
primary_gpu: DrmNode,
|
primary_gpu: DrmNode,
|
||||||
render_node: DrmNode,
|
render_node: DrmNode,
|
||||||
gpu_manager: &mut GpuManager<GbmGlesBackend<GlesRenderer>>,
|
gpu_manager: &mut GpuManager<GbmGlesBackend<GlesRenderer, DrmDeviceFd>>,
|
||||||
composition: &GbmDrmCompositor,
|
composition: &GbmDrmCompositor,
|
||||||
) -> Option<DrmSurfaceDmabufFeedback> {
|
) -> Option<DrmSurfaceDmabufFeedback> {
|
||||||
let primary_formats = gpu_manager
|
let primary_formats = gpu_manager
|
||||||
|
@ -1210,18 +1211,8 @@ impl State {
|
||||||
udev.gpu_manager.single_renderer(&render_node)
|
udev.gpu_manager.single_renderer(&render_node)
|
||||||
} else {
|
} else {
|
||||||
let format = surface.compositor.format();
|
let format = surface.compositor.format();
|
||||||
udev.gpu_manager.renderer(
|
udev.gpu_manager
|
||||||
&primary_gpu,
|
.renderer(&primary_gpu, &render_node, format)
|
||||||
&render_node,
|
|
||||||
udev
|
|
||||||
.allocator
|
|
||||||
.as_mut()
|
|
||||||
// TODO: We could build some kind of `GLAllocator` using Renderbuffers in theory for this case.
|
|
||||||
// That would work for memcpy's of offscreen contents.
|
|
||||||
.expect("We need an allocator for multigpu systems")
|
|
||||||
.as_mut(),
|
|
||||||
format,
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
.expect("failed to create MultiRenderer");
|
.expect("failed to create MultiRenderer");
|
||||||
|
|
||||||
|
@ -1294,7 +1285,7 @@ fn render_surface_for_output<'a>(
|
||||||
#[allow(clippy::too_many_arguments)]
|
#[allow(clippy::too_many_arguments)]
|
||||||
fn render_surface(
|
fn render_surface(
|
||||||
surface: &mut RenderSurface,
|
surface: &mut RenderSurface,
|
||||||
renderer: &mut UdevRenderer<'_, '_>,
|
renderer: &mut UdevRenderer<'_>,
|
||||||
output: &Output,
|
output: &Output,
|
||||||
|
|
||||||
space: &Space<WindowElement>,
|
space: &Space<WindowElement>,
|
||||||
|
|
101
src/focus.rs
101
src/focus.rs
|
@ -5,11 +5,12 @@ use smithay::{
|
||||||
input::{
|
input::{
|
||||||
keyboard::KeyboardTarget,
|
keyboard::KeyboardTarget,
|
||||||
pointer::{MotionEvent, PointerTarget},
|
pointer::{MotionEvent, PointerTarget},
|
||||||
|
touch::{self, TouchTarget},
|
||||||
Seat,
|
Seat,
|
||||||
},
|
},
|
||||||
output::Output,
|
output::Output,
|
||||||
reexports::wayland_server::{protocol::wl_surface::WlSurface, Resource},
|
reexports::wayland_server::{protocol::wl_surface::WlSurface, Resource},
|
||||||
utils::{IsAlive, SERIAL_COUNTER},
|
utils::{IsAlive, Serial, SERIAL_COUNTER},
|
||||||
wayland::seat::WaylandFocus,
|
wayland::seat::WaylandFocus,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -56,7 +57,7 @@ impl State {
|
||||||
assert!(!win.is_x11_override_redirect());
|
assert!(!win.is_x11_override_redirect());
|
||||||
|
|
||||||
if let WindowElement::Wayland(w) = win {
|
if let WindowElement::Wayland(w) = win {
|
||||||
w.toplevel().send_configure();
|
w.toplevel().expect("in wayland enum").send_configure();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -140,9 +141,9 @@ impl TryFrom<FocusTarget> for WlSurface {
|
||||||
impl PointerTarget<State> for FocusTarget {
|
impl PointerTarget<State> for FocusTarget {
|
||||||
fn frame(&self, seat: &Seat<State>, data: &mut State) {
|
fn frame(&self, seat: &Seat<State>, data: &mut State) {
|
||||||
match self {
|
match self {
|
||||||
FocusTarget::Window(window) => window.frame(seat, data),
|
FocusTarget::Window(window) => PointerTarget::frame(window, seat, data),
|
||||||
FocusTarget::Popup(popup) => popup.wl_surface().frame(seat, data),
|
FocusTarget::Popup(popup) => PointerTarget::frame(popup.wl_surface(), seat, data),
|
||||||
FocusTarget::LayerSurface(surf) => surf.frame(seat, data),
|
FocusTarget::LayerSurface(surf) => PointerTarget::frame(surf.wl_surface(), seat, data),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -152,7 +153,9 @@ impl PointerTarget<State> for FocusTarget {
|
||||||
FocusTarget::Popup(popup) => {
|
FocusTarget::Popup(popup) => {
|
||||||
PointerTarget::enter(popup.wl_surface(), seat, data, event);
|
PointerTarget::enter(popup.wl_surface(), seat, data, event);
|
||||||
}
|
}
|
||||||
FocusTarget::LayerSurface(surf) => PointerTarget::enter(surf, seat, data, event),
|
FocusTarget::LayerSurface(surf) => {
|
||||||
|
PointerTarget::enter(surf.wl_surface(), seat, data, event)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -162,7 +165,9 @@ impl PointerTarget<State> for FocusTarget {
|
||||||
FocusTarget::Popup(popup) => {
|
FocusTarget::Popup(popup) => {
|
||||||
PointerTarget::motion(popup.wl_surface(), seat, data, event);
|
PointerTarget::motion(popup.wl_surface(), seat, data, event);
|
||||||
}
|
}
|
||||||
FocusTarget::LayerSurface(surf) => PointerTarget::motion(surf, seat, data, event),
|
FocusTarget::LayerSurface(surf) => {
|
||||||
|
PointerTarget::motion(surf.wl_surface(), seat, data, event)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -180,7 +185,7 @@ impl PointerTarget<State> for FocusTarget {
|
||||||
PointerTarget::relative_motion(popup.wl_surface(), seat, data, event);
|
PointerTarget::relative_motion(popup.wl_surface(), seat, data, event);
|
||||||
}
|
}
|
||||||
FocusTarget::LayerSurface(surf) => {
|
FocusTarget::LayerSurface(surf) => {
|
||||||
PointerTarget::relative_motion(surf, seat, data, event);
|
PointerTarget::relative_motion(surf.wl_surface(), seat, data, event);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -196,7 +201,9 @@ impl PointerTarget<State> for FocusTarget {
|
||||||
FocusTarget::Popup(popup) => {
|
FocusTarget::Popup(popup) => {
|
||||||
PointerTarget::button(popup.wl_surface(), seat, data, event);
|
PointerTarget::button(popup.wl_surface(), seat, data, event);
|
||||||
}
|
}
|
||||||
FocusTarget::LayerSurface(surf) => PointerTarget::button(surf, seat, data, event),
|
FocusTarget::LayerSurface(surf) => {
|
||||||
|
PointerTarget::button(surf.wl_surface(), seat, data, event)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -209,23 +216,21 @@ impl PointerTarget<State> for FocusTarget {
|
||||||
match self {
|
match self {
|
||||||
FocusTarget::Window(window) => PointerTarget::axis(window, seat, data, frame),
|
FocusTarget::Window(window) => PointerTarget::axis(window, seat, data, frame),
|
||||||
FocusTarget::Popup(popup) => PointerTarget::axis(popup.wl_surface(), seat, data, frame),
|
FocusTarget::Popup(popup) => PointerTarget::axis(popup.wl_surface(), seat, data, frame),
|
||||||
FocusTarget::LayerSurface(surf) => PointerTarget::axis(surf, seat, data, frame),
|
FocusTarget::LayerSurface(surf) => {
|
||||||
|
PointerTarget::axis(surf.wl_surface(), seat, data, frame)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn leave(
|
fn leave(&self, seat: &Seat<State>, data: &mut State, serial: Serial, time: u32) {
|
||||||
&self,
|
|
||||||
seat: &Seat<State>,
|
|
||||||
data: &mut State,
|
|
||||||
serial: smithay::utils::Serial,
|
|
||||||
time: u32,
|
|
||||||
) {
|
|
||||||
match self {
|
match self {
|
||||||
FocusTarget::Window(window) => PointerTarget::leave(window, seat, data, serial, time),
|
FocusTarget::Window(window) => PointerTarget::leave(window, seat, data, serial, time),
|
||||||
FocusTarget::Popup(popup) => {
|
FocusTarget::Popup(popup) => {
|
||||||
PointerTarget::leave(popup.wl_surface(), seat, data, serial, time);
|
PointerTarget::leave(popup.wl_surface(), seat, data, serial, time);
|
||||||
}
|
}
|
||||||
FocusTarget::LayerSurface(surf) => PointerTarget::leave(surf, seat, data, serial, time),
|
FocusTarget::LayerSurface(surf) => {
|
||||||
|
PointerTarget::leave(surf.wl_surface(), seat, data, serial, time)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -308,7 +313,7 @@ impl KeyboardTarget<State> for FocusTarget {
|
||||||
seat: &Seat<State>,
|
seat: &Seat<State>,
|
||||||
data: &mut State,
|
data: &mut State,
|
||||||
keys: Vec<smithay::input::keyboard::KeysymHandle<'_>>,
|
keys: Vec<smithay::input::keyboard::KeysymHandle<'_>>,
|
||||||
serial: smithay::utils::Serial,
|
serial: Serial,
|
||||||
) {
|
) {
|
||||||
match self {
|
match self {
|
||||||
FocusTarget::Window(window) => KeyboardTarget::enter(window, seat, data, keys, serial),
|
FocusTarget::Window(window) => KeyboardTarget::enter(window, seat, data, keys, serial),
|
||||||
|
@ -316,18 +321,20 @@ impl KeyboardTarget<State> for FocusTarget {
|
||||||
KeyboardTarget::enter(popup.wl_surface(), seat, data, keys, serial);
|
KeyboardTarget::enter(popup.wl_surface(), seat, data, keys, serial);
|
||||||
}
|
}
|
||||||
FocusTarget::LayerSurface(surf) => {
|
FocusTarget::LayerSurface(surf) => {
|
||||||
KeyboardTarget::enter(surf, seat, data, keys, serial);
|
KeyboardTarget::enter(surf.wl_surface(), seat, data, keys, serial);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn leave(&self, seat: &Seat<State>, data: &mut State, serial: smithay::utils::Serial) {
|
fn leave(&self, seat: &Seat<State>, data: &mut State, serial: Serial) {
|
||||||
match self {
|
match self {
|
||||||
FocusTarget::Window(window) => KeyboardTarget::leave(window, seat, data, serial),
|
FocusTarget::Window(window) => KeyboardTarget::leave(window, seat, data, serial),
|
||||||
FocusTarget::Popup(popup) => {
|
FocusTarget::Popup(popup) => {
|
||||||
KeyboardTarget::leave(popup.wl_surface(), seat, data, serial);
|
KeyboardTarget::leave(popup.wl_surface(), seat, data, serial);
|
||||||
}
|
}
|
||||||
FocusTarget::LayerSurface(surf) => KeyboardTarget::leave(surf, seat, data, serial),
|
FocusTarget::LayerSurface(surf) => {
|
||||||
|
KeyboardTarget::leave(surf.wl_surface(), seat, data, serial)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -337,7 +344,7 @@ impl KeyboardTarget<State> for FocusTarget {
|
||||||
data: &mut State,
|
data: &mut State,
|
||||||
key: smithay::input::keyboard::KeysymHandle<'_>,
|
key: smithay::input::keyboard::KeysymHandle<'_>,
|
||||||
state: smithay::backend::input::KeyState,
|
state: smithay::backend::input::KeyState,
|
||||||
serial: smithay::utils::Serial,
|
serial: Serial,
|
||||||
time: u32,
|
time: u32,
|
||||||
) {
|
) {
|
||||||
match self {
|
match self {
|
||||||
|
@ -348,7 +355,7 @@ impl KeyboardTarget<State> for FocusTarget {
|
||||||
KeyboardTarget::key(popup.wl_surface(), seat, data, key, state, serial, time);
|
KeyboardTarget::key(popup.wl_surface(), seat, data, key, state, serial, time);
|
||||||
}
|
}
|
||||||
FocusTarget::LayerSurface(surf) => {
|
FocusTarget::LayerSurface(surf) => {
|
||||||
KeyboardTarget::key(surf, seat, data, key, state, serial, time);
|
KeyboardTarget::key(surf.wl_surface(), seat, data, key, state, serial, time);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -358,7 +365,7 @@ impl KeyboardTarget<State> for FocusTarget {
|
||||||
seat: &Seat<State>,
|
seat: &Seat<State>,
|
||||||
data: &mut State,
|
data: &mut State,
|
||||||
modifiers: smithay::input::keyboard::ModifiersState,
|
modifiers: smithay::input::keyboard::ModifiersState,
|
||||||
serial: smithay::utils::Serial,
|
serial: Serial,
|
||||||
) {
|
) {
|
||||||
match self {
|
match self {
|
||||||
FocusTarget::Window(window) => {
|
FocusTarget::Window(window) => {
|
||||||
|
@ -368,12 +375,54 @@ impl KeyboardTarget<State> for FocusTarget {
|
||||||
KeyboardTarget::modifiers(popup.wl_surface(), seat, data, modifiers, serial);
|
KeyboardTarget::modifiers(popup.wl_surface(), seat, data, modifiers, serial);
|
||||||
}
|
}
|
||||||
FocusTarget::LayerSurface(surf) => {
|
FocusTarget::LayerSurface(surf) => {
|
||||||
KeyboardTarget::modifiers(surf, seat, data, modifiers, serial);
|
KeyboardTarget::modifiers(surf.wl_surface(), seat, data, modifiers, serial);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl TouchTarget<State> for FocusTarget {
|
||||||
|
fn down(&self, seat: &Seat<State>, data: &mut State, event: &touch::DownEvent, seq: Serial) {
|
||||||
|
todo!()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn up(&self, seat: &Seat<State>, data: &mut State, event: &touch::UpEvent, seq: Serial) {
|
||||||
|
todo!()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn motion(
|
||||||
|
&self,
|
||||||
|
seat: &Seat<State>,
|
||||||
|
data: &mut State,
|
||||||
|
event: &touch::MotionEvent,
|
||||||
|
seq: Serial,
|
||||||
|
) {
|
||||||
|
todo!()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn frame(&self, seat: &Seat<State>, data: &mut State, seq: Serial) {
|
||||||
|
todo!()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn cancel(&self, seat: &Seat<State>, data: &mut State, seq: Serial) {
|
||||||
|
todo!()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn shape(&self, seat: &Seat<State>, data: &mut State, event: &touch::ShapeEvent, seq: Serial) {
|
||||||
|
todo!()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn orientation(
|
||||||
|
&self,
|
||||||
|
seat: &Seat<State>,
|
||||||
|
data: &mut State,
|
||||||
|
event: &touch::OrientationEvent,
|
||||||
|
seq: Serial,
|
||||||
|
) {
|
||||||
|
todo!()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl WaylandFocus for FocusTarget {
|
impl WaylandFocus for FocusTarget {
|
||||||
fn wl_surface(&self) -> Option<WlSurface> {
|
fn wl_surface(&self) -> Option<WlSurface> {
|
||||||
match self {
|
match self {
|
||||||
|
|
|
@ -160,7 +160,7 @@ impl PointerGrab<State> for ResizeSurfaceGrab {
|
||||||
|
|
||||||
match &self.window {
|
match &self.window {
|
||||||
WindowElement::Wayland(window) => {
|
WindowElement::Wayland(window) => {
|
||||||
let toplevel_surface = window.toplevel();
|
let toplevel_surface = window.toplevel().expect("in wayland enum");
|
||||||
|
|
||||||
toplevel_surface.with_pending_state(|state| {
|
toplevel_surface.with_pending_state(|state| {
|
||||||
state.states.set(xdg_toplevel::State::Resizing);
|
state.states.set(xdg_toplevel::State::Resizing);
|
||||||
|
@ -210,7 +210,7 @@ impl PointerGrab<State> for ResizeSurfaceGrab {
|
||||||
|
|
||||||
match &self.window {
|
match &self.window {
|
||||||
WindowElement::Wayland(window) => {
|
WindowElement::Wayland(window) => {
|
||||||
let toplevel_surface = window.toplevel();
|
let toplevel_surface = window.toplevel().expect("in wayland enum");
|
||||||
toplevel_surface.with_pending_state(|state| {
|
toplevel_surface.with_pending_state(|state| {
|
||||||
state.states.unset(xdg_toplevel::State::Resizing);
|
state.states.unset(xdg_toplevel::State::Resizing);
|
||||||
state.size = Some(self.last_window_size);
|
state.size = Some(self.last_window_size);
|
||||||
|
@ -459,11 +459,17 @@ pub fn resize_request_client(
|
||||||
let initial_window_size = window.geometry().size;
|
let initial_window_size = window.geometry().size;
|
||||||
|
|
||||||
if let Some(WindowElement::Wayland(window)) = state.window_for_surface(surface) {
|
if let Some(WindowElement::Wayland(window)) = state.window_for_surface(surface) {
|
||||||
window.toplevel().with_pending_state(|state| {
|
window
|
||||||
|
.toplevel()
|
||||||
|
.expect("in wayland enum")
|
||||||
|
.with_pending_state(|state| {
|
||||||
state.states.set(xdg_toplevel::State::Resizing);
|
state.states.set(xdg_toplevel::State::Resizing);
|
||||||
});
|
});
|
||||||
|
|
||||||
window.toplevel().send_pending_configure();
|
window
|
||||||
|
.toplevel()
|
||||||
|
.expect("in wayland enum")
|
||||||
|
.send_pending_configure();
|
||||||
}
|
}
|
||||||
|
|
||||||
let grab = ResizeSurfaceGrab::start(
|
let grab = ResizeSurfaceGrab::start(
|
||||||
|
@ -507,11 +513,17 @@ pub fn resize_request_server(
|
||||||
let initial_window_size = window.geometry().size;
|
let initial_window_size = window.geometry().size;
|
||||||
|
|
||||||
if let Some(WindowElement::Wayland(window)) = state.window_for_surface(surface) {
|
if let Some(WindowElement::Wayland(window)) = state.window_for_surface(surface) {
|
||||||
window.toplevel().with_pending_state(|state| {
|
window
|
||||||
|
.toplevel()
|
||||||
|
.expect("in wayland enum")
|
||||||
|
.with_pending_state(|state| {
|
||||||
state.states.set(xdg_toplevel::State::Resizing);
|
state.states.set(xdg_toplevel::State::Resizing);
|
||||||
});
|
});
|
||||||
|
|
||||||
window.toplevel().send_pending_configure();
|
window
|
||||||
|
.toplevel()
|
||||||
|
.expect("in wayland enum")
|
||||||
|
.send_pending_configure();
|
||||||
}
|
}
|
||||||
|
|
||||||
let start_data = smithay::input::pointer::GrabStartData {
|
let start_data = smithay::input::pointer::GrabStartData {
|
||||||
|
|
|
@ -194,7 +194,7 @@ impl CompositorHandler for State {
|
||||||
|
|
||||||
if !initial_configure_sent {
|
if !initial_configure_sent {
|
||||||
tracing::debug!("Initial configure");
|
tracing::debug!("Initial configure");
|
||||||
window.toplevel().send_configure();
|
window.toplevel().expect("in wayland enum").send_configure();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -280,7 +280,7 @@ fn ensure_initial_configure(surface: &WlSurface, state: &mut State) {
|
||||||
|
|
||||||
if !initial_configure_sent {
|
if !initial_configure_sent {
|
||||||
tracing::debug!("Initial configure");
|
tracing::debug!("Initial configure");
|
||||||
window.toplevel().send_configure();
|
window.toplevel().expect("in wayland enum").send_configure();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
|
@ -406,6 +406,7 @@ delegate_data_control!(State);
|
||||||
impl SeatHandler for State {
|
impl SeatHandler for State {
|
||||||
type KeyboardFocus = FocusTarget;
|
type KeyboardFocus = FocusTarget;
|
||||||
type PointerFocus = FocusTarget;
|
type PointerFocus = FocusTarget;
|
||||||
|
type TouchFocus = FocusTarget;
|
||||||
|
|
||||||
fn seat_state(&mut self) -> &mut SeatState<Self> {
|
fn seat_state(&mut self) -> &mut SeatState<Self> {
|
||||||
&mut self.seat_state
|
&mut self.seat_state
|
||||||
|
|
|
@ -41,7 +41,7 @@ impl XdgShellHandler for State {
|
||||||
state.states.set(xdg_toplevel::State::TiledRight);
|
state.states.set(xdg_toplevel::State::TiledRight);
|
||||||
});
|
});
|
||||||
|
|
||||||
let window = WindowElement::Wayland(Window::new(surface.clone()));
|
let window = WindowElement::Wayland(Window::new_wayland_window(surface.clone()));
|
||||||
self.new_windows.push(window);
|
self.new_windows.push(window);
|
||||||
|
|
||||||
// if let (Some(output), _) | (None, Some(output)) = (
|
// if let (Some(output), _) | (None, Some(output)) = (
|
||||||
|
@ -139,7 +139,7 @@ impl XdgShellHandler for State {
|
||||||
self.space.raise_element(win, true);
|
self.space.raise_element(win, true);
|
||||||
self.z_index_stack.set_focus(win.clone());
|
self.z_index_stack.set_focus(win.clone());
|
||||||
if let WindowElement::Wayland(win) = &win {
|
if let WindowElement::Wayland(win) = &win {
|
||||||
win.toplevel().send_configure();
|
win.toplevel().expect("in wayland enum").send_configure();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
self.seat
|
self.seat
|
||||||
|
|
|
@ -179,7 +179,7 @@ impl XwmHandler for State {
|
||||||
self.space.raise_element(win, true);
|
self.space.raise_element(win, true);
|
||||||
self.z_index_stack.set_focus(win.clone());
|
self.z_index_stack.set_focus(win.clone());
|
||||||
if let WindowElement::Wayland(win) = &win {
|
if let WindowElement::Wayland(win) = &win {
|
||||||
win.toplevel().send_configure();
|
win.toplevel().expect("in wayland enum").send_configure();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -242,7 +242,7 @@ impl XwmHandler for State {
|
||||||
self.space.raise_element(win, true);
|
self.space.raise_element(win, true);
|
||||||
self.z_index_stack.set_focus(win.clone());
|
self.z_index_stack.set_focus(win.clone());
|
||||||
if let WindowElement::Wayland(win) = &win {
|
if let WindowElement::Wayland(win) = &win {
|
||||||
win.toplevel().send_configure();
|
win.toplevel().expect("in wayland enum").send_configure();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -358,7 +358,7 @@ impl State {
|
||||||
|
|
||||||
for window in self.space.elements() {
|
for window in self.space.elements() {
|
||||||
if let WindowElement::Wayland(window) = window {
|
if let WindowElement::Wayland(window) = window {
|
||||||
window.toplevel().send_configure();
|
window.toplevel().expect("in wayland enum").send_configure();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -368,7 +368,7 @@ impl State {
|
||||||
for window in state.focus_stack.stack.iter() {
|
for window in state.focus_stack.stack.iter() {
|
||||||
window.set_activate(false);
|
window.set_activate(false);
|
||||||
if let WindowElement::Wayland(window) = window {
|
if let WindowElement::Wayland(window) = window {
|
||||||
window.toplevel().send_configure();
|
window.toplevel().expect("in wayland enum").send_configure();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -117,8 +117,9 @@ impl State {
|
||||||
if win.with_state(|state| state.target_loc.is_some()) {
|
if win.with_state(|state| state.target_loc.is_some()) {
|
||||||
match win {
|
match win {
|
||||||
WindowElement::Wayland(wl_win) => {
|
WindowElement::Wayland(wl_win) => {
|
||||||
let pending =
|
let pending = compositor::with_states(
|
||||||
compositor::with_states(wl_win.toplevel().wl_surface(), |states| {
|
wl_win.toplevel().expect("in wayland enum").wl_surface(),
|
||||||
|
|states| {
|
||||||
states
|
states
|
||||||
.data_map
|
.data_map
|
||||||
.get::<XdgToplevelSurfaceData>()
|
.get::<XdgToplevelSurfaceData>()
|
||||||
|
@ -126,10 +127,14 @@ impl State {
|
||||||
.lock()
|
.lock()
|
||||||
.expect("Failed to lock Mutex<XdgToplevelSurfaceData>")
|
.expect("Failed to lock Mutex<XdgToplevelSurfaceData>")
|
||||||
.has_pending_changes()
|
.has_pending_changes()
|
||||||
});
|
},
|
||||||
|
);
|
||||||
|
|
||||||
if pending {
|
if pending {
|
||||||
pending_wins.push((win.clone(), wl_win.toplevel().send_configure()))
|
pending_wins.push((
|
||||||
|
win.clone(),
|
||||||
|
wl_win.toplevel().expect("in wayland enum").send_configure(),
|
||||||
|
))
|
||||||
} else {
|
} else {
|
||||||
let loc = win.with_state(|state| state.target_loc.take());
|
let loc = win.with_state(|state| state.target_loc.take());
|
||||||
if let Some(loc) = loc {
|
if let Some(loc) = loc {
|
||||||
|
|
|
@ -310,6 +310,7 @@ where
|
||||||
if let WindowElement::Wayland(window) = win {
|
if let WindowElement::Wayland(window) = win {
|
||||||
window
|
window
|
||||||
.toplevel()
|
.toplevel()
|
||||||
|
.expect("in wayland enum")
|
||||||
.current_state()
|
.current_state()
|
||||||
.states
|
.states
|
||||||
.contains(xdg_toplevel::State::Fullscreen)
|
.contains(xdg_toplevel::State::Fullscreen)
|
||||||
|
|
104
src/window.rs
104
src/window.rs
|
@ -193,7 +193,10 @@ impl WindowElement {
|
||||||
pub fn change_geometry(&self, new_geo: Rectangle<i32, Logical>) {
|
pub fn change_geometry(&self, new_geo: Rectangle<i32, Logical>) {
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => {
|
WindowElement::Wayland(window) => {
|
||||||
window.toplevel().with_pending_state(|state| {
|
window
|
||||||
|
.toplevel()
|
||||||
|
.expect("in wayland enum")
|
||||||
|
.with_pending_state(|state| {
|
||||||
state.size = Some(new_geo.size);
|
state.size = Some(new_geo.size);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -217,8 +220,9 @@ impl WindowElement {
|
||||||
|
|
||||||
pub fn class(&self) -> Option<String> {
|
pub fn class(&self) -> Option<String> {
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => {
|
WindowElement::Wayland(window) => compositor::with_states(
|
||||||
compositor::with_states(window.toplevel().wl_surface(), |states| {
|
window.toplevel().expect("in wayland enum").wl_surface(),
|
||||||
|
|states| {
|
||||||
states
|
states
|
||||||
.data_map
|
.data_map
|
||||||
.get::<XdgToplevelSurfaceData>()
|
.get::<XdgToplevelSurfaceData>()
|
||||||
|
@ -227,8 +231,8 @@ impl WindowElement {
|
||||||
.expect("Failed to lock Mutex<XdgToplevelSurfaceData>")
|
.expect("Failed to lock Mutex<XdgToplevelSurfaceData>")
|
||||||
.app_id
|
.app_id
|
||||||
.clone()
|
.clone()
|
||||||
})
|
},
|
||||||
}
|
),
|
||||||
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
||||||
Some(surface.class())
|
Some(surface.class())
|
||||||
}
|
}
|
||||||
|
@ -238,8 +242,9 @@ impl WindowElement {
|
||||||
|
|
||||||
pub fn title(&self) -> Option<String> {
|
pub fn title(&self) -> Option<String> {
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => {
|
WindowElement::Wayland(window) => compositor::with_states(
|
||||||
compositor::with_states(window.toplevel().wl_surface(), |states| {
|
window.toplevel().expect("in wayland enum").wl_surface(),
|
||||||
|
|states| {
|
||||||
states
|
states
|
||||||
.data_map
|
.data_map
|
||||||
.get::<XdgToplevelSurfaceData>()
|
.get::<XdgToplevelSurfaceData>()
|
||||||
|
@ -248,8 +253,8 @@ impl WindowElement {
|
||||||
.expect("Failed to lock Mutex<XdgToplevelSurfaceData>")
|
.expect("Failed to lock Mutex<XdgToplevelSurfaceData>")
|
||||||
.title
|
.title
|
||||||
.clone()
|
.clone()
|
||||||
})
|
},
|
||||||
}
|
),
|
||||||
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
||||||
Some(surface.title())
|
Some(surface.title())
|
||||||
}
|
}
|
||||||
|
@ -335,7 +340,10 @@ impl WindowElement {
|
||||||
impl PointerTarget<State> for WindowElement {
|
impl PointerTarget<State> for WindowElement {
|
||||||
fn frame(&self, seat: &Seat<State>, state: &mut State) {
|
fn frame(&self, seat: &Seat<State>, state: &mut State) {
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => window.frame(seat, state),
|
WindowElement::Wayland(window) => window
|
||||||
|
.wl_surface()
|
||||||
|
.expect("in wayland enum")
|
||||||
|
.frame(seat, state),
|
||||||
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
||||||
surface.frame(seat, state)
|
surface.frame(seat, state)
|
||||||
}
|
}
|
||||||
|
@ -346,7 +354,12 @@ impl PointerTarget<State> for WindowElement {
|
||||||
fn enter(&self, seat: &Seat<State>, state: &mut State, event: &MotionEvent) {
|
fn enter(&self, seat: &Seat<State>, state: &mut State, event: &MotionEvent) {
|
||||||
// TODO: ssd
|
// TODO: ssd
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => PointerTarget::enter(window, seat, state, event),
|
WindowElement::Wayland(window) => PointerTarget::enter(
|
||||||
|
&window.wl_surface().expect("in wayland enum"),
|
||||||
|
seat,
|
||||||
|
state,
|
||||||
|
event,
|
||||||
|
),
|
||||||
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
||||||
PointerTarget::enter(surface, seat, state, event)
|
PointerTarget::enter(surface, seat, state, event)
|
||||||
}
|
}
|
||||||
|
@ -364,7 +377,12 @@ impl PointerTarget<State> for WindowElement {
|
||||||
fn motion(&self, seat: &Seat<State>, state: &mut State, event: &MotionEvent) {
|
fn motion(&self, seat: &Seat<State>, state: &mut State, event: &MotionEvent) {
|
||||||
// TODO: ssd
|
// TODO: ssd
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => PointerTarget::motion(window, seat, state, event),
|
WindowElement::Wayland(window) => PointerTarget::motion(
|
||||||
|
&window.wl_surface().expect("in wayland enum"),
|
||||||
|
seat,
|
||||||
|
state,
|
||||||
|
event,
|
||||||
|
),
|
||||||
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
||||||
PointerTarget::motion(surface, seat, state, event)
|
PointerTarget::motion(surface, seat, state, event)
|
||||||
}
|
}
|
||||||
|
@ -381,7 +399,12 @@ impl PointerTarget<State> for WindowElement {
|
||||||
// TODO: ssd
|
// TODO: ssd
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => {
|
WindowElement::Wayland(window) => {
|
||||||
PointerTarget::relative_motion(window, seat, state, event);
|
PointerTarget::relative_motion(
|
||||||
|
&window.wl_surface().expect("in wayland enum"),
|
||||||
|
seat,
|
||||||
|
state,
|
||||||
|
event,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
||||||
PointerTarget::relative_motion(surface, seat, state, event);
|
PointerTarget::relative_motion(surface, seat, state, event);
|
||||||
|
@ -398,7 +421,12 @@ impl PointerTarget<State> for WindowElement {
|
||||||
) {
|
) {
|
||||||
// TODO: ssd
|
// TODO: ssd
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => PointerTarget::button(window, seat, state, event),
|
WindowElement::Wayland(window) => PointerTarget::button(
|
||||||
|
&window.wl_surface().expect("in wayland enum"),
|
||||||
|
seat,
|
||||||
|
state,
|
||||||
|
event,
|
||||||
|
),
|
||||||
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
||||||
PointerTarget::button(surface, seat, state, event)
|
PointerTarget::button(surface, seat, state, event)
|
||||||
}
|
}
|
||||||
|
@ -409,7 +437,12 @@ impl PointerTarget<State> for WindowElement {
|
||||||
fn axis(&self, seat: &Seat<State>, state: &mut State, frame: AxisFrame) {
|
fn axis(&self, seat: &Seat<State>, state: &mut State, frame: AxisFrame) {
|
||||||
// TODO: ssd
|
// TODO: ssd
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => PointerTarget::axis(window, seat, state, frame),
|
WindowElement::Wayland(window) => PointerTarget::axis(
|
||||||
|
&window.wl_surface().expect("in wayland enum"),
|
||||||
|
seat,
|
||||||
|
state,
|
||||||
|
frame,
|
||||||
|
),
|
||||||
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
||||||
PointerTarget::axis(surface, seat, state, frame)
|
PointerTarget::axis(surface, seat, state, frame)
|
||||||
}
|
}
|
||||||
|
@ -421,7 +454,13 @@ impl PointerTarget<State> for WindowElement {
|
||||||
// TODO: ssd
|
// TODO: ssd
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => {
|
WindowElement::Wayland(window) => {
|
||||||
PointerTarget::leave(window, seat, state, serial, time);
|
PointerTarget::leave(
|
||||||
|
&window.wl_surface().expect("in wayland enum"),
|
||||||
|
seat,
|
||||||
|
state,
|
||||||
|
serial,
|
||||||
|
time,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
||||||
PointerTarget::leave(surface, seat, state, serial, time)
|
PointerTarget::leave(surface, seat, state, serial, time)
|
||||||
|
@ -520,7 +559,13 @@ impl KeyboardTarget<State> for WindowElement {
|
||||||
) {
|
) {
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => {
|
WindowElement::Wayland(window) => {
|
||||||
KeyboardTarget::enter(window, seat, state, keys, serial);
|
KeyboardTarget::enter(
|
||||||
|
&window.wl_surface().expect("in wayland enum"),
|
||||||
|
seat,
|
||||||
|
state,
|
||||||
|
keys,
|
||||||
|
serial,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
||||||
KeyboardTarget::enter(surface, seat, state, keys, serial)
|
KeyboardTarget::enter(surface, seat, state, keys, serial)
|
||||||
|
@ -531,7 +576,12 @@ impl KeyboardTarget<State> for WindowElement {
|
||||||
|
|
||||||
fn leave(&self, seat: &Seat<State>, state: &mut State, serial: Serial) {
|
fn leave(&self, seat: &Seat<State>, state: &mut State, serial: Serial) {
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => KeyboardTarget::leave(window, seat, state, serial),
|
WindowElement::Wayland(window) => KeyboardTarget::leave(
|
||||||
|
&window.wl_surface().expect("in wayland enum"),
|
||||||
|
seat,
|
||||||
|
state,
|
||||||
|
serial,
|
||||||
|
),
|
||||||
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
||||||
KeyboardTarget::leave(surface, seat, state, serial)
|
KeyboardTarget::leave(surface, seat, state, serial)
|
||||||
}
|
}
|
||||||
|
@ -550,7 +600,15 @@ impl KeyboardTarget<State> for WindowElement {
|
||||||
) {
|
) {
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => {
|
WindowElement::Wayland(window) => {
|
||||||
KeyboardTarget::key(window, seat, state, key, key_state, serial, time);
|
KeyboardTarget::key(
|
||||||
|
&window.wl_surface().expect("in wayland enum"),
|
||||||
|
seat,
|
||||||
|
state,
|
||||||
|
key,
|
||||||
|
key_state,
|
||||||
|
serial,
|
||||||
|
time,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
||||||
KeyboardTarget::key(surface, seat, state, key, key_state, serial, time);
|
KeyboardTarget::key(surface, seat, state, key, key_state, serial, time);
|
||||||
|
@ -568,7 +626,13 @@ impl KeyboardTarget<State> for WindowElement {
|
||||||
) {
|
) {
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => {
|
WindowElement::Wayland(window) => {
|
||||||
KeyboardTarget::modifiers(window, seat, state, modifiers, serial);
|
KeyboardTarget::modifiers(
|
||||||
|
&window.wl_surface().expect("in wayland enum"),
|
||||||
|
seat,
|
||||||
|
state,
|
||||||
|
modifiers,
|
||||||
|
serial,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
WindowElement::X11(surface) | WindowElement::X11OverrideRedirect(surface) => {
|
||||||
KeyboardTarget::modifiers(surface, seat, state, modifiers, serial);
|
KeyboardTarget::modifiers(surface, seat, state, modifiers, serial);
|
||||||
|
|
|
@ -83,7 +83,10 @@ impl WindowElement {
|
||||||
|
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => {
|
WindowElement::Wayland(window) => {
|
||||||
window.toplevel().with_pending_state(|state| {
|
window
|
||||||
|
.toplevel()
|
||||||
|
.expect("in wayland enum")
|
||||||
|
.with_pending_state(|state| {
|
||||||
state.states.unset(xdg_toplevel::State::Maximized);
|
state.states.unset(xdg_toplevel::State::Maximized);
|
||||||
state.states.set(xdg_toplevel::State::Fullscreen);
|
state.states.set(xdg_toplevel::State::Fullscreen);
|
||||||
state.states.set(xdg_toplevel::State::TiledTop);
|
state.states.set(xdg_toplevel::State::TiledTop);
|
||||||
|
@ -130,7 +133,10 @@ impl WindowElement {
|
||||||
|
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => {
|
WindowElement::Wayland(window) => {
|
||||||
window.toplevel().with_pending_state(|state| {
|
window
|
||||||
|
.toplevel()
|
||||||
|
.expect("in wayland enum")
|
||||||
|
.with_pending_state(|state| {
|
||||||
state.states.set(xdg_toplevel::State::Maximized);
|
state.states.set(xdg_toplevel::State::Maximized);
|
||||||
state.states.unset(xdg_toplevel::State::Fullscreen);
|
state.states.unset(xdg_toplevel::State::Fullscreen);
|
||||||
state.states.set(xdg_toplevel::State::TiledTop);
|
state.states.set(xdg_toplevel::State::TiledTop);
|
||||||
|
@ -172,7 +178,10 @@ impl WindowElement {
|
||||||
fn set_floating_states(&self) {
|
fn set_floating_states(&self) {
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => {
|
WindowElement::Wayland(window) => {
|
||||||
window.toplevel().with_pending_state(|state| {
|
window
|
||||||
|
.toplevel()
|
||||||
|
.expect("in wayland enum")
|
||||||
|
.with_pending_state(|state| {
|
||||||
state.states.unset(xdg_toplevel::State::Maximized);
|
state.states.unset(xdg_toplevel::State::Maximized);
|
||||||
state.states.unset(xdg_toplevel::State::Fullscreen);
|
state.states.unset(xdg_toplevel::State::Fullscreen);
|
||||||
state.states.unset(xdg_toplevel::State::TiledTop);
|
state.states.unset(xdg_toplevel::State::TiledTop);
|
||||||
|
@ -199,7 +208,10 @@ impl WindowElement {
|
||||||
fn set_tiled_states(&self) {
|
fn set_tiled_states(&self) {
|
||||||
match self {
|
match self {
|
||||||
WindowElement::Wayland(window) => {
|
WindowElement::Wayland(window) => {
|
||||||
window.toplevel().with_pending_state(|state| {
|
window
|
||||||
|
.toplevel()
|
||||||
|
.expect("in wayland enum")
|
||||||
|
.with_pending_state(|state| {
|
||||||
state.states.unset(xdg_toplevel::State::Maximized);
|
state.states.unset(xdg_toplevel::State::Maximized);
|
||||||
state.states.unset(xdg_toplevel::State::Fullscreen);
|
state.states.unset(xdg_toplevel::State::Fullscreen);
|
||||||
state.states.set(xdg_toplevel::State::TiledTop);
|
state.states.set(xdg_toplevel::State::TiledTop);
|
||||||
|
|
Loading…
Reference in a new issue