uv_task_runner.cc 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  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 "shell/app/uv_task_runner.h"
  5. #include <utility>
  6. #include "base/location.h"
  7. #include "base/time/time.h"
  8. namespace electron {
  9. UvTaskRunner::UvTaskRunner(uv_loop_t* loop) : loop_{loop} {}
  10. UvTaskRunner::~UvTaskRunner() = default;
  11. bool UvTaskRunner::PostDelayedTask(const base::Location& from_here,
  12. base::OnceClosure task,
  13. base::TimeDelta delay) {
  14. auto on_timeout = [](uv_timer_t* timer) {
  15. auto& tasks = static_cast<UvTaskRunner*>(timer->data)->tasks_;
  16. if (auto iter = tasks.find(timer); iter != tasks.end())
  17. std::move(tasks.extract(iter).mapped()).Run();
  18. };
  19. auto timer = UvHandle<uv_timer_t>{};
  20. timer->data = this;
  21. uv_timer_init(loop_, timer.get());
  22. uv_timer_start(timer.get(), on_timeout, delay.InMilliseconds(), 0);
  23. tasks_.insert_or_assign(std::move(timer), std::move(task));
  24. return true;
  25. }
  26. bool UvTaskRunner::RunsTasksInCurrentSequence() const {
  27. return true;
  28. }
  29. bool UvTaskRunner::PostNonNestableDelayedTask(const base::Location& from_here,
  30. base::OnceClosure task,
  31. base::TimeDelta delay) {
  32. return PostDelayedTask(from_here, std::move(task), delay);
  33. }
  34. } // namespace electron