capi.key: Enable the miss handlers.
This commit is contained in:
parent
afbb3b7faf
commit
fe603f7dc5
|
@ -14,6 +14,7 @@ local capi = { key = key, root = root, awesome = awesome }
|
||||||
local gmath = require("gears.math")
|
local gmath = require("gears.math")
|
||||||
local gtable = require("gears.table")
|
local gtable = require("gears.table")
|
||||||
local gdebug = require("gears.debug")
|
local gdebug = require("gears.debug")
|
||||||
|
local gobject = require("gears.object")
|
||||||
|
|
||||||
--- The keyboard key used to trigger this keybinding.
|
--- The keyboard key used to trigger this keybinding.
|
||||||
--
|
--
|
||||||
|
@ -128,6 +129,13 @@ function key:get_has_root_binding()
|
||||||
return capi.root.has_key(self)
|
return capi.root.has_key(self)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- This is used by the keygrabber and prompt to identify valid awful.key
|
||||||
|
-- objects. It *cannot* be put directly in the object since `capi` uses a lot
|
||||||
|
-- of `next` internally and fixing that would suck more.
|
||||||
|
function key:get__is_awful_key()
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
local function index_handler(self, k)
|
local function index_handler(self, k)
|
||||||
if key["get_"..k] then
|
if key["get_"..k] then
|
||||||
return key["get_"..k](self)
|
return key["get_"..k](self)
|
||||||
|
@ -223,14 +231,26 @@ local function new_common(mod, _key, press, release, data)
|
||||||
local ret = {}
|
local ret = {}
|
||||||
local subsets = gmath.subsets(key.ignore_modifiers)
|
local subsets = gmath.subsets(key.ignore_modifiers)
|
||||||
for _, set in ipairs(subsets) do
|
for _, set in ipairs(subsets) do
|
||||||
ret[#ret + 1] = capi.key({ modifiers = gtable.join(mod, set),
|
local sub_key = capi.key {
|
||||||
key = _key })
|
modifiers = gtable.join(mod, set),
|
||||||
if press then
|
key = _key
|
||||||
ret[#ret]:connect_signal("press", function(_, ...) press(...) end)
|
}
|
||||||
end
|
|
||||||
if release then
|
sub_key._private._legacy_convert_to = ret
|
||||||
ret[#ret]:connect_signal("release", function(_, ...) release(...) end)
|
|
||||||
end
|
sub_key:connect_signal("press", function(_, ...)
|
||||||
|
if ret.on_press then
|
||||||
|
ret.on_press(...)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
|
||||||
|
sub_key:connect_signal("release", function(_, ...)
|
||||||
|
if ret.on_release then
|
||||||
|
ret.on_release(...)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
|
||||||
|
ret[#ret + 1] = sub_key
|
||||||
end
|
end
|
||||||
|
|
||||||
-- append custom userdata (like description) to a hotkey
|
-- append custom userdata (like description) to a hotkey
|
||||||
|
@ -297,6 +317,10 @@ function key.mt:__call(...)
|
||||||
return key.new(...)
|
return key.new(...)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
gobject.properties(capi.key, {
|
||||||
|
auto_emit = true,
|
||||||
|
})
|
||||||
|
|
||||||
return setmetatable(key, key.mt)
|
return setmetatable(key, key.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
|
||||||
|
|
Loading…
Reference in New Issue