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:
parent
04c291cdc9
commit
d0a614d551
15
init.lua
15
init.lua
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue