diff options
author | Danilo Cesar Lemes de Paula <danilo.eu@gmail.com> | 2013-09-01 11:14:54 -0300 |
---|---|---|
committer | Danilo Cesar Lemes de Paula <danilo.eu@gmail.com> | 2013-09-10 14:45:25 -0300 |
commit | 3f8e183008530fb8e110b77d04cf794c46ba4720 (patch) | |
tree | edfd686ca9b323182142f36d2b15a6141dbb8ad8 /qt-ui/downloadfromdivecomputer.cpp | |
parent | 59da382613280b14b34df0921d308b910a36ce32 (diff) | |
download | subsurface-3f8e183008530fb8e110b77d04cf794c46ba4720.tar.gz |
improve DownloadDialog's error handling
shows an error message when libdivecomputer returns
an error.
Signed-off-by: Danilo Cesar Lemes de Paula <danilo.eu@gmail.com>
Diffstat (limited to 'qt-ui/downloadfromdivecomputer.cpp')
-rw-r--r-- | qt-ui/downloadfromdivecomputer.cpp | 47 |
1 files changed, 37 insertions, 10 deletions
diff --git a/qt-ui/downloadfromdivecomputer.cpp b/qt-ui/downloadfromdivecomputer.cpp index f5c6fd51f..acdca89d3 100644 --- a/qt-ui/downloadfromdivecomputer.cpp +++ b/qt-ui/downloadfromdivecomputer.cpp @@ -11,6 +11,7 @@ #include <QDebug> #include <QStringListModel> #include <QTimer> +#include <QMessageBox> struct product { const char *product; @@ -101,18 +102,18 @@ void DownloadFromDCWidget::updateState(states state) // user pressed cancel but the application isn't doing anything. // means close the window - else if ((currentState == INITIAL || currentState == CANCELLED || currentState == DONE) + else if ((currentState == INITIAL || currentState == CANCELLED || currentState == DONE || currentState == ERROR) && state == CANCELLING) { timer->stop(); reject(); } - // A cancel is finished + // the cancelation process is finished else if (currentState == CANCELLING && (state == DONE || state == CANCELLED)) { timer->stop(); state = CANCELLED; ui->progressBar->setValue(0); - ui->progressbar->hide(); + ui->progressBar->hide(); markChildrenAsEnabled(); } @@ -132,6 +133,15 @@ void DownloadFromDCWidget::updateState(states state) markChildrenAsDisabled(); } + // got an error + else if (state == ERROR) { + QMessageBox::critical(this, tr("Error"), this->thread->error, QMessageBox::Ok); + + markChildrenAsEnabled(); + ui->progressBar->hide(); + ui->ok->setText(tr("retry")); + } + // properly updating the widget state currentState = state; } @@ -243,9 +253,12 @@ void DownloadFromDCWidget::reject() void DownloadFromDCWidget::onDownloadThreadFinished() { - if (currentState == DOWNLOADING) - updateState(DONE); - else + if (currentState == DOWNLOADING) { + if (thread->error.isEmpty()) + updateState(DONE); + else + updateState(ERROR); + } else updateState(CANCELLED); } @@ -277,17 +290,31 @@ DownloadThread::DownloadThread(QObject* parent, device_data_t* data): QThread(pa { } +static QString str_error(const char *fmt, ...) +{ + va_list args; + va_start(args, fmt); + const QString str = QString().vsprintf( fmt, args ); + va_end(args); + + return str; +} + void DownloadThread::run() { DownloadFromDCWidget *dfdcw = DownloadFromDCWidget::instance(); + const char *error; if (!strcmp(data->vendor, "Uemis")) - do_uemis_import(data->devname, data->force_download); + error = do_uemis_import(data->devname, data->force_download); else - // TODO: implement error handling - do_libdivecomputer_import(data); + error = do_libdivecomputer_import(data); + + if (error) { + this->error = str_error(error, data->devname, data->vendor, data->product); + } - // I'm not sure if we should really process_dives even + // I'm not sure if we should really call process_dives even // if there's an error or a cancelation process_dives(TRUE, dfdcw->preferDownloaded()); } |