Round time estimate up to nearest nanosecond

This commit is contained in:
Seth Parker
2020-11-16 11:27:16 -05:00
parent e01c2950f2
commit d11ffd91c6
4 changed files with 24 additions and 18 deletions

View File

@@ -200,9 +200,10 @@ private:
if (saved_start_time) {
auto eta = std::chrono::nanoseconds(
progress_ > 0 ? static_cast<long long>(float(elapsed.count()) *
max_progress / progress_)
: 0);
progress_ > 0
? static_cast<long long>(std::ceil(float(elapsed.count()) *
max_progress / progress_))
: 0);
auto remaining = eta > elapsed ? (eta - elapsed) : (elapsed - eta);
details::write_duration(os, remaining);
} else {

View File

@@ -255,9 +255,10 @@ private:
if (saved_start_time) {
auto eta = std::chrono::nanoseconds(
progress_ > 0 ? static_cast<long long>(float(elapsed_.count()) *
max_progress / progress_)
: 0);
progress_ > 0
? static_cast<long long>(std::ceil(float(elapsed_.count()) *
max_progress / progress_))
: 0);
auto remaining = eta > elapsed_ ? (eta - elapsed_) : (elapsed_ - eta);
details::write_duration(os, remaining);
} else {

View File

@@ -195,9 +195,10 @@ public:
else
os << " [";
auto eta = std::chrono::nanoseconds(
progress_ > 0 ? static_cast<long long>(float(elapsed.count()) *
max_progress / progress_)
: 0);
progress_ > 0
? static_cast<long long>(std::ceil(float(elapsed.count()) *
max_progress / progress_))
: 0);
auto remaining = eta > elapsed ? (eta - elapsed) : (elapsed - eta);
details::write_duration(os, remaining);
os << "]";