]> sigrok.org Git - pulseview.git/blobdiff - pv/dialogs/storeprogress.cpp
Fix #895 by adapting to Qt5 and cleaning up properly
[pulseview.git] / pv / dialogs / storeprogress.cpp
index b9c87ee70f49ba433860ab3cfdcda15842d78cf7..0d0a222c2cc5594dc875dfcd0473b169a8c5dd0f 100644 (file)
@@ -26,6 +26,8 @@
 #include "storeprogress.hpp"
 
 using std::map;
+using std::pair;
+using std::shared_ptr;
 using std::string;
 
 using Glib::VariantBase;
@@ -34,9 +36,9 @@ namespace pv {
 namespace dialogs {
 
 StoreProgress::StoreProgress(const QString &file_name,
-       const std::shared_ptr<sigrok::OutputFormat> output_format,
+       const shared_ptr<sigrok::OutputFormat> output_format,
        const map<string, VariantBase> &options,
-       const std::pair<uint64_t, uint64_t> sample_range,
+       const pair<uint64_t, uint64_t> sample_range,
        const Session &session, QWidget *parent) :
        QProgressDialog(tr("Saving..."), tr("Cancel"), 0, 0, parent),
        session_(file_name.toStdString(), output_format, options, sample_range,
@@ -46,6 +48,19 @@ StoreProgress::StoreProgress(const QString &file_name,
                this, SLOT(on_progress_updated()));
        connect(&session_, SIGNAL(store_successful()),
                &session, SLOT(on_data_saved()));
+
+       // Since we're not setting any progress in case of an error, the dialog
+       // will pop up after the minimumDuration time has been reached - 4000 ms
+       // by default.
+       // We do not want this as it overlaps with the error message box, so we
+       // set the minimumDuration to 0 so that it only appears when we feed it
+       // progress data. Then, call reset() to prevent the progress dialog from
+       // popping up anyway. This would happen in Qt5 because the behavior was
+       // changed in such a way that the duration timer is started by the
+       // constructor. We don't want that and reset() stops the timer, so we
+       // use it.
+       setMinimumDuration(0);
+       reset();
 }
 
 StoreProgress::~StoreProgress()
@@ -69,16 +84,22 @@ void StoreProgress::show_error()
        msg.setStandardButtons(QMessageBox::Ok);
        msg.setIcon(QMessageBox::Warning);
        msg.exec();
+
+       close();
 }
 
 void StoreProgress::closeEvent(QCloseEvent*)
 {
        session_.cancel();
+
+       // Closing doesn't mean we're going to be destroyed because our parent
+       // still owns our handle. Make sure this stale instance doesn't hang around.
+       deleteLater();
 }
 
 void StoreProgress::on_progress_updated()
 {
-       const std::pair<int, int> p = session_.progress();
+       const pair<int, int> p = session_.progress();
        assert(p.first <= p.second);
 
        if (p.second) {
@@ -92,5 +113,5 @@ void StoreProgress::on_progress_updated()
        }
 }
 
-} // dialogs
-} // pv
+}  // namespace dialogs
+}  // namespace pv