aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorXavier Claessens <xclaesse@src.gnome.org>2008-10-13 16:04:35 +0800
committerXavier Claessens <xclaesse@src.gnome.org>2008-10-13 16:04:35 +0800
commited0d44f1527cf59372aaa30c0405a99f5a6f72fe (patch)
treef3279bf55df0167a56a59b70f1d8b67a8f662947
parentf872b96ad8daa7cf25e3fac233a633922bb33a59 (diff)
downloadgsoc2013-empathy-ed0d44f1527cf59372aaa30c0405a99f5a6f72fe.tar
gsoc2013-empathy-ed0d44f1527cf59372aaa30c0405a99f5a6f72fe.tar.gz
gsoc2013-empathy-ed0d44f1527cf59372aaa30c0405a99f5a6f72fe.tar.bz2
gsoc2013-empathy-ed0d44f1527cf59372aaa30c0405a99f5a6f72fe.tar.lz
gsoc2013-empathy-ed0d44f1527cf59372aaa30c0405a99f5a6f72fe.tar.xz
gsoc2013-empathy-ed0d44f1527cf59372aaa30c0405a99f5a6f72fe.tar.zst
gsoc2013-empathy-ed0d44f1527cf59372aaa30c0405a99f5a6f72fe.zip
empathy-contact-menu.c: store the chatroom instead of the channel in contact_room_sub_menu_item_activate_cb_ctx
svn path=/trunk/; revision=1585
-rw-r--r--libempathy-gtk/empathy-contact-menu.c25
1 files changed, 13 insertions, 12 deletions
diff --git a/libempathy-gtk/empathy-contact-menu.c b/libempathy-gtk/empathy-contact-menu.c
index caf59fc8a..609b5ba16 100644
--- a/libempathy-gtk/empathy-contact-menu.c
+++ b/libempathy-gtk/empathy-contact-menu.c
@@ -243,19 +243,19 @@ empathy_contact_edit_menu_item_new (EmpathyContact *contact)
typedef struct
{
EmpathyContact *contact;
- TpChannel *channel;
+ EmpathyChatroom *chatroom;
} contact_room_sub_menu_item_activate_cb_ctx;
static contact_room_sub_menu_item_activate_cb_ctx *
contact_room_sub_menu_item_activate_cb_ctx_new (EmpathyContact *contact,
- TpChannel *channel)
+ EmpathyChatroom *chatroom)
{
contact_room_sub_menu_item_activate_cb_ctx *ctx;
ctx = g_slice_new (contact_room_sub_menu_item_activate_cb_ctx);
ctx->contact = g_object_ref (contact);
- ctx->channel = g_object_ref (channel);
+ ctx->chatroom = g_object_ref (chatroom);
return ctx;
}
@@ -266,7 +266,7 @@ contact_room_sub_menu_item_activate_cb_ctx_free (
{
/* FIXME: seems this is never called... */
g_object_unref (ctx->contact);
- g_object_unref (ctx->channel);
+ g_object_unref (ctx->chatroom);
g_slice_free (contact_room_sub_menu_item_activate_cb_ctx, ctx);
}
@@ -278,16 +278,23 @@ contact_room_sub_menu_item_activate_cb (
{
GArray *handles;
TpHandle handle;
+ TpChannel *channel;
+
+ g_object_get (ctx->chatroom, "tp-channel", &channel, NULL);
+ if (channel == NULL)
+ /* channel was invalidated. Ignoring */
+ return;
/* send invitation */
handles = g_array_new (FALSE, FALSE, sizeof (TpHandle));
handle = empathy_contact_get_handle (ctx->contact);
g_array_append_val (handles, handle);
- tp_cli_channel_interface_group_call_add_members (ctx->channel, -1, handles,
+ tp_cli_channel_interface_group_call_add_members (channel, -1, handles,
_("Inviting to this room"), NULL, NULL, NULL, NULL);
g_array_free (handles, TRUE);
+ g_object_unref (channel);
}
static GtkWidget *
@@ -295,24 +302,18 @@ create_room_sub_menu_item (EmpathyContact *contact,
EmpathyChatroom *chatroom)
{
GtkWidget *item;
- TpChannel *channel;
contact_room_sub_menu_item_activate_cb_ctx *ctx;
g_return_val_if_fail (EMPATHY_IS_CONTACT (contact), NULL);
item = gtk_menu_item_new_with_label (empathy_chatroom_get_name (chatroom));
- g_object_get (chatroom, "tp-channel", &channel, NULL);
- g_assert (channel != NULL);
-
- ctx = contact_room_sub_menu_item_activate_cb_ctx_new (contact, channel);
+ ctx = contact_room_sub_menu_item_activate_cb_ctx_new (contact, chatroom);
g_signal_connect_data (item, "activate",
G_CALLBACK (contact_room_sub_menu_item_activate_cb), ctx,
(GClosureNotify) contact_room_sub_menu_item_activate_cb_ctx_free, 0);
- g_object_unref (channel);
-
return item;
}