2017-09-13 03:35:27 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <atomic>
|
|
|
|
#include <functional>
|
|
|
|
#include <mutex>
|
|
|
|
#include <thread>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
// Helper methods for starting threads that do some work. Enables test code to
|
|
|
|
// wait for all work to complete.
|
|
|
|
struct WorkThread {
|
2017-09-22 01:14:57 +00:00
|
|
|
enum class Result { MoreWork, NoWork, ExitThread };
|
2017-09-13 03:35:27 +00:00
|
|
|
|
|
|
|
// The number of active worker threads.
|
|
|
|
static std::atomic<int> num_active_threads;
|
|
|
|
// Set to true to request all work thread instances to exit.
|
|
|
|
static std::atomic<bool> request_exit_on_idle;
|
|
|
|
|
|
|
|
// Launch a new thread. |entry_point| will be called continously. It should
|
|
|
|
// return true if it there is still known work to be done.
|
2017-09-22 01:14:57 +00:00
|
|
|
static void StartThread(const std::string& thread_name,
|
|
|
|
const std::function<Result()>& entry_point);
|
2017-09-13 03:35:27 +00:00
|
|
|
|
|
|
|
// Static-only class.
|
|
|
|
WorkThread() = delete;
|
|
|
|
};
|