mirror of
https://github.com/microsoft/PowerToys.git
synced 2026-04-06 19:26:39 +02:00
* Implement CallTracer * Add CallTracer to various places * Newline * Fix unit tests not compiling for some reason * Add macro remove some trace calls * Add indentation * Add semicolon * Update src/modules/fancyzones/lib/CallTracer.cpp Co-authored-by: Enrico Giordani <enricogior@users.noreply.github.com> * Actually indent/unindent output * Fix initial indent level Co-authored-by: Enrico Giordani <enrico.giordani@gmail.com> Co-authored-by: Enrico Giordani <enricogior@users.noreply.github.com>
54 lines
1.2 KiB
C++
54 lines
1.2 KiB
C++
#include "pch.h"
|
|
|
|
#include "on_thread_executor.h"
|
|
#include "CallTracer.h"
|
|
|
|
OnThreadExecutor::OnThreadExecutor() :
|
|
_shutdown_request{ false }, _worker_thread{ [this] { worker_thread(); } }
|
|
{
|
|
}
|
|
|
|
std::future<void> OnThreadExecutor::submit(task_t task)
|
|
{
|
|
auto future = task.get_future();
|
|
std::lock_guard lock{ _task_mutex };
|
|
_task_queue.emplace(std::move(task));
|
|
_task_cv.notify_one();
|
|
return future;
|
|
}
|
|
|
|
void OnThreadExecutor::cancel()
|
|
{
|
|
std::lock_guard lock{ _task_mutex };
|
|
_task_queue = {};
|
|
_task_cv.notify_one();
|
|
}
|
|
|
|
|
|
void OnThreadExecutor::worker_thread()
|
|
{
|
|
while (!_shutdown_request)
|
|
{
|
|
task_t task;
|
|
{
|
|
CallTracer callTracer(__FUNCTION__ "(loop)");
|
|
std::unique_lock task_lock{ _task_mutex };
|
|
_task_cv.wait(task_lock, [this] { return !_task_queue.empty() || _shutdown_request; });
|
|
if (_shutdown_request)
|
|
{
|
|
return;
|
|
}
|
|
task = std::move(_task_queue.front());
|
|
_task_queue.pop();
|
|
}
|
|
task();
|
|
}
|
|
}
|
|
|
|
OnThreadExecutor::~OnThreadExecutor()
|
|
{
|
|
_shutdown_request = true;
|
|
_task_cv.notify_one();
|
|
_worker_thread.join();
|
|
}
|