/* * Copyright (c) 2018-2020, Andreas Kling * Copyright (c) 2022, the SerenityOS developers. * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include namespace Core { class Timer final : public EventReceiver { C_OBJECT(Timer); public: static ErrorOr> create_repeating(int interval_ms, Function&& timeout_handler, EventReceiver* parent = nullptr) { return adopt_nonnull_ref_or_enomem(new Timer(interval_ms, move(timeout_handler), parent)); } static ErrorOr> create_single_shot(int interval_ms, Function&& timeout_handler, EventReceiver* parent = nullptr) { auto timer = TRY(adopt_nonnull_ref_or_enomem(new Timer(interval_ms, move(timeout_handler), parent))); timer->set_single_shot(true); return timer; } virtual ~Timer() override = default; void start(); void start(int interval_ms); void restart(); void restart(int interval_ms); void stop(); void set_active(bool); bool is_active() const { return m_active; } int interval() const { return m_interval_ms; } void set_interval(int interval_ms) { if (m_interval_ms == interval_ms) return; m_interval_ms = interval_ms; m_interval_dirty = true; } bool is_single_shot() const { return m_single_shot; } void set_single_shot(bool single_shot) { m_single_shot = single_shot; } Function on_timeout; private: explicit Timer(EventReceiver* parent = nullptr); Timer(int interval_ms, Function&& timeout_handler, EventReceiver* parent = nullptr); virtual void timer_event(TimerEvent&) override; bool m_active { false }; bool m_single_shot { false }; bool m_interval_dirty { false }; int m_interval_ms { 0 }; }; }