diff options
author | crupest <crupest@outlook.com> | 2020-10-28 16:58:56 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2020-10-28 16:58:56 +0800 |
commit | 2df47ffbfff02fb6b64d19e404adc41a93677afe (patch) | |
tree | e15a566c95b68b6266bdcab14bba64be729ab300 /include/cru/platform | |
parent | fde24556042b76863bdec34dcc213cb7298f68f9 (diff) | |
download | cru-2df47ffbfff02fb6b64d19e404adc41a93677afe.tar.gz cru-2df47ffbfff02fb6b64d19e404adc41a93677afe.tar.bz2 cru-2df47ffbfff02fb6b64d19e404adc41a93677afe.zip |
...
Diffstat (limited to 'include/cru/platform')
-rw-r--r-- | include/cru/platform/native/UiApplication.hpp | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/include/cru/platform/native/UiApplication.hpp b/include/cru/platform/native/UiApplication.hpp index 135e95c3..4c1b3456 100644 --- a/include/cru/platform/native/UiApplication.hpp +++ b/include/cru/platform/native/UiApplication.hpp @@ -1,6 +1,7 @@ #pragma once #include "../Resource.hpp" #include "Base.hpp" +#include "cru/common/Base.hpp" #include <chrono> #include <functional> @@ -53,6 +54,60 @@ struct IUiApplication : public virtual INativeResource { virtual IInputMethodManager* GetInputMethodManager() = 0; }; +class TimerAutoCanceler { + public: + TimerAutoCanceler() : id_(0) {} + explicit TimerAutoCanceler(long long id) : id_(id) {} + + CRU_DELETE_COPY(TimerAutoCanceler) + + TimerAutoCanceler(TimerAutoCanceler&& other) : id_(other.id_) { + other.id_ = 0; + } + + TimerAutoCanceler& operator=(TimerAutoCanceler&& other) { + Reset(other.id_); + other.id_ = 0; + return *this; + } + + ~TimerAutoCanceler() { Reset(); } + + long long Release() { + auto temp = id_; + id_ = 0; + return temp; + } + + void Reset(long long id = 0) { + if (id_ > 0) IUiApplication::GetInstance()->CancelTimer(id_); + id_ = id; + } + + private: + long long id_; +}; + +class TimerListAutoCanceler { + public: + TimerListAutoCanceler() = default; + CRU_DELETE_COPY(TimerListAutoCanceler) + CRU_DEFAULT_MOVE(TimerListAutoCanceler) + ~TimerListAutoCanceler() = default; + + TimerListAutoCanceler& operator+=(long long id) { + list_.push_back(TimerAutoCanceler(id)); + return *this; + } + + void Clear() { list_.clear(); } + + bool IsEmpty() const { return list_.empty(); } + + private: + std::vector<TimerAutoCanceler> list_; +}; + // Bootstrap from this. std::unique_ptr<IUiApplication> CreateUiApplication(); } // namespace cru::platform::native |