diff options
Diffstat (limited to 'my-evolution/e-summary-rdf.c')
-rw-r--r-- | my-evolution/e-summary-rdf.c | 166 |
1 files changed, 38 insertions, 128 deletions
diff --git a/my-evolution/e-summary-rdf.c b/my-evolution/e-summary-rdf.c index 015f75246e..1fe6d33003 100644 --- a/my-evolution/e-summary-rdf.c +++ b/my-evolution/e-summary-rdf.c @@ -33,8 +33,12 @@ #include <libgnome/gnome-defs.h> #include <libgnome/gnome-i18n.h> + + #include <gal/widgets/e-unicode.h> -#include <libgnomevfs/gnome-vfs.h> + +#include <libsoup/soup.h> + #include "e-summary.h" struct _ESummaryRDF { @@ -49,14 +53,14 @@ struct _ESummaryRDF { typedef struct _RDF { char *uri; char *html; - GnomeVFSAsyncHandle *handle; - GString *string; - char *buffer; xmlDocPtr cache; ESummary *summary; gboolean shown; + + /* Soup stuff */ + SoupMessage *message; } RDF; int xmlSubstituteEntitiesDefaultValue = 1; @@ -314,120 +318,35 @@ display_doc (RDF *r) } static void -close_callback (GnomeVFSAsyncHandle *handle, - GnomeVFSResult result, - RDF *r) +message_finished (SoupMessage *msg, + gpointer userdata) { - ESummary *summary; - char *xml; xmlDocPtr doc; + RDF *r = (RDF *) userdata; - summary = r->summary; - if (summary->rdf->connection->callback) { - ESummaryConnection *connection = summary->rdf->connection; - connection->callback (summary, connection->callback_closure); - } + if (SOUP_MESSAGE_IS_ERROR (msg)) { + g_warning ("Message failed: %d\n%s", msg->errorcode, + msg->errorphrase); + r->cache = NULL; + r->message = NULL; - if (r->handle == NULL) { - g_free (r->buffer); - r->buffer = NULL; - g_string_free (r->string, TRUE); - r->string = NULL; + display_doc (r); return; } - r->handle = NULL; - g_free (r->buffer); - r->buffer = NULL; - xml = r->string->str; - g_string_free (r->string, FALSE); - r->string = NULL; - if (r->cache != NULL) { xmlFreeDoc (r->cache); r->cache = NULL; } - doc = xmlParseMemory (xml, strlen (xml)); -#if 0 - if (doc == NULL) { - g_free (r->html); - r->html = g_strdup ("<b>Error parsing XML</b>"); - - e_summary_draw (r->summary); - g_free (xml); - return; - } -#endif - g_free (xml); + doc = xmlParseMemory (msg->response.body, msg->response.length); r->cache = doc; + r->message = NULL; - /* Draw it */ + /* Display it */ display_doc (r); } -static void -read_callback (GnomeVFSAsyncHandle *handle, - GnomeVFSResult result, - gpointer buffer, - GnomeVFSFileSize bytes_requested, - GnomeVFSFileSize bytes_read, - RDF *r) -{ - if (result != GNOME_VFS_OK && result != GNOME_VFS_ERROR_EOF) { - char *str; - - g_free (r->html); - str = g_strdup_printf ("<b>%s:</b><br>%s", _("Error downloading RDF"), - r->uri); - r->html = e_utf8_from_locale_string (str); - - g_free (str); - - e_summary_draw (r->summary); - r->handle = NULL; - gnome_vfs_async_close (handle, - (GnomeVFSAsyncCloseCallback) close_callback, r); - return; - } - - if (bytes_read == 0) { - gnome_vfs_async_close (handle, - (GnomeVFSAsyncCloseCallback) close_callback, r); - } else { - *((char *) buffer + bytes_read) = 0; - g_string_append (r->string, (const char *) buffer); - gnome_vfs_async_read (handle, buffer, 4095, - (GnomeVFSAsyncReadCallback) read_callback, r); - } -} - -static void -open_callback (GnomeVFSAsyncHandle *handle, - GnomeVFSResult result, - RDF *r) -{ - if (result != GNOME_VFS_OK) { - char *str; - - r->handle = NULL; - g_free (r->html); - str = g_strdup_printf ("<b>%s:</b><br>%s", _("Error downloading RDF"), - r->uri); - r->html = e_utf8_from_locale_string (str); - g_free (str); - - display_doc (r); - return; - } - - r->string = g_string_new (""); - r->buffer = g_new (char, 4096); - - gnome_vfs_async_read (handle, r->buffer, 4095, - (GnomeVFSAsyncReadCallback) read_callback, r); -} - gboolean e_summary_rdf_update (ESummary *summary) { @@ -439,27 +358,23 @@ e_summary_rdf_update (ESummary *summary) } for (r = summary->rdf->rdfs; r; r = r->next) { + SoupContext *context; RDF *rdf = r->data; - if (rdf->handle) { - gnome_vfs_async_cancel (rdf->handle); - rdf->handle = NULL; + if (rdf->message) { + soup_message_cancel (rdf->message); } - if (rdf->buffer) { - g_free (rdf->buffer); - rdf->buffer = NULL; - } - - if (rdf->string) { - g_string_free (rdf->string, TRUE); - rdf->string = NULL; + context = soup_context_get (rdf->uri); + if (context == NULL) { + g_warning ("Invalid URL: %s", rdf->uri); + soup_context_unref (context); + continue; } - g_warning ("Opening %s", rdf->uri); - gnome_vfs_async_open (&rdf->handle, rdf->uri, - GNOME_VFS_OPEN_READ, - (GnomeVFSAsyncOpenCallback) open_callback, rdf); + rdf->message = soup_message_new (context, SOUP_METHOD_GET); + soup_context_unref (context); + soup_message_queue (rdf->message, message_finished, rdf); } return TRUE; @@ -510,7 +425,7 @@ e_summary_rdf_count (ESummary *summary, for (p = rdf->rdfs; p; p = p->next) { RDF *r = p->data; - if (r->handle != NULL) { + if (r->message != NULL) { count++; } } @@ -541,7 +456,7 @@ e_summary_rdf_add (ESummary *summary, for (p = rdf->rdfs; p; p = p->next) { RDF *r = p->data; - if (r->handle != NULL) { + if (r->message != NULL) { ESummaryConnectionData *d; d = make_connection (r); @@ -556,17 +471,12 @@ static void rdf_free (RDF *r) { /* Stop the download */ - if (r->handle) { - gnome_vfs_async_cancel (r->handle); + if (r->message) { + soup_message_cancel (r->message); } g_free (r->uri); g_free (r->html); - g_free (r->buffer); - - if (r->string) { - g_string_free (r->string, TRUE); - } if (r->cache) { xmlFreeDoc (r->cache); @@ -599,9 +509,9 @@ e_summary_rdf_set_online (ESummary *summary, RDF *r; r = p->data; - if (r->handle) { - gnome_vfs_async_cancel (r->handle); - r->handle = NULL; + if (r->message) { + soup_message_cancel (r->message); + r->message = NULL; } } |