electron/atom/app/uv_task_runner.cc

61 lines
1.7 KiB
C++
Raw Normal View History

2015-09-03 02:28:50 +00:00
// Copyright (c) 2015 GitHub, Inc.
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
#include <utility>
2015-09-03 02:28:50 +00:00
#include "atom/app/uv_task_runner.h"
#include "base/stl_util.h"
namespace atom {
2018-04-18 01:55:30 +00:00
UvTaskRunner::UvTaskRunner(uv_loop_t* loop) : loop_(loop) {}
2015-09-03 02:28:50 +00:00
UvTaskRunner::~UvTaskRunner() {
for (auto& iter : tasks_) {
uv_unref(reinterpret_cast<uv_handle_t*>(iter.first));
delete iter.first;
}
}
bool UvTaskRunner::PostDelayedTask(const base::Location& from_here,
base::OnceClosure task,
2015-09-03 02:28:50 +00:00
base::TimeDelta delay) {
auto* timer = new uv_timer_t;
2015-09-03 02:28:50 +00:00
timer->data = this;
uv_timer_init(loop_, timer);
uv_timer_start(timer, UvTaskRunner::OnTimeout, delay.InMilliseconds(), 0);
tasks_[timer] = std::move(task);
2015-09-03 02:28:50 +00:00
return true;
}
bool UvTaskRunner::RunsTasksInCurrentSequence() const {
2015-09-03 02:28:50 +00:00
return true;
}
2018-04-18 01:55:30 +00:00
bool UvTaskRunner::PostNonNestableDelayedTask(const base::Location& from_here,
base::OnceClosure task,
base::TimeDelta delay) {
return PostDelayedTask(from_here, std::move(task), delay);
2015-09-03 02:28:50 +00:00
}
// static
void UvTaskRunner::OnTimeout(uv_timer_t* timer) {
UvTaskRunner* self = static_cast<UvTaskRunner*>(timer->data);
if (!ContainsKey(self->tasks_, timer))
return;
std::move(self->tasks_[timer]).Run();
2015-09-03 02:28:50 +00:00
self->tasks_.erase(timer);
uv_timer_stop(timer);
uv_close(reinterpret_cast<uv_handle_t*>(timer), UvTaskRunner::OnClose);
}
// static
void UvTaskRunner::OnClose(uv_handle_t* handle) {
delete reinterpret_cast<uv_timer_t*>(handle);
2015-09-03 02:28:50 +00:00
}
} // namespace atom