aboutsummaryrefslogtreecommitdiff
path: root/src/handlers
diff options
context:
space:
mode:
authorIvan Molodetskikh <yalterz@gmail.com>2023-08-15 16:19:05 +0400
committerIvan Molodetskikh <yalterz@gmail.com>2023-08-15 16:19:05 +0400
commit2465bba0858662d45ea1e5a321c6fbe11036d99f (patch)
tree98ffb9605df0fec87c2e966d845479bfc6970387 /src/handlers
parentb0d129951c122f36f5b85a405cbdc1d38ae0c421 (diff)
downloadniri-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.rs28
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);