spdlog/include/spdlog/details/periodic_worker.h

77 lines
1.8 KiB
C
Raw Normal View History

//
// Copyright(c) 2018 Gabi Melman.
// Distributed under the MIT License (http://opensource.org/licenses/MIT)
//
#pragma once
2018-07-22 07:02:01 +08:00
// periodic worker thread - periodically executes the given callback function.
//
// RAII over the owned thread:
// creates the thread on construction.
// stops and joins the thread on destruction.
#include <chrono>
2018-07-22 04:48:07 +08:00
#include <condition_variable>
#include <functional>
2018-07-22 04:48:07 +08:00
#include <mutex>
2018-07-23 02:55:47 +08:00
#include <thread>
2018-07-22 04:48:07 +08:00
namespace spdlog {
namespace details {
class periodic_worker
{
public:
periodic_worker(std::function<void()> callback_fun, std::chrono::seconds interval)
{
if (interval == std::chrono::seconds::zero())
{
active_ = false;
return;
}
active_ = true;
2018-07-22 04:48:07 +08:00
flusher_thread_ = std::thread([callback_fun, interval, this]() {
for (;;)
{
std::unique_lock<std::mutex> lock(this->mutex_);
2018-07-24 08:01:27 +08:00
bool should_terminate = this->cv_.wait_for(lock, interval, [this] {
return !this->active_;
});
2018-07-24 08:01:27 +08:00
if (should_terminate)
{
break;
}
callback_fun();
}
});
}
2018-07-22 04:48:07 +08:00
periodic_worker(const periodic_worker &) = delete;
periodic_worker &operator=(const periodic_worker &) = delete;
// stop the back thread and join it
~periodic_worker()
{
2018-07-24 08:08:49 +08:00
if (!active_)
{
2018-07-24 08:08:49 +08:00
return;
}
{
std::lock_guard<std::mutex> lock(mutex_);
active_ = false;
}
2018-07-24 08:08:49 +08:00
cv_.notify_one();
flusher_thread_.join();
}
private:
2018-07-24 08:08:49 +08:00
bool active_;
std::thread flusher_thread_;
std::mutex mutex_;
std::condition_variable cv_;
};
2018-07-22 04:48:07 +08:00
} // namespace details
2018-07-22 07:02:01 +08:00
} // namespace spdlog