diff options
author | Matthew Barnes <mbarnes@redhat.com> | 2012-10-10 04:55:08 +0800 |
---|---|---|
committer | Matthew Barnes <mbarnes@redhat.com> | 2012-10-10 05:02:30 +0800 |
commit | dbd8378954fe3161aba153821ec04060235c17fa (patch) | |
tree | 6be00aa80e6b31283624fa0439cbebf9b6a5e236 | |
parent | 092a504759f8966c9e37c7cdd079f98290be4c07 (diff) | |
download | gsoc2013-evolution-dbd8378954fe3161aba153821ec04060235c17fa.tar gsoc2013-evolution-dbd8378954fe3161aba153821ec04060235c17fa.tar.gz gsoc2013-evolution-dbd8378954fe3161aba153821ec04060235c17fa.tar.bz2 gsoc2013-evolution-dbd8378954fe3161aba153821ec04060235c17fa.tar.lz gsoc2013-evolution-dbd8378954fe3161aba153821ec04060235c17fa.tar.xz gsoc2013-evolution-dbd8378954fe3161aba153821ec04060235c17fa.tar.zst gsoc2013-evolution-dbd8378954fe3161aba153821ec04060235c17fa.zip |
Bug 684691 - EMailConfigFormatHTML: Signal handler never disconnected
EMailConfigFormatHTML listens for "changed" signals from a GSettings
instance, passing itself as the 'user_data' to the signal handler. But
the signal handler was left connected after EMailConfigFormatHTML was
finalized, resulting in the signal handler receiving a dangling pointer.
Not using g_signal_connect_object() here because of the unresolved
reference leak issue in GObject. The GSettings instance is likely
cached internally and lives well beyond the EMailConfigFormatHTML.
(cherry picked from commit 4483209dba2d421d814fae5dc31e5597fcacd612)
-rw-r--r-- | modules/mail/e-mail-config-format-html.c | 92 |
1 files changed, 59 insertions, 33 deletions
diff --git a/modules/mail/e-mail-config-format-html.c b/modules/mail/e-mail-config-format-html.c index 40edc7df9e..d2df6b9c42 100644 --- a/modules/mail/e-mail-config-format-html.c +++ b/modules/mail/e-mail-config-format-html.c @@ -32,7 +32,8 @@ ((obj), E_TYPE_MAIL_CONFIG_FORMAT_HTML, EMailConfigFormatHTMLPrivate)) struct _EMailConfigFormatHTMLPrivate { - gint placeholder; + GSettings *settings; + gulong headers_changed_id; }; G_DEFINE_DYNAMIC_TYPE ( @@ -40,23 +41,26 @@ G_DEFINE_DYNAMIC_TYPE ( e_mail_config_format_html, E_TYPE_EXTENSION) -static void -headers_changed_cb (GSettings *settings, - const gchar *key, - gpointer user_data) +static EMailFormatter * +mail_config_format_html_get_formatter (EMailConfigFormatHTML *extension) { - gint ii; - gchar **headers; - EExtension *extension; - EMailFormatter *formatter; + EExtensible *extensible; + + extensible = e_extension_get_extensible (E_EXTENSION (extension)); - g_return_if_fail (settings != NULL); + return E_MAIL_FORMATTER (extensible); +} - if (key && !g_str_equal (key, "headers")) - return; +static void +mail_config_format_html_headers_changed_cb (GSettings *settings, + const gchar *key, + EMailConfigFormatHTML *extension) +{ + EMailFormatter *formatter; + gchar **headers; + gint ii; - extension = user_data; - formatter = E_MAIL_FORMATTER (e_extension_get_extensible (extension)); + formatter = mail_config_format_html_get_formatter (extension); headers = g_settings_get_strv (settings, "headers"); @@ -81,66 +85,84 @@ headers_changed_cb (GSettings *settings, } static void +mail_config_format_html_dispose (GObject *object) +{ + EMailConfigFormatHTMLPrivate *priv; + + priv = E_MAIL_CONFIG_FORMAT_HTML_GET_PRIVATE (object); + + if (priv->settings != NULL) { + g_signal_handler_disconnect ( + priv->settings, + priv->headers_changed_id); + g_object_unref (priv->settings); + priv->settings = NULL; + } + + /* Chain up to parent's dispose() method. */ + G_OBJECT_CLASS (e_mail_config_format_html_parent_class)-> + dispose (object); +} + +static void mail_config_format_html_constructed (GObject *object) { - EExtension *extension; - EExtensible *extensible; + EMailConfigFormatHTML *extension; + EMailFormatter *formatter; EShellSettings *shell_settings; EShell *shell; - GSettings *settings; - extension = E_EXTENSION (object); - extensible = e_extension_get_extensible (extension); + extension = E_MAIL_CONFIG_FORMAT_HTML (object); + formatter = mail_config_format_html_get_formatter (extension); shell = e_shell_get_default (); shell_settings = e_shell_get_shell_settings (shell); g_object_bind_property_full ( shell_settings, "mail-citation-color", - extensible, "citation-color", + formatter, "citation-color", G_BINDING_SYNC_CREATE, e_binding_transform_string_to_color, NULL, NULL, (GDestroyNotify) NULL); g_object_bind_property ( shell_settings, "mail-mark-citations", - extensible, "mark-citations", + formatter, "mark-citations", G_BINDING_SYNC_CREATE); g_object_bind_property ( shell_settings, "mail-image-loading-policy", - extensible, "image-loading-policy", + formatter, "image-loading-policy", G_BINDING_SYNC_CREATE); g_object_bind_property ( shell_settings, "mail-only-local-photos", - extensible, "only-local-photos", + formatter, "only-local-photos", G_BINDING_SYNC_CREATE); g_object_bind_property ( shell_settings, "mail-show-sender-photo", - extensible, "show-sender-photo", + formatter, "show-sender-photo", G_BINDING_SYNC_CREATE); g_object_bind_property ( shell_settings, "mail-show-real-date", - extensible, "show-real-date", + formatter, "show-real-date", G_BINDING_SYNC_CREATE); g_object_bind_property ( shell_settings, "mail-show-animated-images", - extensible, "animate-images", + formatter, "animate-images", G_BINDING_SYNC_CREATE); - settings = g_settings_new ("org.gnome.evolution.mail"); - g_signal_connect (settings, "changed", G_CALLBACK (headers_changed_cb), object); - - g_object_set_data_full ( - G_OBJECT (extensible), "reader-header-settings", - settings, g_object_unref); + extension->priv->headers_changed_id = g_signal_connect ( + extension->priv->settings, "changed::headers", + G_CALLBACK (mail_config_format_html_headers_changed_cb), + extension); /* Initial synchronization */ - headers_changed_cb (settings, NULL, object); + mail_config_format_html_headers_changed_cb ( + extension->priv->settings, NULL, extension); /* Chain up to parent's constructed() method. */ G_OBJECT_CLASS (e_mail_config_format_html_parent_class)-> @@ -157,6 +179,7 @@ e_mail_config_format_html_class_init (EMailConfigFormatHTMLClass *class) class, sizeof (EMailConfigFormatHTMLPrivate)); object_class = G_OBJECT_CLASS (class); + object_class->dispose = mail_config_format_html_dispose; object_class->constructed = mail_config_format_html_constructed; extension_class = E_EXTENSION_CLASS (class); @@ -172,6 +195,9 @@ static void e_mail_config_format_html_init (EMailConfigFormatHTML *extension) { extension->priv = E_MAIL_CONFIG_FORMAT_HTML_GET_PRIVATE (extension); + + extension->priv->settings = + g_settings_new ("org.gnome.evolution.mail"); } void |