diff options
author | Tomaz Canabrava <tcanabrava@kde.org> | 2013-06-06 11:57:12 -0300 |
---|---|---|
committer | Tomaz Canabrava <tcanabrava@kde.org> | 2013-06-06 11:57:12 -0300 |
commit | 2d05f4227e5538f3e8976a8244b54a5247ec833c (patch) | |
tree | a73d0803705afbf7a823d63bcb79511ab0c1dbcd /webservice.c | |
parent | f55ae1570738ec4e890ec35504e2c1e5c81364cc (diff) | |
download | subsurface-2d05f4227e5538f3e8976a8244b54a5247ec833c.tar.gz |
Hoocked up the Apply button.
Hoocked up the apply button - Didn't tested ( as I frankly don't know
what the expected result should be. ). but the app is not crashing, yey.
Signed-off-by: Tomaz Canabrava <tcanabrava@kde.org>
Diffstat (limited to 'webservice.c')
-rw-r--r-- | webservice.c | 60 |
1 files changed, 58 insertions, 2 deletions
diff --git a/webservice.c b/webservice.c index 2ac19c85a..f4f8baeb4 100644 --- a/webservice.c +++ b/webservice.c @@ -1,16 +1,36 @@ #include <libintl.h> #include <glib/gi18n.h> #include <libsoup/soup.h> - +#include <libxml/tree.h> +#include <libxml/parser.h> #include "dive.h" #include "divelist.h" #include "display-gtk.h" #include "file.h" -#include "webservice.h" struct dive_table gps_location_table; static gboolean merge_locations_into_dives(void); +enum { + DD_STATUS_OK, + DD_STATUS_ERROR_CONNECT, + DD_STATUS_ERROR_ID, + DD_STATUS_ERROR_PARSE, +}; + +static const gchar *download_dialog_status_text(const gint status) +{ + switch (status) { + case DD_STATUS_ERROR_CONNECT: + return _("Connection Error: "); + case DD_STATUS_ERROR_ID: + return _("Invalid user identifier!"); + case DD_STATUS_ERROR_PARSE: + return _("Cannot parse response!"); + } + return _("Download Success!"); +} + /* provides a state of the download dialog contents and the downloaded xml */ struct download_dialog_state { GtkWidget *uid; @@ -53,6 +73,42 @@ gboolean webservice_request_user_xml(const gchar *user_id, return ret; } +/* requires that there is a <download> or <error> tag under the <root> tag */ +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((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((const char *)cur_node->name, (const char *)"error")) { + *download_status = DD_STATUS_ERROR_ID; + return; + } + } +} + +static guint download_dialog_parse_response(gchar *xmldata, guint len) +{ + xmlNodePtr root; + xmlDocPtr doc = xmlParseMemory(xmldata, len); + guint status = DD_STATUS_ERROR_PARSE; + + if (!doc) + return DD_STATUS_ERROR_PARSE; + root = xmlDocGetRootElement(doc); + if (!root) { + status = DD_STATUS_ERROR_PARSE; + goto end; + } + if (root->children) + download_dialog_traverse_xml(root->children, &status); + end: + xmlFreeDoc(doc); + return status; +} + static void download_dialog_connect_cb(GtkWidget *w, gpointer data) { struct download_dialog_state *state = (struct download_dialog_state *)data; |