mirror of
https://github.com/subsurface/subsurface.git
synced 2025-01-19 14:25:27 +00:00
Fixed some small issues in webservice.c
1) download_dialog_status_text() had some statements with no effect due to missing return keywords. This fixes incorrect error reporting. 2) Optimize the traversion of the response XML. Assuming that the status tag should be always under the root tag. We check if the root tag has children and enter a loop until we find a the "download" or "error" node names. If there are no children we return a parser error. 3) Clamp the number of input characters to 30 in the user id GtkEntry field. Signed-off-by: Lubomir I. Ivanov <neolit123@gmail.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
parent
334e51988d
commit
9fa6b224f7
1 changed files with 14 additions and 16 deletions
30
webservice.c
30
webservice.c
|
@ -18,17 +18,15 @@ static const gchar *download_dialog_status_text(const gint status)
|
|||
switch (status) {
|
||||
case DD_STATUS_ERROR_CONNECT:
|
||||
return _("Connection Error: ");
|
||||
break;
|
||||
case DD_STATUS_ERROR_ID:
|
||||
_("Invalid user identifier!");
|
||||
break;
|
||||
return _("Invalid user identifier!");
|
||||
case DD_STATUS_ERROR_PARSE:
|
||||
_("Cannot parse response!");
|
||||
return _("Cannot parse response!");
|
||||
}
|
||||
return _("Download Success!");
|
||||
}
|
||||
|
||||
/* provides a state of the download dialog contents and the download xml */
|
||||
/* provides a state of the download dialog contents and the downloaded xml */
|
||||
struct download_dialog_state {
|
||||
GtkWidget *uid;
|
||||
GtkWidget *status;
|
||||
|
@ -69,20 +67,18 @@ gboolean webservice_request_user_xml(const gchar *user_id,
|
|||
return ret;
|
||||
}
|
||||
|
||||
static void download_dialog_traverse_xml(xmlNodePtr node, gboolean *download_status)
|
||||
/* 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(cur_node->name, (const gchar *)"download")) {
|
||||
if (!strcmp(xmlNodeGetContent(cur_node), (const gchar *)"ok")) {
|
||||
*download_status = DD_STATUS_OK;
|
||||
return;
|
||||
}
|
||||
} else if (!strcmp(cur_node->name, (const gchar *)"error")) {
|
||||
if ((!strcmp(cur_node->name, (const gchar *)"download")) &&
|
||||
(!strcmp(xmlNodeGetContent(cur_node), (const gchar *)"ok"))) {
|
||||
*download_status = DD_STATUS_OK;
|
||||
return;
|
||||
} else if (!strcmp(cur_node->name, (const gchar *)"error")) {
|
||||
*download_status = DD_STATUS_ERROR_ID;
|
||||
} else {
|
||||
download_dialog_traverse_xml(cur_node->children, download_status);
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -100,7 +96,8 @@ static guint download_dialog_parse_response(gchar *xmldata, guint len)
|
|||
status = DD_STATUS_ERROR_PARSE;
|
||||
goto end;
|
||||
}
|
||||
download_dialog_traverse_xml(root, &status);
|
||||
if (root->children)
|
||||
download_dialog_traverse_xml(root->children, &status);
|
||||
end:
|
||||
xmlFreeDoc(doc);
|
||||
return status;
|
||||
|
@ -177,6 +174,7 @@ void webservice_download_dialog(void)
|
|||
gtk_box_pack_start(GTK_BOX(vbox), frame_uid, FALSE, TRUE, pad);
|
||||
uid = gtk_entry_new();
|
||||
gtk_container_add(GTK_CONTAINER(frame_uid), uid);
|
||||
gtk_entry_set_max_length(GTK_ENTRY(uid), 30);
|
||||
gtk_entry_set_text(GTK_ENTRY(uid), current_uid);
|
||||
|
||||
download = gtk_button_new_with_label(_(" Download"));
|
||||
|
|
Loading…
Add table
Reference in a new issue