2020-01-18 09:38:21 +01:00
|
|
|
/*
|
2024-10-04 13:19:50 +02:00
|
|
|
* Copyright (c) 2018-2020, Andreas Kling <andreas@ladybird.org>
|
2020-01-18 09:38:21 +01:00
|
|
|
*
|
2021-04-22 01:24:48 -07:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
2020-01-18 09:38:21 +01:00
|
|
|
*/
|
|
|
|
|
2019-03-25 01:42:15 +01:00
|
|
|
#pragma once
|
|
|
|
|
2021-09-11 20:24:37 -07:00
|
|
|
#include <AK/Time.h>
|
2019-03-25 01:42:15 +01:00
|
|
|
|
2020-02-02 12:34:39 +01:00
|
|
|
namespace Core {
|
|
|
|
|
2024-02-26 17:52:03 +00:00
|
|
|
enum class TimerType {
|
|
|
|
Precise,
|
|
|
|
Coarse
|
|
|
|
};
|
|
|
|
|
2020-02-02 12:34:39 +01:00
|
|
|
class ElapsedTimer {
|
2019-03-25 01:42:15 +01:00
|
|
|
public:
|
2024-05-08 20:15:05 +02:00
|
|
|
static ElapsedTimer start_new(TimerType timer_type = TimerType::Coarse);
|
2021-09-12 08:21:16 -07:00
|
|
|
|
2024-02-26 17:52:03 +00:00
|
|
|
ElapsedTimer(TimerType timer_type = TimerType::Coarse)
|
|
|
|
: m_timer_type(timer_type)
|
2020-12-03 22:12:50 -07:00
|
|
|
{
|
|
|
|
}
|
2019-03-25 01:42:15 +01:00
|
|
|
|
2019-04-01 22:03:32 +02:00
|
|
|
bool is_valid() const { return m_valid; }
|
2019-03-25 01:42:15 +01:00
|
|
|
void start();
|
2021-10-27 23:41:32 +02:00
|
|
|
void reset();
|
2023-01-01 22:30:31 -07:00
|
|
|
|
2023-05-24 08:32:20 -04:00
|
|
|
i64 elapsed_milliseconds() const;
|
2024-07-16 23:43:39 -06:00
|
|
|
AK::Duration elapsed_time() const;
|
2019-03-25 01:42:15 +01:00
|
|
|
|
2023-03-17 19:50:39 +01:00
|
|
|
MonotonicTime const& origin_time() const { return m_origin_time; }
|
2020-09-29 18:22:53 +02:00
|
|
|
|
2019-03-25 01:42:15 +01:00
|
|
|
private:
|
2023-03-17 19:50:39 +01:00
|
|
|
MonotonicTime m_origin_time { MonotonicTime::now() };
|
2024-02-26 17:52:03 +00:00
|
|
|
TimerType m_timer_type { TimerType::Coarse };
|
2019-04-01 22:03:32 +02:00
|
|
|
bool m_valid { false };
|
2019-03-25 01:42:15 +01:00
|
|
|
};
|
2020-02-02 12:34:39 +01:00
|
|
|
|
|
|
|
}
|