1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-10-26 02:12:07 +00:00
serenity/Userland/Libraries/LibCore/Timer.cpp
Sam Atkins 6edc0cf5ab LibCore+Userland: Don't auto-start new Core::Timers
This was unintuitive, and only useful in a few cases. In the majority,
users had to immediately call `stop()`, and several who did want the
timer started would call `start()` on it immediately anyway. Case in
point: There are only two places I had to add a manual `start()`.
2023-01-12 11:25:51 +01:00

81 lines
1.2 KiB
C++

/*
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
* Copyright (c) 2022, the SerenityOS developers.
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#include <LibCore/Timer.h>
namespace Core {
Timer::Timer(Object* parent)
: Object(parent)
{
}
Timer::Timer(int interval_ms, Function<void()>&& timeout_handler, Object* parent)
: Object(parent)
, on_timeout(move(timeout_handler))
, m_interval_ms(interval_ms)
{
}
void Timer::start()
{
start(m_interval_ms);
}
void Timer::start(int interval_ms)
{
if (m_active)
return;
m_interval_ms = interval_ms;
start_timer(interval_ms);
m_active = true;
}
void Timer::restart()
{
restart(m_interval_ms);
}
void Timer::restart(int interval_ms)
{
if (m_active)
stop();
start(interval_ms);
}
void Timer::stop()
{
if (!m_active)
return;
stop_timer();
m_active = false;
}
void Timer::set_active(bool active)
{
if (active)
start();
else
stop();
}
void Timer::timer_event(TimerEvent&)
{
if (m_single_shot)
stop();
else {
if (m_interval_dirty) {
stop();
start(m_interval_ms);
}
}
if (on_timeout)
on_timeout();
}
}