From e5cc2583cca174a9393289af94ad8e2412fc0471 Mon Sep 17 00:00:00 2001 From: Mike Will Date: Fri, 6 Oct 2023 18:38:46 -0400 Subject: [PATCH] defaults.lua: add an inactive parameter to timer constructors Added to the functions `mp.add_timeout` and `mp.add_periodic_timer`. If the `inactive` argument is set to `true` or a truthy value, the timer will wait to be manually started with a call to its `resume()` method. --- DOCS/man/lua.rst | 8 ++++++-- player/lua/defaults.lua | 10 ++++++---- 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/DOCS/man/lua.rst b/DOCS/man/lua.rst index 494e95fcd8c82..9976ce929d9f7 100644 --- a/DOCS/man/lua.rst +++ b/DOCS/man/lua.rst @@ -438,17 +438,21 @@ The ``mp`` module is preloaded, although it can be loaded manually with that are equal to the ``fn`` parameter. This uses normal Lua ``==`` comparison, so be careful when dealing with closures. -``mp.add_timeout(seconds, fn)`` +``mp.add_timeout(seconds, fn [, inactive])`` Call the given function fn when the given number of seconds has elapsed. Note that the number of seconds can be fractional. For now, the timer's resolution may be as low as 50 ms, although this will be improved in the future. + If the ``inactive`` argument is set to ``true`` or a truthy value, the + timer will wait to be manually started with a call to its ``resume()`` + method. + This is a one-shot timer: it will be removed when it's fired. Returns a timer object. See ``mp.add_periodic_timer`` for details. -``mp.add_periodic_timer(seconds, fn)`` +``mp.add_periodic_timer(seconds, fn [, inactive])`` Call the given function periodically. This is like ``mp.add_timeout``, but the timer is re-added after the function fn is run. diff --git a/player/lua/defaults.lua b/player/lua/defaults.lua index e0914115f52df..8b9fe7d832c6d 100644 --- a/player/lua/defaults.lua +++ b/player/lua/defaults.lua @@ -265,20 +265,22 @@ local timers = {} local timer_mt = {} timer_mt.__index = timer_mt -function mp.add_timeout(seconds, cb) - local t = mp.add_periodic_timer(seconds, cb) +function mp.add_timeout(seconds, cb, inactive) + local t = mp.add_periodic_timer(seconds, cb, inactive) t.oneshot = true return t end -function mp.add_periodic_timer(seconds, cb) +function mp.add_periodic_timer(seconds, cb, inactive) local t = { timeout = seconds, cb = cb, oneshot = false, } setmetatable(t, timer_mt) - t:resume() + if not inactive then + t:resume() + end return t end