Add support for startup notification callbacks

It is now possible to set a function that will be called
when Tyrannical will manage a new client. This function
must return an array of client properties (ontop, floating,
...). The `tag` and `tags` properties will also work. The
key is a startup notification ID. awful.util.spawn will
return this as the second return value if the command was
a success.

Example:
local pid,snid = awful.util.spawn("firefox")
tyrannical.sn_callback[snid] = funtion return {ontop=true} end
This commit is contained in:
Emmanuel Lepage Vallee 2014-05-01 16:44:17 -04:00
parent 04c291cdc9
commit d0a614d551
1 changed files with 9 additions and 8 deletions

View File

@ -78,7 +78,7 @@ local function apply_properties(c,override,normal)
local props = awful.util.table.join(normal,override) local props = awful.util.table.join(normal,override)
--Set all 'c.something' properties --Set all 'c.something' properties
for k,_ in pairs(props) do for k,_ in pairs(props) do
props[k] = (override[v] ~= nil) and override[k] or normal[k] if override[k] ~= nil then props[k] = override[k] else props[k] = normal[k] end
c[k] = props[k] c[k] = props[k]
end end
--Force floating state, if necessary --Force floating state, if necessary
@ -114,16 +114,17 @@ end
local function match_client(c, startup) local function match_client(c, startup)
if not c then return end if not c then return end
local startup = startup == nil and capi.awesome.startup or startup local startup = startup == nil and capi.awesome.startup or startup
if c.startup_id and sn_callback[c.startup_id] and sn_callback[c.startup_id](c,startup) then return end local props = (c.startup_id and sn_callback[c.startup_id]) and sn_callback[c.startup_id](c,startup) or {}
local low = string.lower(c.class or "N/A")
local low,tags = string.lower(c.class or "N/A"),props.tags or {props.tag}
local rules = class_client[low] local rules = class_client[low]
if c.transient_for and settings.group_children == true then if #tags == 0 and c.transient_for and settings.group_children == true then
c.sticky = c.transient_for.sticky or false c.sticky = c.transient_for.sticky or false
c:tags(c.transient_for:tags()) c:tags(c.transient_for:tags())
capi.client.focus = c capi.client.focus = c
return return
elseif rules then elseif rules then
local ret = apply_properties(c,{},rules.properties) local ret = apply_properties(c,props,rules.properties)
if ret then if ret then
if not rules.properties.no_autofocus then if not rules.properties.no_autofocus then
capi.client.focus = c capi.client.focus = c
@ -131,8 +132,8 @@ local function match_client(c, startup)
return ret return ret
end end
--Add to matches --Add to matches
local tags,tags_src,fav_scr,c_src,mouse_s = {},{},false,c.screen,capi.mouse.screen local tags_src,fav_scr,c_src,mouse_s = {},false,c.screen,capi.mouse.screen
for j=1,#(rules.tags or {}) do for j=1,#(#tags == 0 and rules.tags or {}) do
local tag,cache = rules.tags[j],rules.tags[j].screen local tag,cache = rules.tags[j],rules.tags[j].screen
tag.instances,has_screen = tag.instances or {},(type(tag.screen)=="table" and awful.util.table.hasitem(tag.screen,c_src)~=nil) tag.instances,has_screen = tag.instances or {},(type(tag.screen)=="table" and awful.util.table.hasitem(tag.screen,c_src)~=nil)
tag.screen = (tag.force_screen ~= true and c_src) or (has_screen and c_src or type(tag.screen)=="table" and tag.screen[1] or tag.screen) tag.screen = (tag.force_screen ~= true and c_src) or (has_screen and c_src or type(tag.screen)=="table" and tag.screen[1] or tag.screen)