improve progressbar

This commit is contained in:
mrbesen 2022-10-23 12:01:02 +02:00
parent 4caabf923a
commit 7e1e39e592
Signed by: MrBesen
GPG Key ID: 596B2350DCD67504
2 changed files with 14 additions and 7 deletions

View File

@ -88,6 +88,7 @@ std::map<uint64_t, Files> Dedup::hash(std::multimap<uint64_t, std::shared_ptr<Fi
std::cout << progressBar;
}
std::cout << "\n";
Log::info << "Hashing done after: " << (int) (progressBar.getDuration().count() / 1000) << "s ";
return filesizes;

View File

@ -1,5 +1,7 @@
#include "progressbar.h"
#include <iomanip>
#include "file.h"
const uint_fast8_t ProgressBar::BARLENGTH = 50;
@ -18,17 +20,20 @@ std::chrono::duration<uint64_t, std::milli> ProgressBar::getDuration() const {
}
std::ostream& operator<<(std::ostream& str, const ProgressBar& pb) {
double progressd = pb.currentBytes / (double) pb.maxBytes;
uint64_t progressi = (progressd * 10000.0);
double progress = (pb.currentBytes / (double) pb.maxBytes);
auto usedtime = pb.getDuration();
std::chrono::duration<uint64_t, std::ratio<60>> eta = std::chrono::duration_cast<std::chrono::minutes>((usedtime / (double) pb.currentBytes) * pb.maxBytes);
// speed
double speed = (pb.currentBytes / (double) usedtime.count()); // B/ms
speed /= 1000; // B/s
uint64_t bytespersecond = (int) speed; // floor
// generate bar
str << "[";
str << "\r[";
for(uint_fast8_t i = 0; i < ProgressBar::BARLENGTH; ++i) {
if( (i / (double) ProgressBar::BARLENGTH) < progressd ) {
if( (i / (double) ProgressBar::BARLENGTH) < progress ) {
str << '#';
} else {
str << ' ';
@ -36,9 +41,10 @@ std::ostream& operator<<(std::ostream& str, const ProgressBar& pb) {
}
// print info
str << "] " << (progressi / 100.0f) << "% " << pb.currentFiles << '/' << pb.maxFiles << " Files "
<< FileSize(pb.currentBytes) << '/' << FileSize(pb.maxBytes) << " ETA: " << eta.count()
<< "s \r" << std::flush;
str << "] " << std::setprecision(2) << std::setfill('0') << std::fixed << std::setw(5) << (progress * 100) << "% "
<< std::setprecision(6) << std::defaultfloat
<< FileSize(pb.currentBytes) << '/' << FileSize(pb.maxBytes) << " " << pb.currentFiles << '/' << pb.maxFiles << " Files "
<< FileSize(bytespersecond) << "/s ETA: " << eta.count() << "s " << std::flush;
return str;
}