From 69e9cc4cbdcb241f66519ca64eb745090e11b553 Mon Sep 17 00:00:00 2001 From: Emmanuel Lepage Vallee Date: Sat, 28 Jul 2018 14:30:43 -0400 Subject: [PATCH 1/4] request::activate: Unminimize clients Fixes #927 --- lib/awful/ewmh.lua | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/lib/awful/ewmh.lua b/lib/awful/ewmh.lua index 4657a372f..9e29b9040 100644 --- a/lib/awful/ewmh.lua +++ b/lib/awful/ewmh.lua @@ -98,6 +98,12 @@ function ewmh.activate(c, context, hints) -- luacheck: no unused args if found then break end end + -- Minimized clients can be requested to have focus by, for example, 3rd + -- party toolbars and they might not try to unminimize it first. + if ret ~= false and hints.raise then + c.minimized = false + end + if ret ~= false and c:isvisible() then client.focus = c elseif ret == false and not hints.force then From 26e4856821da72a2213ceb65610983fbd7ea1295 Mon Sep 17 00:00:00 2001 From: Emmanuel Lepage Vallee Date: Sun, 29 Jul 2018 17:52:28 -0400 Subject: [PATCH 2/4] activate: Raise unfocusable clients. I am sure there is corner cases where this is considered wrong, but it allows to simplify rc.lua handling of such clients. --- lib/awful/ewmh.lua | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/lib/awful/ewmh.lua b/lib/awful/ewmh.lua index 9e29b9040..8e8397ab8 100644 --- a/lib/awful/ewmh.lua +++ b/lib/awful/ewmh.lua @@ -81,7 +81,13 @@ end function ewmh.activate(c, context, hints) -- luacheck: no unused args hints = hints or {} - if c.focusable == false and not hints.force then return end + if c.focusable == false and not hints.force then + if hints.raise then + c:raise() + end + + return + end local found, ret = false From 091adca070b078755268ed651a2b3c1476c82432 Mon Sep 17 00:00:00 2001 From: Emmanuel Lepage Vallee Date: Sun, 29 Jul 2018 18:04:12 -0400 Subject: [PATCH 3/4] activate: Merge the old hardcoded focus filter with awful.ewmh one. This code was attached to mouse::enter in `rc.lua` instead of being part of the unified request::activate architecture. There is currently no way to detach this focus filter because it is generally correct. --- lib/awful/ewmh.lua | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/lib/awful/ewmh.lua b/lib/awful/ewmh.lua index 8e8397ab8..230f57ce6 100644 --- a/lib/awful/ewmh.lua +++ b/lib/awful/ewmh.lua @@ -15,6 +15,7 @@ local aclient = require("awful.client") local aplace = require("awful.placement") local asuit = require("awful.layout.suit") local beautiful = require("beautiful") +local alayout = require("awful.layout") local ewmh = { generic_activate_filters = {}, @@ -400,6 +401,15 @@ function ewmh.client_geometry_requests(c, context, hints) end end +-- The magnifier layout doesn't work with focus follow mouse. +ewmh.add_activate_filter(function(c) + if alayout.get(c.screen) ~= alayout.suit.magnifier + and aclient.focus.filter(c) then + return nil + else + return false + end +end, "mouse_enter") client.connect_signal("request::activate", ewmh.activate) client.connect_signal("request::tag", ewmh.tag) From e0d1b404c596ac46674243d9a34ac07c7fb0daf5 Mon Sep 17 00:00:00 2001 From: Emmanuel Lepage Vallee Date: Sat, 28 Jul 2018 14:34:29 -0400 Subject: [PATCH 4/4] rc.lua: Use request::activate instead of client.focus. For a long time, it was deemed overkill and made rc.lua less readable without the documentation. However it is now clear that it's handling of unfocusable clients and general bypassing of both `awful.client.focus.filter` and `awful.ewmh.activate` filters causes bugs. Fixing them individually in each instance of `rc.lua` `client.focus = c` would add so much code that all the clarity provided by not using request::activate would be burried in boilerplate code. Fix #2328 --- awesomerc.lua | 40 ++++++++++++++-------------------------- 1 file changed, 14 insertions(+), 26 deletions(-) diff --git a/awesomerc.lua b/awesomerc.lua index 867148fed..3d5d73d64 100644 --- a/awesomerc.lua +++ b/awesomerc.lua @@ -155,16 +155,11 @@ local tasklist_buttons = gears.table.join( if c == client.focus then c.minimized = true else - -- Without this, the following - -- :isvisible() makes no sense - c.minimized = false - if not c:isvisible() and c.first_tag then - c.first_tag:view_only() - end - -- This will also un-minimize - -- the client, if needed - client.focus = c - c:raise() + c:emit_signal( + "request::activate", + "tasklist", + {raise = true} + ) end end), awful.button({ }, 3, client_menu_toggle_fn()), @@ -335,8 +330,9 @@ globalkeys = gears.table.join( local c = awful.client.restore() -- Focus restored client if c then - client.focus = c - c:raise() + c:emit_signal( + "request::activate", "key.unminimize", {raise = true} + ) end end, {description = "restore minimized", group = "client"}), @@ -459,17 +455,14 @@ end -- @DOC_CLIENT_BUTTONS@ clientbuttons = gears.table.join( awful.button({ }, 1, function (c) - client.focus = c; - c:raise() + c:emit_signal("request::activate", "mouse_click", {raise = true}) end), awful.button({ modkey }, 1, function (c) - client.focus = c - c:raise() + c:emit_signal("request::activate", "mouse_click", {raise = true}) awful.mouse.client.move(c) end), awful.button({ modkey }, 3, function (c) - client.focus = c - c:raise() + c:emit_signal("request::activate", "mouse_click", {raise = true}) awful.mouse.client.resize(c) end) ) @@ -559,13 +552,11 @@ client.connect_signal("request::titlebars", function(c) -- buttons for the titlebar local buttons = gears.table.join( awful.button({ }, 1, function() - client.focus = c - c:raise() + c:emit_signal("request::activate", "titlebar", {raise = true}) awful.mouse.client.move(c) end), awful.button({ }, 3, function() - client.focus = c - c:raise() + c:emit_signal("request::activate", "titlebar", {raise = true}) awful.mouse.client.resize(c) end) ) @@ -598,10 +589,7 @@ end) -- Enable sloppy focus, so that focus follows mouse. client.connect_signal("mouse::enter", function(c) - if awful.layout.get(c.screen) ~= awful.layout.suit.magnifier - and awful.client.focus.filter(c) then - client.focus = c - end + c:emit_signal("request::activate", "mouse_enter", {raise = true}) end) -- @DOC_BORDER@