diff options
| author | Isaac Freund <ifreund@ifreund.xyz> | 2020-05-02 16:25:04 +0200 |
|---|---|---|
| committer | Isaac Freund <ifreund@ifreund.xyz> | 2020-05-02 16:25:04 +0200 |
| commit | d20d01e596b82599865de0ad75b54002ee3f23ec (patch) | |
| tree | 11e761d7aafcb1a35da21360240678044b08b3a3 /src/decoration.zig | |
| parent | fb766fe09cebf9b487192099d6e7032481e77f89 (diff) | |
| download | river-d20d01e596b82599865de0ad75b54002ee3f23ec.tar.gz river-d20d01e596b82599865de0ad75b54002ee3f23ec.tar.xz | |
Make Decoration a toplevel struct
Diffstat (limited to 'src/decoration.zig')
| -rw-r--r-- | src/decoration.zig | 55 |
1 files changed, 27 insertions, 28 deletions
diff --git a/src/decoration.zig b/src/decoration.zig index aaf7129..a75929a 100644 --- a/src/decoration.zig +++ b/src/decoration.zig @@ -1,37 +1,36 @@ +const Self = @This(); + const std = @import("std"); + const c = @import("c.zig"); const DecorationManager = @import("decoration_manager.zig"); // TODO: this needs to listen for destroy and free nodes from the deco list -pub const Decoration = struct { - const Self = @This(); +decoration_manager: *DecorationManager, +wlr_xdg_toplevel_decoration: *c.wlr_xdg_toplevel_decoration_v1, +listen_request_mode: c.wl_listener, + +pub fn init( + self: *Self, decoration_manager: *DecorationManager, wlr_xdg_toplevel_decoration: *c.wlr_xdg_toplevel_decoration_v1, - - listen_request_mode: c.wl_listener, - - pub fn init( - self: *Self, - decoration_manager: *DecorationManager, - wlr_xdg_toplevel_decoration: *c.wlr_xdg_toplevel_decoration_v1, - ) void { - self.decoration_manager = decoration_manager; - self.wlr_xdg_toplevel_decoration = wlr_xdg_toplevel_decoration; - - self.listen_request_mode.notify = handleRequestMode; - c.wl_signal_add(&self.wlr_xdg_toplevel_decoration.events.request_mode, &self.listen_request_mode); - - handleRequestMode(&self.listen_request_mode, self.wlr_xdg_toplevel_decoration); - } - - fn handleRequestMode(listener: ?*c.wl_listener, data: ?*c_void) callconv(.C) void { - const self = @fieldParentPtr(Self, "listen_request_mode", listener.?); - // TODO: we might need to take this configure serial and do a transaction - _ = c.wlr_xdg_toplevel_decoration_v1_set_mode( - self.wlr_xdg_toplevel_decoration, - c.wlr_xdg_toplevel_decoration_v1_mode.WLR_XDG_TOPLEVEL_DECORATION_V1_MODE_SERVER_SIDE, - ); - } -}; +) void { + self.decoration_manager = decoration_manager; + self.wlr_xdg_toplevel_decoration = wlr_xdg_toplevel_decoration; + + self.listen_request_mode.notify = handleRequestMode; + c.wl_signal_add(&self.wlr_xdg_toplevel_decoration.events.request_mode, &self.listen_request_mode); + + handleRequestMode(&self.listen_request_mode, self.wlr_xdg_toplevel_decoration); +} + +fn handleRequestMode(listener: ?*c.wl_listener, data: ?*c_void) callconv(.C) void { + const self = @fieldParentPtr(Self, "listen_request_mode", listener.?); + // TODO: we might need to take this configure serial and do a transaction + _ = c.wlr_xdg_toplevel_decoration_v1_set_mode( + self.wlr_xdg_toplevel_decoration, + c.wlr_xdg_toplevel_decoration_v1_mode.WLR_XDG_TOPLEVEL_DECORATION_V1_MODE_SERVER_SIDE, + ); +} |
