Add support for fallback tags
This commit is contained in:
parent
117bf645dd
commit
e6b6004cce
|
@ -179,6 +179,7 @@ Then edit this section to fit your needs.
|
||||||
| **screen** | Tag screen(s) | number or array |
|
| **screen** | Tag screen(s) | number or array |
|
||||||
| **selected** | Select when created | boolean |
|
| **selected** | Select when created | boolean |
|
||||||
| **volatile** | Destroy when the last client is closed | boolean |
|
| **volatile** | Destroy when the last client is closed | boolean |
|
||||||
|
| **fallback** | Use this tag for unmatched clients | boolean |
|
||||||
|
|
||||||
|
|
||||||
##### The available client properties are:
|
##### The available client properties are:
|
||||||
|
|
10
init.lua
10
init.lua
|
@ -9,12 +9,12 @@ local capi = {client = client , tag = tag , awesome = awesome,
|
||||||
|
|
||||||
-------------------------------INIT------------------------------
|
-------------------------------INIT------------------------------
|
||||||
|
|
||||||
local signals,module,class_client,tags_hash,settings,sn_callback = {
|
local signals,module,class_client,tags_hash,settings,sn_callback,fallbacks = {
|
||||||
"exclusive" , "init" , "volatile" , "focus_new" , "instances" ,
|
"exclusive" , "init" , "volatile" , "focus_new" , "instances" ,
|
||||||
"match" , "class" , "spawn" , "position" , "force_screen" ,
|
"match" , "class" , "spawn" , "position" , "force_screen" ,
|
||||||
"max_clients" , "exec_once" , "clone_on" , "clone_of" , "no_focus_stealing",
|
"max_clients" , "exec_once" , "clone_on" , "clone_of" , "no_focus_stealing",
|
||||||
"shape_bounding", "no_focus_stealing_out","no_focus_stealing_in"
|
"shape_bounding", "no_focus_stealing_out","no_focus_stealing_in"
|
||||||
},{},{},{},{},{}
|
},{},{},{},{},{},{}
|
||||||
|
|
||||||
for _,sig in ipairs(signals) do
|
for _,sig in ipairs(signals) do
|
||||||
capi.tag.add_signal("property::"..sig)
|
capi.tag.add_signal("property::"..sig)
|
||||||
|
@ -163,6 +163,11 @@ local function match_client(c, startup)
|
||||||
capi.client.focus = c
|
capi.client.focus = c
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
--Add to the fallback tags
|
||||||
|
if #c:tags((function(arr) for k,v in ipairs(fallbacks) do
|
||||||
|
arr[#arr+1]=awful.tag.getscreen(v) == c.screen and v or nil
|
||||||
|
end; return arr
|
||||||
|
end)({})) > 0 then return end
|
||||||
--Last resort, create a new tag
|
--Last resort, create a new tag
|
||||||
class_client[low] = class_client[low] or {tags={},properties={}}
|
class_client[low] = class_client[low] or {tags={},properties={}}
|
||||||
local tmp,tag = class_client[low],awful.tag.add(c.class or "N/A",{name=c.class or "N/A",volatile=true,exclusive=true,screen=(c.screen <= capi.screen.count())
|
local tmp,tag = class_client[low],awful.tag.add(c.class or "N/A",{name=c.class or "N/A",volatile=true,exclusive=true,screen=(c.screen <= capi.screen.count())
|
||||||
|
@ -212,6 +217,7 @@ awful.tag.add,awful.tag._setscreen = function(tag,props)
|
||||||
local t3 = awful.tag._add(tag,{screen = awful.tag.getproperty(t,"clone_on"), clone_of = t,icon=awful.tag.geticon(t)})
|
local t3 = awful.tag._add(tag,{screen = awful.tag.getproperty(t,"clone_on"), clone_of = t,icon=awful.tag.geticon(t)})
|
||||||
--TODO prevent clients from being added to the clone
|
--TODO prevent clients from being added to the clone
|
||||||
end
|
end
|
||||||
|
fallbacks[#fallbacks+1] = props.fallback and t or nil
|
||||||
t:connect_signal("property::selected", function(t) on_selected_change(t,props or {}) end)
|
t:connect_signal("property::selected", function(t) on_selected_change(t,props or {}) end)
|
||||||
t.selected = props.selected or false
|
t.selected = props.selected or false
|
||||||
props.instances[props.screen] = t
|
props.instances[props.screen] = t
|
||||||
|
|
Loading…
Reference in New Issue