keygrabber: Allow multiple instances to be created during the same loop. (#2741)
Due to a facepalm caliber mistake, the wrong self was being used... Fixes #2712
This commit is contained in:
parent
7b7dcdd87a
commit
4440c5c1d5
|
@ -126,7 +126,7 @@ local function add_root_keybindings(self, list)
|
|||
-- everything into one operation. In not so extreme cases, not doing so
|
||||
-- would slow down `awesome.restart()` by a small, but noticeable amount
|
||||
-- of time.
|
||||
gtable.merge(delay_list, list)
|
||||
table.insert(delay_list, {self, list})
|
||||
|
||||
-- As of Awesome v4.3, `root.keys()` is an all or nothing API and there
|
||||
-- isn't a standard mechanism to add and remove keybindings at runtime
|
||||
|
@ -137,13 +137,16 @@ local function add_root_keybindings(self, list)
|
|||
gtimer.delayed_call(function()
|
||||
local ret = {}
|
||||
|
||||
for _, v in ipairs(delay_list) do
|
||||
for _, obj in ipairs(delay_list) do
|
||||
local obj_self, obj_list = obj[1], obj[2]
|
||||
|
||||
for _, v in ipairs(obj_list) do
|
||||
local mods, key, press, release, description = unpack(v)
|
||||
|
||||
if press then
|
||||
local old_press = press
|
||||
press = function(...)
|
||||
self:start()
|
||||
obj_self:start()
|
||||
old_press(...)
|
||||
end
|
||||
end
|
||||
|
@ -151,13 +154,14 @@ local function add_root_keybindings(self, list)
|
|||
if release then
|
||||
local old_release = release
|
||||
release = function(...)
|
||||
self:start()
|
||||
obj_self:start()
|
||||
old_release(...)
|
||||
end
|
||||
end
|
||||
|
||||
table.insert(ret, akey(mods, key, press, release, description))
|
||||
end
|
||||
end
|
||||
|
||||
-- Wow...
|
||||
capi.root.keys(gtable.join( capi.root.keys(), unpack(ret) ))
|
||||
|
|
Loading…
Reference in New Issue