diff options
Diffstat (limited to 'src/libjin/Time')
-rw-r--r-- | src/libjin/Time/je_timer.cpp | 18 | ||||
-rw-r--r-- | src/libjin/Time/je_timer.h | 5 |
2 files changed, 17 insertions, 6 deletions
diff --git a/src/libjin/Time/je_timer.cpp b/src/libjin/Time/je_timer.cpp index 94ab747..fcd805c 100644 --- a/src/libjin/Time/je_timer.cpp +++ b/src/libjin/Time/je_timer.cpp @@ -36,6 +36,17 @@ namespace JinEngine } } + void Timer::cancel(Handler* handler) + { + handler->canceled = true; + } + + void Timer::cancelAll() + { + for (auto h : mHandlers) + cancel(h); + } + Timer::Handler* Timer::every(int ms, TimerCallback callback, void* p) { Handler* t = new Handler(Handler::EVERY, ms, 0, callback, p); @@ -79,7 +90,7 @@ namespace JinEngine if (tickdown <= 0) { tickdown = duration; - if (callback != nullptr) + if (!canceled && callback != nullptr) callback(paramters); if (type == EVERY) { @@ -97,11 +108,6 @@ namespace JinEngine } } - void Timer::cancel(Handler* handler) - { - handler->canceled = true; - } - } // namespace Time } // namespace JinEngine diff --git a/src/libjin/Time/je_timer.h b/src/libjin/Time/je_timer.h index d0e5513..1310890 100644 --- a/src/libjin/Time/je_timer.h +++ b/src/libjin/Time/je_timer.h @@ -82,6 +82,11 @@ namespace JinEngine /// void cancel(Handler* handler = nullptr); + /// + /// + /// + void cancelAll(); + private: std::vector<Handler*> mHandlers; |