VolumeVerifier: Allocate QProgressDialog on stack

No reason to have it on the heap.

This also lets us skip calling reset, since the dialog closes
when the QProgressDialog object goes out of scope.
This commit is contained in:
JosJuice 2019-08-09 14:33:24 +02:00
parent e87a3f91a9
commit cd02ca17ce

View File

@ -98,18 +98,18 @@ void VerifyWidget::Verify()
// We have to divide the number of processed bytes with something so it won't make ints overflow // We have to divide the number of processed bytes with something so it won't make ints overflow
constexpr int DIVISOR = 0x100; constexpr int DIVISOR = 0x100;
QProgressDialog* progress = new QProgressDialog(tr("Verifying"), tr("Cancel"), 0, QProgressDialog progress(tr("Verifying"), tr("Cancel"), 0, verifier.GetTotalBytes() / DIVISOR,
verifier.GetTotalBytes() / DIVISOR, this); this);
progress->setWindowTitle(tr("Verifying")); progress.setWindowTitle(tr("Verifying"));
progress->setWindowFlags(progress->windowFlags() & ~Qt::WindowContextHelpButtonHint); progress.setWindowFlags(progress.windowFlags() & ~Qt::WindowContextHelpButtonHint);
progress->setMinimumDuration(500); progress.setMinimumDuration(500);
progress->setWindowModality(Qt::WindowModal); progress.setWindowModality(Qt::WindowModal);
verifier.Start(); verifier.Start();
while (verifier.GetBytesProcessed() != verifier.GetTotalBytes()) while (verifier.GetBytesProcessed() != verifier.GetTotalBytes())
{ {
progress->setValue(verifier.GetBytesProcessed() / DIVISOR); progress.setValue(verifier.GetBytesProcessed() / DIVISOR);
if (progress->wasCanceled()) if (progress.wasCanceled())
return; return;
verifier.Process(); verifier.Process();
@ -117,7 +117,7 @@ void VerifyWidget::Verify()
verifier.Finish(); verifier.Finish();
DiscIO::VolumeVerifier::Result result = verifier.GetResult(); DiscIO::VolumeVerifier::Result result = verifier.GetResult();
progress->reset(); progress.setValue(verifier.GetBytesProcessed() / DIVISOR);
m_summary_text->setText(QString::fromStdString(result.summary_text)); m_summary_text->setText(QString::fromStdString(result.summary_text));