aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatthew Barnes <mbarnes@redhat.com>2012-10-10 04:55:08 +0800
committerMatthew Barnes <mbarnes@redhat.com>2012-10-10 05:02:30 +0800
commitdbd8378954fe3161aba153821ec04060235c17fa (patch)
tree6be00aa80e6b31283624fa0439cbebf9b6a5e236
parent092a504759f8966c9e37c7cdd079f98290be4c07 (diff)
downloadgsoc2013-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.c92
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