client: Extend request::tag instead of awful.tag.withcurrent

There was a regression when refactoring the API. It was no longer
possible to disable the automatic tag selection.

Due to recent changes, it was no longer possible to disable the
default tag selection handler. This commit extend the already
existing request::tag mechanism to let handlers select the tags.
This commit is contained in:
Emmanuel Lepage Vallee 2016-04-17 03:52:59 -04:00
parent 7cd76e0529
commit 299e155acc
4 changed files with 9 additions and 11 deletions

2
ewmh.c
View File

@ -399,7 +399,7 @@ ewmh_process_desktop(client_t *c, uint32_t desktop)
if(desktop == 0xffffffff) if(desktop == 0xffffffff)
{ {
luaA_object_push(L, c); luaA_object_push(L, c);
lua_pushnil(L); lua_pushboolean(L, true);
luaA_object_emit_signal(L, -2, "request::tag", 1); luaA_object_emit_signal(L, -2, "request::tag", 1);
/* Pop the client, arguments are already popped */ /* Pop the client, arguments are already popped */
lua_pop(L, 1); lua_pop(L, 1);

View File

@ -177,8 +177,14 @@ end
-- --
-- @client c A client to tag -- @client c A client to tag
-- @tag[opt] t A tag to use. If omitted, then the client is made sticky. -- @tag[opt] t A tag to use. If omitted, then the client is made sticky.
function ewmh.tag(c, t) -- @tparam[opt={}] table hints Extra information
function ewmh.tag(c, t, hints) --luacheck: no unused
-- There is nothing to do
if not t and #c:tags() > 0 then return end
if not t then if not t then
c:to_selected_tags()
elseif type(t) == "boolean" and t then
c.sticky = true c.sticky = true
else else
c.screen = t.screen c.screen = t.screen

View File

@ -29,10 +29,6 @@ local function get_screen(s)
return s and capi.screen[s] return s and capi.screen[s]
end end
-- awful.client is required() at the end of this file so the miss_handler is set
-- before it is being required.
local client
local tag = {object = {}, mt = {} } local tag = {object = {}, mt = {} }
-- Private data -- Private data
@ -1370,11 +1366,6 @@ object.properties(capi.tag, {
setter_fallback = tag.setproperty, setter_fallback = tag.setproperty,
}) })
-- fix a load loop
client = require("awful.client")
capi.client.connect_signal("manage", function(c) client.object.to_selected_tags(c) end)
return setmetatable(tag, tag.mt) return setmetatable(tag, tag.mt)
-- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80 -- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80

View File

@ -12,6 +12,7 @@ local function add_signals(c)
c:add_signal("property::screen") c:add_signal("property::screen")
c:add_signal("property::geometry") c:add_signal("property::geometry")
c:add_signal("request::geometry") c:add_signal("request::geometry")
c:add_signal("request::tag")
c:add_signal("swapped") c:add_signal("swapped")
c:add_signal("raised") c:add_signal("raised")
c:add_signal("property::_label") --Used internally c:add_signal("property::_label") --Used internally