diff options
author | Milan Crha <mcrha@redhat.com> | 2009-12-23 18:06:36 +0800 |
---|---|---|
committer | Milan Crha <mcrha@redhat.com> | 2009-12-23 18:06:36 +0800 |
commit | 6ba2bdcb5134c15af4f370a75240e54288210331 (patch) | |
tree | bab22200dcf1a530757481bb5430a2d9fbbac017 /mail | |
parent | 05c11c2cee07576e60963aa91ede71a6ecb6bea2 (diff) | |
download | gsoc2013-evolution-6ba2bdcb5134c15af4f370a75240e54288210331.tar gsoc2013-evolution-6ba2bdcb5134c15af4f370a75240e54288210331.tar.gz gsoc2013-evolution-6ba2bdcb5134c15af4f370a75240e54288210331.tar.bz2 gsoc2013-evolution-6ba2bdcb5134c15af4f370a75240e54288210331.tar.lz gsoc2013-evolution-6ba2bdcb5134c15af4f370a75240e54288210331.tar.xz gsoc2013-evolution-6ba2bdcb5134c15af4f370a75240e54288210331.tar.zst gsoc2013-evolution-6ba2bdcb5134c15af4f370a75240e54288210331.zip |
Bug #595501 - Crash on a changed mail filter action removal
Diffstat (limited to 'mail')
-rw-r--r-- | mail/em-filter-rule.c | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/mail/em-filter-rule.c b/mail/em-filter-rule.c index b6349b61ba..aa72175111 100644 --- a/mail/em-filter-rule.c +++ b/mail/em-filter-rule.c @@ -373,6 +373,9 @@ get_rule_part_widget(EMFilterContext *f, EFilterPart *newpart, EFilterRule *fr) data->part = newpart; hbox = gtk_hbox_new(FALSE, 0); + /* only set to automatically clean up the memory and for less_parts */ + g_object_set_data_full ((GObject *) hbox, "data", data, g_free); + p = e_filter_part_get_widget(newpart); data->partwidget = p; @@ -412,6 +415,7 @@ less_parts(GtkWidget *button, struct _rule_data *data) { EFilterPart *part; GtkWidget *rule; + struct _part_data *part_data; GList *l; l =((EMFilterRule *)data->fr)->actions; @@ -419,7 +423,11 @@ less_parts(GtkWidget *button, struct _rule_data *data) return; rule = g_object_get_data((GObject *)button, "rule"); - part = g_object_get_data((GObject *)rule, "part"); + part_data = g_object_get_data ((GObject *) rule, "data"); + + g_return_if_fail (part_data != NULL); + + part = part_data->part; /* remove the part from the list */ em_filter_rule_remove_action((EMFilterRule *)data->fr, part); @@ -440,7 +448,6 @@ attach_rule(GtkWidget *rule, struct _rule_data *data, EFilterPart *part, gint ro remove = gtk_button_new_from_stock(GTK_STOCK_REMOVE); g_object_set_data((GObject *)remove, "rule", rule); - g_object_set_data((GObject *)rule, "part", part); /*gtk_button_set_relief(GTK_BUTTON(remove), GTK_RELIEF_NONE);*/ g_signal_connect(remove, "clicked", G_CALLBACK(less_parts), data); gtk_table_attach(GTK_TABLE(data->parts), remove, 1, 2, row, row + 1, @@ -544,6 +551,9 @@ get_widget(EFilterRule *fr, ERuleContext *rc) data->fr = fr; data->parts = parts; + /* only set to automatically clean up the memory */ + g_object_set_data_full ((GObject *) hbox, "data", data, g_free); + hbox = gtk_hbox_new(FALSE, 3); add = gtk_button_new_with_mnemonic (_("Add Ac_tion")); |