keygrabber: Rename release_event to stop_event (#2422)

In the earlier revision of the keygrabber PR, there was a `release_key`
and it was suggested to rename it `stop_key`. However its sibling
`release_event` wasn't, so it is now confusing.

The commit adds a mild deprecation codepath to avoid breaking configs
based on git-master. However it isn't a "long term" deprecation notice
and the code can probably be removed in 5.0 without further delay.
This commit is contained in:
Emmanuel Lepage Vallée 2018-10-16 08:42:56 -04:00 committed by GitHub
parent 0475ff12c9
commit 35130169c9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 27 additions and 14 deletions

View File

@ -170,7 +170,7 @@ end
local function runner(self, modifiers, key, event) local function runner(self, modifiers, key, event)
-- Stop the keygrabber with the `stop_key` -- Stop the keygrabber with the `stop_key`
if key == self.stop_key if key == self.stop_key
and event == self.release_event and self.stop_key then and event == self.stop_event and self.stop_key then
self:stop(key, modifiers) self:stop(key, modifiers)
return false return false
end end
@ -182,7 +182,7 @@ local function runner(self, modifiers, key, event)
end end
-- Support multiple stop keys -- Support multiple stop keys
if type(self.stop_key) == "table" and event == self.release_event then if type(self.stop_key) == "table" and event == self.stop_event then
for _, k in ipairs(self.stop_key) do for _, k in ipairs(self.stop_key) do
if k == key then if k == key then
self:stop(k, modifiers) self:stop(k, modifiers)
@ -297,7 +297,7 @@ end
--- The key on which the keygrabber listen to terminate itself. --- The key on which the keygrabber listen to terminate itself.
-- --
-- When this is set, the running keygrabber will quit when [one of] the release -- When this is set, the running keygrabber will quit when [one of] the stop
-- key event occurs. -- key event occurs.
-- --
-- By default, the event is `press`. It is common for use case like the -- By default, the event is `press`. It is common for use case like the
@ -317,7 +317,7 @@ end
-- --
-- @property stop_key -- @property stop_key
-- @param[opt=nil] string|table stop_key -- @param[opt=nil] string|table stop_key
-- @see release_event -- @see stop_event
--- The event on which the keygrabbing will be terminated. --- The event on which the keygrabbing will be terminated.
-- --
@ -326,7 +326,7 @@ end
-- * "press" (default) -- * "press" (default)
-- * "release" -- * "release"
-- --
-- @property release_event -- @property stop_event
-- @param string -- @param string
-- @see stop_key -- @see stop_key
@ -493,12 +493,12 @@ end
--- Stop the keygrabber. --- Stop the keygrabber.
-- @function keygrabber:stop -- @function keygrabber:stop
function keygrabber:stop(_stop_key, _release_mods) -- (at)function disables ldoc params function keygrabber:stop(_stop_key, _stop_mods) -- (at)function disables ldoc params
keygrab.stop(self.grabber) keygrab.stop(self.grabber)
if self.stop_callback then if self.stop_callback then
self.stop_callback( self.stop_callback(
self.current_instance, _stop_key, _release_mods, self.sequence self.current_instance, _stop_key, _stop_mods, self.sequence
) )
end end
@ -544,6 +544,19 @@ function keygrabber:set_allowed_keys(keys)
end end
end end
--TODO v5 remove this
function keygrabber:set_release_event(event)
-- It has never been in a release, so it can be deprecated right away
gdebug.deprecate("release_event has been renamed to stop_event")
self.stop_event = event
end
--TODO v5 remove this
function keygrabber:get_release_event()
return self.stop_event
end
--- When the keygrabber starts. --- When the keygrabber starts.
-- @signal started -- @signal started
@ -556,12 +569,12 @@ end
--- The callback when the keygrabbing stops. --- The callback when the keygrabbing stops.
-- --
-- @usage local function my_done_cb(self, stop_key, release_mods, sequence) -- @usage local function my_done_cb(self, stop_key, stop_mods, sequence)
-- -- do something -- -- do something
-- end -- end
-- @tparam table self The current transaction object. -- @tparam table self The current transaction object.
-- @tparam string stop_key The key(s) that stop the keygrabbing (if any) -- @tparam string stop_key The key(s) that stop the keygrabbing (if any)
-- @tparam table release_mods The release modifiers key (if any) -- @tparam table stop_mods The modifiers key (if any)
-- @tparam sting sequence The recorded key sequence. -- @tparam sting sequence The recorded key sequence.
-- @callback stop_callback -- @callback stop_callback
-- @see sequence -- @see sequence
@ -604,11 +617,11 @@ end
-- navigation. -- navigation.
-- --
-- Note that the object returned can be used as a client or global keybinding -- Note that the object returned can be used as a client or global keybinding
-- callback without modification. Make sure to set `stop_key` and `release_event` -- callback without modification. Make sure to set `stop_key` and `stop_event`
-- to proper values to avoid permanently locking the keyboard. -- to proper values to avoid permanently locking the keyboard.
-- --
-- @tparam table args -- @tparam table args
-- @tparam[opt="press"] string args.release_event Release event ("press" or "release") -- @tparam[opt="press"] string args.stop_event Release event ("press" or "release")
-- @tparam[opt=nil] string|table args.stop_key The key that has to be kept pressed. -- @tparam[opt=nil] string|table args.stop_key The key that has to be kept pressed.
-- @tparam table args.keybindings All keybindings. -- @tparam table args.keybindings All keybindings.
-- @tparam[opt=-1] number args.timeout The maximum inactivity delay. -- @tparam[opt=-1] number args.timeout The maximum inactivity delay.
@ -646,7 +659,7 @@ function keygrab.run_with_keybindings(args)
gtable.crush(ret, args) gtable.crush(ret, args)
ret._private.keybindings = {} ret._private.keybindings = {}
ret.release_event = args.release_event or "press" ret.stop_event = args.stop_event or "press"
-- Build the hook map -- Build the hook map
for _,v in ipairs(args.keybindings or {}) do for _,v in ipairs(args.keybindings or {}) do

View File

@ -17,7 +17,7 @@ local awful = {keygrabber = require("awful.keygrabber"), --DOC_HIDE
}, },
-- Note that it is using the key name and not the modifier name. -- Note that it is using the key name and not the modifier name.
stop_key = "Alt_L", stop_key = "Alt_L",
release_event = "release", stop_event = "release",
start_callback = awful.client.focus.history.disable_tracking, start_callback = awful.client.focus.history.disable_tracking,
stop_callback = awful.client.focus.history.enable_tracking, stop_callback = awful.client.focus.history.enable_tracking,
export_keybindings = true, export_keybindings = true,