1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-10-26 11:56:37 +00:00
openmw/components/misc/progressreporter.hpp
elsid bb26ba30b6
Add progress reporter type
To log/report progress of long duration operations using given time period.
2021-10-18 01:26:10 +02:00

50 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