From 56400a5955603b8760a27f49ac4b33bcaa86b73c Mon Sep 17 00:00:00 2001 From: Isaac Freund Date: Thu, 23 Apr 2020 17:27:18 +0200 Subject: [PATCH] Fix crash on non-toplevel views --- src/keyboard.zig | 4 ++-- src/render.zig | 2 +- src/seat.zig | 4 ++-- src/view.zig | 34 +++++++++++++++++++++++----------- 4 files changed, 28 insertions(+), 16 deletions(-) diff --git a/src/keyboard.zig b/src/keyboard.zig index 4be0ccb..13aac76 100644 --- a/src/keyboard.zig +++ b/src/keyboard.zig @@ -17,7 +17,7 @@ pub const Keyboard = struct { pub fn init(self: *Self, seat: *Seat, device: *c.wlr_input_device) !void { self.seat = seat; self.device = device; - self.wlr_keyboard = device.unnamed_133.keyboard; + self.wlr_keyboard = device.unnamed_134.keyboard; // We need to prepare an XKB keymap and assign it to the keyboard. This // assumes the defaults (e.g. layout = "us"). @@ -60,7 +60,7 @@ pub const Keyboard = struct { @alignCast(@alignOf(*c.wlr_event_keyboard_key), data), ); - const wlr_keyboard: *c.wlr_keyboard = self.device.unnamed_133.keyboard; + const wlr_keyboard: *c.wlr_keyboard = self.device.unnamed_134.keyboard; // Translate libinput keycode -> xkbcommon const keycode = event.keycode + 8; diff --git a/src/render.zig b/src/render.zig index d8b46ec..218b10a 100644 --- a/src/render.zig +++ b/src/render.zig @@ -262,7 +262,7 @@ fn renderSurface(_surface: ?*c.wlr_surface, sx: c_int, sy: c_int, data: ?*c_void fn renderBorders(output: Output, view: *View, now: *c.timespec) void { var border: c.wlr_box = undefined; - const color = if (view.wlr_xdg_surface.unnamed_164.toplevel.*.current.activated) + const color = if (view.focused) [_]f32{ 0.57647059, 0.63137255, 0.63137255, 1.0 } // Solarized base1 else [_]f32{ 0.34509804, 0.43137255, 0.45882353, 1.0 }; // Solarized base01 diff --git a/src/seat.zig b/src/seat.zig index 9d13257..19d61fb 100644 --- a/src/seat.zig +++ b/src/seat.zig @@ -159,7 +159,7 @@ pub const Seat = struct { // First clear the current focus if (self.focused_view) |current_focus| { std.debug.assert(self.focused_layer == null); - current_focus.setActivated(false); + current_focus.setFocused(false); self.focused_view = null; } if (self.focused_layer) |current_focus| { @@ -172,7 +172,7 @@ pub const Seat = struct { switch (focus_target) { .view => |target_view| { std.debug.assert(self.focused_output == target_view.output); - target_view.setActivated(true); + target_view.setFocused(true); self.focused_view = target_view; }, .layer => |target_layer| blk: { diff --git a/src/view.zig b/src/view.zig index 8e84066..41c7824 100644 --- a/src/view.zig +++ b/src/view.zig @@ -18,6 +18,9 @@ pub const View = struct { /// If the view is floating or not floating: bool, + /// True if the view is currentlt focused by at lease one seat + focused: bool, + current_box: Box, pending_box: ?Box, @@ -52,6 +55,8 @@ pub const View = struct { self.mapped = false; + self.focused = false; + self.current_box = Box{ .x = 0, .y = 0, @@ -130,6 +135,16 @@ pub const View = struct { } } + /// Set the focued bool and the active state of the view if it is a toplevel + pub fn setFocused(self: *Self, focused: bool) void { + self.focused = focused; + if (self.wlr_xdg_surface.role == + c.enum_wlr_xdg_surface_role.WLR_XDG_SURFACE_ROLE_TOPLEVEL) + { + _ = c.wlr_xdg_toplevel_set_activated(self.wlr_xdg_surface, focused); + } + } + /// If true is passsed, make the view float. If false, return it to the tiled /// layout. pub fn setFloating(self: *Self, float: bool) void { @@ -197,14 +212,16 @@ pub const View = struct { self.natural_height = @intCast(u32, self.wlr_xdg_surface.surface.*.current.height); } - const app_id: [*:0]const u8 = self.wlr_xdg_surface.unnamed_164.toplevel.*.app_id; - Log.Debug.log("View with app_id '{}' mapped", .{app_id}); + const app_id: ?[*:0]const u8 = self.wlr_xdg_surface.unnamed_165.toplevel.*.app_id; + Log.Debug.log("View with app_id '{}' mapped", .{if (app_id) |id| id else "NULL"}); // Make views with app_ids listed in the float filter float - for (self.output.root.server.config.float_filter.items) |filter_app_id| { - if (std.mem.eql(u8, std.mem.span(app_id), std.mem.span(filter_app_id))) { - self.setFloating(true); - break; + if (app_id) |id| { + for (self.output.root.server.config.float_filter.items) |filter_app_id| { + if (std.mem.eql(u8, std.mem.span(id), std.mem.span(filter_app_id))) { + self.setFloating(true); + break; + } } } @@ -250,11 +267,6 @@ pub const View = struct { // TODO: check for unexpected change in size and react as needed } - /// Set the active state of the view to the passed bool - pub fn setActivated(self: Self, activated: bool) void { - _ = c.wlr_xdg_toplevel_set_activated(self.wlr_xdg_surface, activated); - } - fn isAt(self: Self, lx: f64, ly: f64, surface: *?*c.wlr_surface, sx: *f64, sy: *f64) bool { // XDG toplevels may have nested surfaces, such as popup windows for context // menus or tooltips. This function tests if any of those are underneath the