Make Decoration a toplevel struct
This commit is contained in:
parent
fb766fe09c
commit
d20d01e596
2 changed files with 25 additions and 26 deletions
|
@ -1,37 +1,36 @@
|
||||||
|
const Self = @This();
|
||||||
|
|
||||||
const std = @import("std");
|
const std = @import("std");
|
||||||
|
|
||||||
const c = @import("c.zig");
|
const c = @import("c.zig");
|
||||||
|
|
||||||
const DecorationManager = @import("decoration_manager.zig");
|
const DecorationManager = @import("decoration_manager.zig");
|
||||||
|
|
||||||
// TODO: this needs to listen for destroy and free nodes from the deco list
|
// TODO: this needs to listen for destroy and free nodes from the deco list
|
||||||
pub const Decoration = struct {
|
decoration_manager: *DecorationManager,
|
||||||
const Self = @This();
|
wlr_xdg_toplevel_decoration: *c.wlr_xdg_toplevel_decoration_v1,
|
||||||
|
|
||||||
|
listen_request_mode: c.wl_listener,
|
||||||
|
|
||||||
|
pub fn init(
|
||||||
|
self: *Self,
|
||||||
decoration_manager: *DecorationManager,
|
decoration_manager: *DecorationManager,
|
||||||
wlr_xdg_toplevel_decoration: *c.wlr_xdg_toplevel_decoration_v1,
|
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;
|
||||||
|
|
||||||
listen_request_mode: c.wl_listener,
|
self.listen_request_mode.notify = handleRequestMode;
|
||||||
|
c.wl_signal_add(&self.wlr_xdg_toplevel_decoration.events.request_mode, &self.listen_request_mode);
|
||||||
|
|
||||||
pub fn init(
|
handleRequestMode(&self.listen_request_mode, self.wlr_xdg_toplevel_decoration);
|
||||||
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;
|
fn handleRequestMode(listener: ?*c.wl_listener, data: ?*c_void) callconv(.C) void {
|
||||||
c.wl_signal_add(&self.wlr_xdg_toplevel_decoration.events.request_mode, &self.listen_request_mode);
|
const self = @fieldParentPtr(Self, "listen_request_mode", listener.?);
|
||||||
|
// TODO: we might need to take this configure serial and do a transaction
|
||||||
handleRequestMode(&self.listen_request_mode, self.wlr_xdg_toplevel_decoration);
|
_ = 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,
|
||||||
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,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
|
@ -4,7 +4,7 @@ const std = @import("std");
|
||||||
|
|
||||||
const c = @import("c.zig");
|
const c = @import("c.zig");
|
||||||
|
|
||||||
const Decoration = @import("decoration.zig").Decoration;
|
const Decoration = @import("decoration.zig");
|
||||||
const Server = @import("server.zig");
|
const Server = @import("server.zig");
|
||||||
|
|
||||||
server: *Server,
|
server: *Server,
|
||||||
|
|
Loading…
Reference in a new issue