2009-04-14 17:53:22 +02:00
|
|
|
---------------------------------------------------------------------------
|
|
|
|
-- @author Julien Danjou <julien@danjou.info>
|
|
|
|
-- @copyright 2009 Julien Danjou
|
|
|
|
-- @release @AWESOME_VERSION@
|
|
|
|
---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
-- Grab environment we need
|
|
|
|
local setmetatable = setmetatable
|
|
|
|
local ipairs = ipairs
|
|
|
|
local unpack = unpack
|
|
|
|
local capi = { key = key }
|
|
|
|
local util = require("awful.util")
|
|
|
|
|
|
|
|
--- Key helper for awful
|
|
|
|
module("awful.key")
|
|
|
|
|
|
|
|
--- Modifiers to ignore
|
|
|
|
ignore_modifiers = { "Lock", "Mod2" }
|
|
|
|
|
|
|
|
--- Create a new key to use as binding.
|
|
|
|
-- This function is useful to create several keys from one, because it will use
|
|
|
|
-- the ignore_modifier variable to create more key with or without the ignored
|
|
|
|
-- modifiers activated.
|
|
|
|
-- For example if you want to ignore CapsLock in your keybinding (which is
|
|
|
|
-- ignored by default by this function), creatina key binding with this function
|
|
|
|
-- will return 2 key objects: one with CapsLock on, and the other one with
|
|
|
|
-- CapsLock off.
|
|
|
|
-- @see C api key() function for parameters.
|
2009-04-17 11:13:22 +02:00
|
|
|
-- @return A table with one or several key objects.
|
2009-04-27 18:38:00 +02:00
|
|
|
function new(mod, ...)
|
2009-04-14 17:53:22 +02:00
|
|
|
local ret = {}
|
|
|
|
local subsets = util.subsets(ignore_modifiers)
|
|
|
|
for _, set in ipairs(subsets) do
|
2009-04-15 21:33:21 +02:00
|
|
|
ret[#ret + 1] = capi.key(util.table.join(mod, set), unpack(arg))
|
2009-04-14 17:53:22 +02:00
|
|
|
end
|
2009-04-17 11:13:22 +02:00
|
|
|
return ret
|
2009-04-14 17:53:22 +02:00
|
|
|
end
|
|
|
|
|
2009-04-27 18:35:04 +02:00
|
|
|
--- Compare a key object with modifiers and key.
|
|
|
|
-- @param key The key object.
|
|
|
|
-- @param pressed_mod The modifiers to compare with.
|
|
|
|
-- @param pressed_key The key to compare with.
|
|
|
|
function match(key, pressed_mod, pressed_key)
|
|
|
|
-- First, compare key.
|
|
|
|
if pressed_key ~= key.key then return false end
|
|
|
|
-- Then, compare mod
|
|
|
|
local mod = key.modifiers
|
|
|
|
local nbmod = 0
|
2009-04-28 20:02:10 +02:00
|
|
|
-- For each modifier of the key object, check that the modifier has been
|
|
|
|
-- pressed.
|
|
|
|
for _, m in ipairs(mod) do
|
|
|
|
-- Has it been pressed?
|
|
|
|
if util.table.hasitem(pressed_mod, m) then
|
|
|
|
-- Yes, the number of modifier correctly pressed++
|
2009-04-27 18:35:04 +02:00
|
|
|
nbmod = nbmod + 1
|
2009-04-28 20:02:10 +02:00
|
|
|
else
|
|
|
|
-- No, so this is failure!
|
|
|
|
return false
|
2009-04-27 18:35:04 +02:00
|
|
|
end
|
|
|
|
end
|
2009-04-28 20:02:10 +02:00
|
|
|
-- If the number of pressed modifier is ~=, it is probably >, so this is not
|
|
|
|
-- the same, return false.
|
|
|
|
if nbmod ~= #mod then
|
2009-04-27 18:35:04 +02:00
|
|
|
return false
|
|
|
|
end
|
|
|
|
return true
|
|
|
|
end
|
|
|
|
|
2009-04-27 18:38:00 +02:00
|
|
|
setmetatable(_M, { __call = function(_, ...) return new(unpack(arg)) end })
|
2009-04-14 17:53:22 +02:00
|
|
|
|
|
|
|
-- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80
|