diff options
| author | Ivan Molodetskikh <yalterz@gmail.com> | 2023-08-15 16:19:05 +0400 |
|---|---|---|
| committer | Ivan Molodetskikh <yalterz@gmail.com> | 2023-08-15 16:19:05 +0400 |
| commit | 2465bba0858662d45ea1e5a321c6fbe11036d99f (patch) | |
| tree | 98ffb9605df0fec87c2e966d845479bfc6970387 /src/handlers | |
| parent | b0d129951c122f36f5b85a405cbdc1d38ae0c421 (diff) | |
| download | niri-2465bba0858662d45ea1e5a321c6fbe11036d99f.tar.gz niri-2465bba0858662d45ea1e5a321c6fbe11036d99f.tar.bz2 niri-2465bba0858662d45ea1e5a321c6fbe11036d99f.zip | |
Add client cursor support
Diffstat (limited to 'src/handlers')
| -rw-r--r-- | src/handlers/mod.rs | 28 |
1 files changed, 8 insertions, 20 deletions
diff --git a/src/handlers/mod.rs b/src/handlers/mod.rs index fcde0585..cc80a841 100644 --- a/src/handlers/mod.rs +++ b/src/handlers/mod.rs @@ -2,13 +2,13 @@ mod compositor; mod layer_shell; mod xdg_shell; -// -// Wl Seat +use smithay::input::pointer::CursorImageStatus; use smithay::input::{Seat, SeatHandler, SeatState}; use smithay::reexports::wayland_server::protocol::wl_surface::WlSurface; use smithay::reexports::wayland_server::Resource; use smithay::wayland::data_device::{ - set_data_device_focus, ClientDndGrabHandler, DataDeviceHandler, ServerDndGrabHandler, + set_data_device_focus, ClientDndGrabHandler, DataDeviceHandler, DataDeviceState, + ServerDndGrabHandler, }; use smithay::{delegate_data_device, delegate_output, delegate_seat}; @@ -22,11 +22,10 @@ impl SeatHandler for Niri { &mut self.seat_state } - fn cursor_image( - &mut self, - _seat: &Seat<Self>, - _image: smithay::input::pointer::CursorImageStatus, - ) { + fn cursor_image(&mut self, _seat: &Seat<Self>, image: CursorImageStatus) { + self.cursor_image = image; + // FIXME: more granular + self.queue_redraw_all(); } fn focus_changed(&mut self, seat: &Seat<Self>, focused: Option<&WlSurface>) { @@ -35,27 +34,16 @@ impl SeatHandler for Niri { set_data_device_focus(dh, seat, client); } } - delegate_seat!(Niri); -// -// Wl Data Device -// - impl DataDeviceHandler for Niri { type SelectionUserData = (); - fn data_device_state(&self) -> &smithay::wayland::data_device::DataDeviceState { + fn data_device_state(&self) -> &DataDeviceState { &self.data_device_state } } - impl ClientDndGrabHandler for Niri {} impl ServerDndGrabHandler for Niri {} - delegate_data_device!(Niri); -// -// Wl Output & Xdg Output -// - delegate_output!(Niri); |
