notifications: Make `:reset_timer()` more intuitive. (#3175)

Previously it would only work if there already was a timeout to
avoid some infinite loops. Now it just delay the new timer to the
next loop.

Fix #3147
This commit is contained in:
Emmanuel Lepage Vallée 2020-09-27 23:34:14 -07:00 committed by GitHub
parent ca29aa191f
commit 5cbc423938
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 14 additions and 0 deletions

View File

@ -503,6 +503,13 @@ function notification:reset_timeout(new_timeout)
-- timer before the constructor ends. -- timer before the constructor ends.
if new_timeout and self.timer then if new_timeout and self.timer then
self.timeout = new_timeout self.timeout = new_timeout
elseif new_timeout and new_timeout ~= self._private.timeout then
local previous_timer = self._private.timeout
timer.delayed_call(function()
if self._private.timeout == previous_timer then
self.timeout = new_timeout
end
end)
end end
if self.timer and not self.timer.started then if self.timer and not self.timer.started then

View File

@ -1076,7 +1076,14 @@ table.insert(steps, function()
assert(naughty.get_by_id(42) ~= n) assert(naughty.get_by_id(42) ~= n)
-- The timeout -- The timeout
local real, called = n.reset_timeout, false
n.reset_timeout = function(...)
called = true
return real(...)
end
naughty.reset_timeout(n, 1337) naughty.reset_timeout(n, 1337)
assert(called)
assert(n.timer and n.timer.started)
-- Destroy using the old API -- Destroy using the old API
local old_count = #destroyed local old_count = #destroyed