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:
parent
ca29aa191f
commit
5cbc423938
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue