mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-06 00:55:50 +00:00
bb26ba30b6
To log/report progress of long duration operations using given time period.
51 lines
1.5 KiB
C++
51 lines
1.5 KiB
C++
#ifndef OPENMW_COMPONENTS_MISC_PROGRESSREPORTER_H
|
|
#define OPENMW_COMPONENTS_MISC_PROGRESSREPORTER_H
|
|
|
|
#include <algorithm>
|
|
#include <chrono>
|
|
#include <mutex>
|
|
#include <type_traits>
|
|
#include <utility>
|
|
|
|
namespace Misc
|
|
{
|
|
template <class Report>
|
|
class ProgressReporter
|
|
{
|
|
public:
|
|
explicit ProgressReporter(Report&& report = Report {})
|
|
: mReport(std::forward<Report>(report))
|
|
{}
|
|
|
|
explicit ProgressReporter(std::chrono::steady_clock::duration interval, Report&& report = Report {})
|
|
: mInterval(interval)
|
|
, mReport(std::forward<Report>(report))
|
|
{}
|
|
|
|
void operator()(std::size_t provided, std::size_t expected)
|
|
{
|
|
expected = std::max(expected, provided);
|
|
const bool shouldReport = [&]
|
|
{
|
|
const std::lock_guard lock(mMutex);
|
|
const auto now = std::chrono::steady_clock::now();
|
|
const auto left = mNextReport - now;
|
|
if (left.count() > 0 || provided == expected)
|
|
return false;
|
|
mNextReport += mInterval + left;
|
|
return true;
|
|
} ();
|
|
if (shouldReport)
|
|
mReport(provided, expected);
|
|
}
|
|
|
|
private:
|
|
const std::chrono::steady_clock::duration mInterval = std::chrono::seconds(1);
|
|
Report mReport;
|
|
std::mutex mMutex;
|
|
std::chrono::steady_clock::time_point mNextReport {std::chrono::steady_clock::now() + mInterval};
|
|
};
|
|
}
|
|
|
|
#endif
|