diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2012-11-11 14:29:26 +0100 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2012-11-11 14:29:26 +0100 |
commit | fe4f13f184ffb97ee4b6dbd4138a9d8ae3aabd14 (patch) | |
tree | ae127ca3591cb72b86bd1b512134086902e140cd /gtk-gui.c | |
parent | 78ad07c72ed37928020cdbf4842e24690ce35f81 (diff) | |
download | subsurface-fe4f13f184ffb97ee4b6dbd4138a9d8ae3aabd14.tar.gz |
Add special download modes to force updates from the divecomputer
This will hopefully not be something we need often, but if we improve
support for a divecomputer (either in libdivecomputer or in our native
Uemis code or even in the way we handle (and potentially discard) events),
then it is extremely useful to be able to say "re-download things
from the divecomputer and for things that were not edited in Subsurface,
don't try to merge the data (which gives BAD results if for example you
fixed a bug in the depth calculation in libdivecomputer) but instead
simply take the samples, the events and some of the other unedited data
straight from the download".
This commit implements just that - a "force download" checkbox in the
download dialog that makes us reimport all dives from the dive computer,
even the ones we already have, and an "always prefer downloaded dive"
checkbox that then tells Subsurface not to merge but simply to take the
data from the downloaded dive - without overwriting the things we have
already edited in Subsurface (like location, buddy, equipment, etc).
This, as a precaution, refuses to merge dives that don't have identical
start times. So if you have edited the date / time of a dive or if you
have previously merged your dive with a different dive computer (and
therefore modified samples and events) you are out of luck.
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'gtk-gui.c')
-rw-r--r-- | gtk-gui.c | 27 |
1 files changed, 22 insertions, 5 deletions
@@ -43,6 +43,8 @@ static const char *default_dive_computer_vendor; static const char *default_dive_computer_product; static const char *default_dive_computer_device; static char *uemis_max_dive_data; +static gboolean force_download; +static gboolean prefer_downloaded; static int is_default_dive_computer(const char *vendor, const char *product) { @@ -350,7 +352,7 @@ static void file_open(GtkWidget *w, gpointer data) } g_free(filename); g_slist_free(fn_glist); - report_dives(FALSE); + report_dives(FALSE, FALSE); } gtk_widget_destroy(dialog); } @@ -510,6 +512,8 @@ OPTIONCALLBACK(autogroup_toggle, autogroup) OPTIONCALLBACK(po2_toggle, partial_pressure_graphs.po2) OPTIONCALLBACK(pn2_toggle, partial_pressure_graphs.pn2) OPTIONCALLBACK(phe_toggle, partial_pressure_graphs.phe) +OPTIONCALLBACK(force_toggle, force_download) +OPTIONCALLBACK(prefer_dl_toggle, prefer_downloaded) static void event_toggle(GtkWidget *w, gpointer _data) { @@ -1605,7 +1609,7 @@ void import_files(GtkWidget *w, gpointer data) filenames = gtk_file_chooser_get_filenames(GTK_FILE_CHOOSER(fs_dialog)); if (filenames) { g_slist_foreach(filenames, do_import_file, NULL); - report_dives(TRUE); + report_dives(TRUE, FALSE); g_slist_free(filenames); } } @@ -1619,7 +1623,7 @@ static GError *setup_uemis_import(device_data_t *data) GError *error = NULL; char *buf = NULL; - error = uemis_download(data->devname, &uemis_max_dive_data, &buf, &data->progress); + error = uemis_download(data->devname, &uemis_max_dive_data, &buf, &data->progress, data->force_download); if (buf && strlen(buf) > 1) { #ifdef DEBUGFILE fprintf(debugfile, "xml buffer \"%s\"\n\n", buf); @@ -1696,6 +1700,18 @@ void download_dialog(GtkWidget *w, gpointer data) devicedata.progress.bar = gtk_progress_bar_new(); gtk_container_add(GTK_CONTAINER(hbox), devicedata.progress.bar); + force_download = FALSE; + button = gtk_check_button_new_with_label(_("Force download of all dives")); + gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(button), FALSE); + gtk_box_pack_start(GTK_BOX(vbox), button, FALSE, FALSE, 6); + g_signal_connect(G_OBJECT(button), "toggled", G_CALLBACK(force_toggle), NULL); + + prefer_downloaded = FALSE; + button = gtk_check_button_new_with_label(_("Always prefer downloaded dive")); + gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(button), FALSE); + gtk_box_pack_start(GTK_BOX(vbox), button, FALSE, FALSE, 6); + g_signal_connect(G_OBJECT(button), "toggled", G_CALLBACK(prefer_dl_toggle), NULL); + button = gtk_dialog_get_widget_for_response(GTK_DIALOG(dialog), GTK_RESPONSE_ACCEPT); if (!gtk_combo_box_get_active_iter(computer, &iter)) gtk_widget_set_sensitive(button, FALSE); @@ -1747,15 +1763,16 @@ repeat: while (*(--ne) == ' ' || *ne == '\t') *ne = '\0'; devicedata.devname = ns; + devicedata.force_download = force_download; info = import_dive_computer(&devicedata, GTK_DIALOG(dialog)); free((void *)devname); if (info) goto repeat; - report_dives(TRUE); + report_dives(TRUE, prefer_downloaded); break; default: /* it's possible that some dives were downloaded */ - report_dives(TRUE); + report_dives(TRUE, prefer_downloaded); break; } gtk_widget_destroy(dialog); |