aboutsummaryrefslogtreecommitdiff
path: root/include/cru/platform/native/ui_application.hpp
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2020-04-24 00:03:16 +0800
committercrupest <crupest@outlook.com>2020-04-24 00:03:16 +0800
commit75ff8a6a05afd02aaadf7e3049b0a0e305241182 (patch)
tree5444bbb3ef80036cc38a827b8ccf03f48b310728 /include/cru/platform/native/ui_application.hpp
parent922d7f6c96f81a33538900f8a8992a5b6f640874 (diff)
downloadcru-75ff8a6a05afd02aaadf7e3049b0a0e305241182.tar.gz
cru-75ff8a6a05afd02aaadf7e3049b0a0e305241182.tar.bz2
cru-75ff8a6a05afd02aaadf7e3049b0a0e305241182.zip
...
Diffstat (limited to 'include/cru/platform/native/ui_application.hpp')
-rw-r--r--include/cru/platform/native/ui_application.hpp15
1 files changed, 10 insertions, 5 deletions
diff --git a/include/cru/platform/native/ui_application.hpp b/include/cru/platform/native/ui_application.hpp
index 006255db..afcc7117 100644
--- a/include/cru/platform/native/ui_application.hpp
+++ b/include/cru/platform/native/ui_application.hpp
@@ -32,11 +32,16 @@ struct IUiApplication : public virtual INativeResource {
virtual void AddOnQuitHandler(std::function<void()> handler) = 0;
virtual void InvokeLater(std::function<void()> action) = 0;
- virtual unsigned long SetTimeout(std::chrono::milliseconds milliseconds,
- std::function<void()> action) = 0;
- virtual unsigned long SetInterval(std::chrono::milliseconds milliseconds,
- std::function<void()> action) = 0;
- virtual void CancelTimer(unsigned long id) = 0;
+ // Timer id should always be positive and never the same. So it's ok to use
+ // negative value to represent no timer.
+ virtual long long SetTimeout(std::chrono::milliseconds milliseconds,
+ std::function<void()> action) = 0;
+ virtual long long SetInterval(std::chrono::milliseconds milliseconds,
+ std::function<void()> action) = 0;
+ // Implementation should guarantee calls on timer id already canceled have no
+ // effects and do not crash. Also canceling negative id should always result
+ // in no-op.
+ virtual void CancelTimer(long long id) = 0;
virtual std::vector<INativeWindow*> GetAllWindow() = 0;
virtual std::shared_ptr<INativeWindowResolver> CreateWindow(