summaryrefslogtreecommitdiffstats
path: root/qt-ui/downloadfromdivecomputer.cpp
diff options
context:
space:
mode:
authorGravatar Danilo Cesar Lemes de Paula <danilo.eu@gmail.com>2013-09-01 11:14:54 -0300
committerGravatar Danilo Cesar Lemes de Paula <danilo.eu@gmail.com>2013-09-10 14:45:25 -0300
commit3f8e183008530fb8e110b77d04cf794c46ba4720 (patch)
treeedfd686ca9b323182142f36d2b15a6141dbb8ad8 /qt-ui/downloadfromdivecomputer.cpp
parent59da382613280b14b34df0921d308b910a36ce32 (diff)
downloadsubsurface-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.cpp47
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());
}