aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIsaac Freund <ifreund@ifreund.xyz>2020-11-29 21:05:27 +0100
committerIsaac Freund <ifreund@ifreund.xyz>2020-11-29 21:05:27 +0100
commit807d4a4212a2cc14203d63376895cc36072ff1a2 (patch)
tree876993728d68c6d925a343c6a07567bda807ddcc
parentf1e5f1aacb2d812e8bba72ff33e377c971845c17 (diff)
downloadriver-807d4a4212a2cc14203d63376895cc36072ff1a2.tar.gz
river-807d4a4212a2cc14203d63376895cc36072ff1a2.tar.xz
keyboard: handle destruction
m---------deps/zig-wayland0
-rw-r--r--river/Keyboard.zig17
-rw-r--r--river/Seat.zig5
3 files changed, 21 insertions, 1 deletions
diff --git a/deps/zig-wayland b/deps/zig-wayland
-Subproject 181f9344b23504080be5cec676e4c4adebcd1f9
+Subproject ba49b2b6f984b788aea5e752bfeb64e3381472e
diff --git a/river/Keyboard.zig b/river/Keyboard.zig
index 06bdf90..9fe876d 100644
--- a/river/Keyboard.zig
+++ b/river/Keyboard.zig
@@ -31,6 +31,7 @@ wlr_keyboard: *c.wlr_keyboard,
listen_key: c.wl_listener = undefined,
listen_modifiers: c.wl_listener = undefined,
+listen_destroy: c.wl_listener = undefined,
pub fn init(self: *Self, seat: *Seat, wlr_input_device: *c.wlr_input_device) !void {
self.* = .{
@@ -67,6 +68,15 @@ pub fn init(self: *Self, seat: *Seat, wlr_input_device: *c.wlr_input_device) !vo
self.listen_modifiers.notify = handleModifiers;
c.wl_signal_add(&self.wlr_keyboard.events.modifiers, &self.listen_modifiers);
+
+ self.listen_destroy.notify = handleDestroy;
+ c.wl_signal_add(&self.wlr_keyboard.events.destroy, &self.listen_destroy);
+}
+
+pub fn deinit(self: *Self) void {
+ c.wl_list_remove(&self.listen_key.link);
+ c.wl_list_remove(&self.listen_modifiers.link);
+ c.wl_list_remove(&self.listen_destroy.link);
}
fn handleKey(listener: ?*c.wl_listener, data: ?*c_void) callconv(.C) void {
@@ -157,6 +167,13 @@ fn handleModifiers(listener: ?*c.wl_listener, data: ?*c_void) callconv(.C) void
// Send modifiers to the client.
c.wlr_seat_keyboard_notify_modifiers(self.seat.wlr_seat, &self.wlr_keyboard.modifiers);
}
+fn handleDestroy(listener: ?*c.wl_listener, data: ?*c_void) callconv(.C) void {
+ const self = @fieldParentPtr(Self, "listen_destroy", listener.?);
+ self.deinit();
+ const node = @fieldParentPtr(std.TailQueue(Self).Node, "data", self);
+ self.seat.keyboards.remove(node);
+ util.gpa.destroy(node);
+}
/// Handle any builtin, harcoded compsitor mappings such as VT switching.
/// Returns true if the keysym was handled.
diff --git a/river/Seat.zig b/river/Seat.zig
index 198cd7c..eaed5fc 100644
--- a/river/Seat.zig
+++ b/river/Seat.zig
@@ -101,7 +101,10 @@ pub fn init(self: *Self, input_manager: *InputManager, name: [*:0]const u8) !voi
pub fn deinit(self: *Self) void {
self.cursor.deinit();
- while (self.keyboards.pop()) |node| util.gpa.destroy(node);
+ while (self.keyboards.pop()) |node| {
+ node.data.deinit();
+ util.gpa.destroy(node);
+ }
while (self.focus_stack.first) |node| {
self.focus_stack.remove(node);