summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Lubomir I. Ivanov <neolit123@gmail.com>2013-02-25 22:25:12 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2013-02-25 12:56:59 -0800
commit04ad50cb75eeb40c22d4da3e8c605cb48143bd11 (patch)
treef0e537f57a17ec45fb9e371f7244888b53104858
parentcd5c61e102dfd7cb1bfc5031e693b2dcd66bec9e (diff)
downloadsubsurface-04ad50cb75eeb40c22d4da3e8c605cb48143bd11.tar.gz
Improvements to the "Download from Webservice" dialog
- Added a help button that links to the online API page and should provide a sufficient start to the new user. - Use download_dialog_response_cb as a callback for most dialog reponses instead of waiting for gtk_dialog_run() and using goto e.g. in the case of GTK_RESPONSE_HELP. - Fixed some integer signedness warnings in download_dialog_traverse_xml() Signed-off-by: Lubomir I. Ivanov <neolit123@gmail.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--webservice.c58
1 files changed, 33 insertions, 25 deletions
diff --git a/webservice.c b/webservice.c
index 531a571c3..f3def9f14 100644
--- a/webservice.c
+++ b/webservice.c
@@ -8,6 +8,7 @@
#include "display-gtk.h"
struct dive_table gps_location_table;
+static void merge_locations_into_dives(void);
enum {
DD_STATUS_OK,
@@ -76,11 +77,11 @@ static void download_dialog_traverse_xml(xmlNodePtr node, guint *download_status
{
xmlNodePtr cur_node;
for (cur_node = node; cur_node; cur_node = cur_node->next) {
- if ((!strcmp(cur_node->name, (const gchar *)"download")) &&
- (!strcmp(xmlNodeGetContent(cur_node), (const gchar *)"ok"))) {
+ if ((!strcmp((const char *)cur_node->name, (const char *)"download")) &&
+ (!strcmp((const char *)xmlNodeGetContent(cur_node), (const char *)"ok"))) {
*download_status = DD_STATUS_OK;
return;
- } else if (!strcmp(cur_node->name, (const gchar *)"error")) {
+ } else if (!strcmp((const char *)cur_node->name, (const char *)"error")) {
*download_status = DD_STATUS_ERROR_ID;
return;
}
@@ -139,10 +140,29 @@ static void download_dialog_release_xml(struct download_dialog_state *state)
free((void *)state->xmldata);
}
-static void download_dialog_delete(GtkWidget *w, gpointer data)
+static void download_dialog_response_cb(GtkDialog *d, gint response, gpointer data)
{
struct download_dialog_state *state = (struct download_dialog_state *)data;
- download_dialog_release_xml(state);
+ switch (response) {
+ case GTK_RESPONSE_HELP:
+ /* open webservice api page */
+ subsurface_launch_for_uri("http://api.hohndel.org/");
+ break;
+ case GTK_RESPONSE_ACCEPT:
+ /* apply download */
+ parse_xml_buffer(_("Webservice"), state->xmldata, state->xmldata_len, &gps_location_table, NULL);
+ /* now merge the data in the gps_location table into the dive_table */
+ merge_locations_into_dives();
+ mark_divelist_changed(TRUE);
+ dive_list_update_dives();
+ /* store last entered uid in config */
+ subsurface_set_conf("webservice_uid", gtk_entry_get_text(GTK_ENTRY(state->uid)));
+ default:
+ case GTK_RESPONSE_DELETE_EVENT:
+ gtk_widget_destroy(GTK_WIDGET(d));
+ download_dialog_release_xml(state);
+ free(state);
+ }
}
static gboolean is_automatic_fix(struct dive *gpsfix)
@@ -198,9 +218,8 @@ void webservice_download_dialog(void)
const gchar *current_uid = subsurface_get_conf("webservice_uid");
GtkWidget *dialog, *vbox, *status, *info, *uid;
GtkWidget *frame_uid, *frame_status, *download, *image, *apply;
- struct download_dialog_state state = {NULL};
+ struct download_dialog_state *state = malloc(sizeof(struct download_dialog_state));
gboolean has_previous_uid = TRUE;
- int result;
if (!current_uid) {
current_uid = "";
@@ -214,6 +233,8 @@ void webservice_download_dialog(void)
GTK_RESPONSE_ACCEPT,
GTK_STOCK_CANCEL,
GTK_RESPONSE_REJECT,
+ GTK_STOCK_HELP,
+ GTK_RESPONSE_HELP,
NULL);
apply = gtk_dialog_get_widget_for_response(GTK_DIALOG(dialog), GTK_RESPONSE_ACCEPT);
@@ -238,7 +259,7 @@ void webservice_download_dialog(void)
image = gtk_image_new_from_stock(GTK_STOCK_CONNECT, GTK_ICON_SIZE_MENU);
gtk_button_set_image(GTK_BUTTON(download), image);
gtk_box_pack_start(GTK_BOX(vbox), download, FALSE, TRUE, pad);
- g_signal_connect(download, "clicked", G_CALLBACK(download_dialog_connect_cb), &state);
+ g_signal_connect(download, "clicked", G_CALLBACK(download_dialog_connect_cb), (gpointer)state);
frame_status = gtk_frame_new(_("Status"));
status = gtk_label_new(_("Idle"));
@@ -246,25 +267,12 @@ void webservice_download_dialog(void)
gtk_container_add(GTK_CONTAINER(frame_status), status);
gtk_misc_set_padding(GTK_MISC(status), pad, pad);
- state.uid = uid;
- state.status = status;
- state.apply = apply;
+ state->uid = uid;
+ state->status = status;
+ state->apply = apply;
+ g_signal_connect(dialog, "response", G_CALLBACK(download_dialog_response_cb), (gpointer)state);
gtk_widget_show_all(dialog);
- g_signal_connect(dialog, "delete-event", G_CALLBACK(download_dialog_delete), &state);
- result = gtk_dialog_run(GTK_DIALOG(dialog));
- if (result == GTK_RESPONSE_ACCEPT) {
- /* apply download */
- parse_xml_buffer(_("Webservice"), state.xmldata, state.xmldata_len, &gps_location_table, NULL);
- /* now merge the data in the gps_location table into the dive_table */
- merge_locations_into_dives();
- mark_divelist_changed(TRUE);
- dive_list_update_dives();
- /* store last entered uid in config */
- subsurface_set_conf("webservice_uid", gtk_entry_get_text(GTK_ENTRY(uid)));
- }
- download_dialog_release_xml(&state);
- gtk_widget_destroy(dialog);
if (has_previous_uid)
free((void *)current_uid);
}