uv_task_runner.cc 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. // Copyright (c) 2015 GitHub, Inc.
  2. // Use of this source code is governed by the MIT license that can be
  3. // found in the LICENSE file.
  4. #include <utility>
  5. #include "base/location.h"
  6. #include "base/stl_util.h"
  7. #include "base/time/time.h"
  8. #include "shell/app/uv_task_runner.h"
  9. namespace electron {
  10. UvTaskRunner::UvTaskRunner(uv_loop_t* loop) : loop_(loop) {}
  11. UvTaskRunner::~UvTaskRunner() {
  12. for (auto& iter : tasks_) {
  13. uv_unref(reinterpret_cast<uv_handle_t*>(iter.first));
  14. delete iter.first;
  15. }
  16. }
  17. bool UvTaskRunner::PostDelayedTask(const base::Location& from_here,
  18. base::OnceClosure task,
  19. base::TimeDelta delay) {
  20. auto* timer = new uv_timer_t;
  21. timer->data = this;
  22. uv_timer_init(loop_, timer);
  23. uv_timer_start(timer, UvTaskRunner::OnTimeout, delay.InMilliseconds(), 0);
  24. tasks_[timer] = std::move(task);
  25. return true;
  26. }
  27. bool UvTaskRunner::RunsTasksInCurrentSequence() const {
  28. return true;
  29. }
  30. bool UvTaskRunner::PostNonNestableDelayedTask(const base::Location& from_here,
  31. base::OnceClosure task,
  32. base::TimeDelta delay) {
  33. return PostDelayedTask(from_here, std::move(task), delay);
  34. }
  35. // static
  36. void UvTaskRunner::OnTimeout(uv_timer_t* timer) {
  37. auto& tasks = static_cast<UvTaskRunner*>(timer->data)->tasks_;
  38. const auto iter = tasks.find(timer);
  39. if (iter == std::end(tasks))
  40. return;
  41. std::move(iter->second).Run();
  42. tasks.erase(iter);
  43. uv_timer_stop(timer);
  44. uv_close(reinterpret_cast<uv_handle_t*>(timer), UvTaskRunner::OnClose);
  45. }
  46. // static
  47. void UvTaskRunner::OnClose(uv_handle_t* handle) {
  48. delete reinterpret_cast<uv_timer_t*>(handle);
  49. }
  50. } // namespace electron