X-Git-Url: http://git.maemo.org/git/?a=blobdiff_plain;f=src%2Fwidgets%2Fmodest-tny-stream-gtkhtml.c;h=d01fae29e03133f771743a6ed84e82e00cb5ea6a;hb=d1db55141f6b645c376ddda0c9f3aef773708670;hp=af053337f2f57a7f3598b762e39e1cdeffd8dc5b;hpb=94dd9606eadbd7df971e7abc458bbbd903cdc772;p=modest diff --git a/src/widgets/modest-tny-stream-gtkhtml.c b/src/widgets/modest-tny-stream-gtkhtml.c index af05333..d01fae2 100644 --- a/src/widgets/modest-tny-stream-gtkhtml.c +++ b/src/widgets/modest-tny-stream-gtkhtml.c @@ -31,6 +31,7 @@ /* modest-tny-stream-gtkhtml.c */ #include "modest-tny-stream-gtkhtml.h" +#include "modest-gtkhtml-mime-part-view.h" #include #include #include @@ -42,6 +43,8 @@ static void modest_tny_stream_gtkhtml_finalize (GObject *obj); static void modest_tny_stream_gtkhml_iface_init (gpointer g_iface, gpointer iface_data); +static void stop_streams (ModestGtkhtmlMimePartView *view, gpointer userdata); + /* list my signals */ enum { /* MY_SIGNAL_1, */ @@ -52,6 +55,8 @@ enum { typedef struct _ModestTnyStreamGtkhtmlPrivate ModestTnyStreamGtkhtmlPrivate; struct _ModestTnyStreamGtkhtmlPrivate { GtkHTMLStream *stream; + GtkHTML *html; + guint stop_streams_id; }; #define MODEST_TNY_STREAM_GTKHTML_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE((o), \ MODEST_TYPE_TNY_STREAM_GTKHTML, \ @@ -116,6 +121,8 @@ modest_tny_stream_gtkhtml_init (ModestTnyStreamGtkhtml *obj) priv = MODEST_TNY_STREAM_GTKHTML_GET_PRIVATE(obj); priv->stream = NULL; + priv->html = NULL; + priv->stop_streams_id = 0; } static void @@ -125,10 +132,20 @@ modest_tny_stream_gtkhtml_finalize (GObject *obj) priv = MODEST_TNY_STREAM_GTKHTML_GET_PRIVATE(obj); priv->stream = NULL; + + if (priv->stop_streams_id > 0) { + g_signal_handler_disconnect (G_OBJECT (priv->html), priv->stop_streams_id); + priv->stop_streams_id = 0; + } + + if (priv->html) { + g_object_unref (priv->html); + priv->html = NULL; + } } GObject* -modest_tny_stream_gtkhtml_new (GtkHTMLStream *stream) +modest_tny_stream_gtkhtml_new (GtkHTMLStream *stream, GtkHTML *html) { GObject *obj; ModestTnyStreamGtkhtmlPrivate *priv; @@ -139,6 +156,10 @@ modest_tny_stream_gtkhtml_new (GtkHTMLStream *stream) g_return_val_if_fail (stream, NULL); priv->stream = stream; + priv->html = g_object_ref (html); + + priv->stop_streams_id = g_signal_connect (G_OBJECT (html), "stop-streams", + G_CALLBACK (stop_streams), obj); return obj; } @@ -168,7 +189,10 @@ gtkhtml_write (TnyStream *self, const char *buffer, size_t n) if (n == 0 || !buffer) return 0; - + + if (!priv->html || !GTK_WIDGET_VISIBLE (priv->html)) + return -1; + gtk_html_stream_write (priv->stream, buffer, n); return n; /* hmmm */ } @@ -188,8 +212,18 @@ gtkhtml_close (TnyStream *self) g_return_val_if_fail (self, 0); priv = MODEST_TNY_STREAM_GTKHTML_GET_PRIVATE(self); - gtk_html_stream_close (priv->stream, GTK_HTML_STREAM_OK); + if (priv->html && GTK_WIDGET_VISIBLE (priv->html)) { + gtk_html_stream_close (priv->stream, GTK_HTML_STREAM_OK); + } priv->stream = NULL; + if (priv->html && priv->stop_streams_id > 0) { + g_signal_handler_disconnect (G_OBJECT (priv->html), priv->stop_streams_id); + priv->stop_streams_id = 0; + } + if (priv->html) { + g_object_unref (priv->html); + priv->html = NULL; + } return 0; } @@ -216,6 +250,25 @@ gtkhtml_write_to_stream (TnyStream *self, TnyStream *output) return 0; } +static void +stop_streams (ModestGtkhtmlMimePartView *view, gpointer userdata) +{ + ModestTnyStreamGtkhtml *self = (ModestTnyStreamGtkhtml *) userdata; + ModestTnyStreamGtkhtmlPrivate *priv; + + g_return_if_fail (self); + priv = MODEST_TNY_STREAM_GTKHTML_GET_PRIVATE(self); + + if (priv->html && priv->stop_streams_id > 0) { + g_signal_handler_disconnect (G_OBJECT (priv->html), priv->stop_streams_id); + priv->stop_streams_id = 0; + } + + if (priv->html) { + g_object_unref (priv->html); + priv->html = NULL; + } +} static void modest_tny_stream_gtkhml_iface_init (gpointer g_iface, gpointer iface_data)