awful.key: Add a function to execute keybindings

This commit is contained in:
Emmanuel Lepage Vallee 2016-04-08 02:45:29 -04:00
parent cf9e45e5d9
commit 11f0620d7c
1 changed files with 36 additions and 1 deletions

View File

@ -10,7 +10,7 @@
-- Grab environment we need -- Grab environment we need
local setmetatable = setmetatable local setmetatable = setmetatable
local ipairs = ipairs local ipairs = ipairs
local capi = { key = key } local capi = { key = key, root = root }
local util = require("awful.util") local util = require("awful.util")
@ -26,6 +26,40 @@ local key = { mt = {}, hotkeys = {} }
-- @class table -- @class table
local ignore_modifiers = { "Lock", "Mod2" } local ignore_modifiers = { "Lock", "Mod2" }
--- Convert the modifiers into pc105 key names
local conversion = {
mod4 = "Super_L",
control = "Control_L",
shift = "Shift_L",
mod1 = "Alt_L",
}
--- Execute a key combination.
-- If an awesome keybinding is assigned to the combination, it should be
-- executed.
-- @see root.fake_input
-- @tparam table mod A modified table. Valid modifiers are: Any, Mod1,
-- Mod2, Mod3, Mod4, Mod5, Shift, Lock and Control.
-- @tparam string k The key
function key.execute(mod, k)
for _, v in ipairs(mod) do
local m = conversion[v:lower()]
if m then
root.fake_input("key_press", m)
end
end
root.fake_input("key_press" , k)
root.fake_input("key_release", k)
for _, v in ipairs(mod) do
local m = conversion[v:lower()]
if m then
root.fake_input("key_release", m)
end
end
end
--- Create a new key to use as binding. --- Create a new key to use as binding.
-- This function is useful to create several keys from one, because it will use -- This function is useful to create several keys from one, because it will use
-- the ignore_modifier variable to create several keys with and without the -- the ignore_modifier variable to create several keys with and without the
@ -66,6 +100,7 @@ function key.new(mod, _key, press, release, data)
data.mod = mod data.mod = mod
data.key = _key data.key = _key
table.insert(key.hotkeys, data) table.insert(key.hotkeys, data)
data.execute = function(_) key.execute(mod, _key) end
return ret return ret
end end