Skip to content

Commit

Permalink
Merge pull request #1302 from Ryex/fix/progress-dialog-segfault
Browse files Browse the repository at this point in the history
fix: segfault in progress dialog
  • Loading branch information
Ryex authored and Scrumplex committed Jul 16, 2023
1 parent 721ac01 commit a65e4af
Showing 1 changed file with 23 additions and 12 deletions.
35 changes: 23 additions & 12 deletions launcher/ui/dialogs/ProgressDialog.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@
*/

#include "ProgressDialog.h"
#include <QPoint>
#include "ui_ProgressDialog.h"

#include <limits>
Expand Down Expand Up @@ -68,6 +69,7 @@ ProgressDialog::ProgressDialog(QWidget* parent) : QDialog(parent), ui(new Ui::Pr
setAttribute(Qt::WidgetAttribute::WA_QuitOnClose, true);
setSkipButton(false);
changeProgress(0, 100);
updateSize();
}

void ProgressDialog::setSkipButton(bool present, QString label)
Expand Down Expand Up @@ -96,22 +98,29 @@ ProgressDialog::~ProgressDialog()
void ProgressDialog::updateSize()
{
QSize lastSize = this->size();
QSize qSize = QSize(480, minimumSizeHint().height());

QPoint lastPos = this->pos();
int minHeight = ui->globalStatusDetailsLabel->minimumSize().height() + (ui->verticalLayout->spacing() * 2);
minHeight += ui->globalProgressBar->minimumSize().height() + ui->verticalLayout->spacing();
if (!ui->taskProgressScrollArea->isHidden())
minHeight += ui->taskProgressScrollArea->minimumSizeHint().height() + ui->verticalLayout->spacing();
if (ui->skipButton->isVisible())
minHeight += ui->skipButton->height() + ui->verticalLayout->spacing();
minHeight = std::max(minHeight, 60);
QSize minSize = QSize(480, minHeight);

setMinimumSize(minSize);
adjustSize();

QSize newSize = this->size();
// if the current window is too small
if ((lastSize != qSize) && (lastSize.height() < qSize.height()))
if ((lastSize != newSize) && (lastSize.height() < newSize.height()))
{
resize(qSize);

// keep the dialog in the center after a resize
this->move(
this->parentWidget()->x() + (this->parentWidget()->width() - this->width()) / 2,
this->parentWidget()->y() + (this->parentWidget()->height() - this->height()) / 2
);
QSize sizeDiff = lastSize - newSize; // last size was smaller, the results should be negative
// center on old position after resize
QPoint newPos(lastPos.x() + (sizeDiff.width() / 2), lastPos.y() + (sizeDiff.height() / 2));
this->move(newPos);
}

setMinimumSize(qSize);

}

int ProgressDialog::execWithTask(Task* task)
Expand Down Expand Up @@ -201,7 +210,9 @@ void ProgressDialog::onTaskSucceeded()
void ProgressDialog::changeStatus(const QString& status)
{
ui->globalStatusLabel->setText(task->getStatus());
ui->globalStatusLabel->adjustSize();
ui->globalStatusDetailsLabel->setText(task->getDetails());
ui->globalStatusDetailsLabel->adjustSize();

updateSize();
}
Expand Down

0 comments on commit a65e4af

Please sign in to comment.