From 8978c0d955186405e291a7ff2ac71a063cdb9e68 Mon Sep 17 00:00:00 2001 From: Guillaume Desmottes Date: Thu, 3 Feb 2011 11:02:35 +0100 Subject: individual-menu: ensure that the contact stays alive while the activate signal is connected (#641119) --- libempathy-gtk/empathy-individual-menu.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) (limited to 'libempathy-gtk/empathy-individual-menu.c') diff --git a/libempathy-gtk/empathy-individual-menu.c b/libempathy-gtk/empathy-individual-menu.c index 29ead4fb0..76d708156 100644 --- a/libempathy-gtk/empathy-individual-menu.c +++ b/libempathy-gtk/empathy-individual-menu.c @@ -460,8 +460,10 @@ menu_item_set_contact (GtkWidget *item, if (can_do_action == TRUE) { - g_signal_connect (item, "activate", G_CALLBACK (activate_callback), - contact); + /* We want to make sure that the EmpathyContact stays alive while the + * signal is connected. */ + g_signal_connect_data (item, "activate", G_CALLBACK (activate_callback), + g_object_ref (contact), (GClosureNotify) g_object_unref, 0); } return can_do_action; -- cgit v1.2.3