# HG changeset patch # User Richard Laager # Date 1136342471 0 # Node ID 2d326453b33d772724168533104be3a754691e90 # Parent b4bd3b41bf3b083fbad104ead53c46d6c744f506 [gaim-migrate @ 15054] Make the context-menu send item do its work by firing the message_send signal, instead of calling the internal callback directly. Change the message_send handlers to connect after the default handler. This way, we can be sure that plugins can block the message from being sent, at a UI level. I'm not sure if that was strictly necessary, but it shouldn't hurt anything. committer: Tailor Script diff -r b4bd3b41bf3b -r 2d326453b33d src/gtkconv.c --- a/src/gtkconv.c Wed Jan 04 02:38:56 2006 +0000 +++ b/src/gtkconv.c Wed Jan 04 02:41:11 2006 +0000 @@ -3616,6 +3616,11 @@ buddy_cb_common(buddy, conv, FALSE); } +static void send_menu_cb(GtkWidget *widget, GaimGtkConversation *gtkconv) +{ + g_signal_emit_by_name(gtkconv->entry, "message_send"); +} + static void entry_popup_menu_cb(GtkIMHtml *imhtml, GtkMenu *menu, gpointer data) { @@ -3626,7 +3631,7 @@ g_return_if_fail(gtkconv != NULL); menuitem = gaim_new_item_from_stock(NULL, _("_Send"), GAIM_STOCK_SEND, - G_CALLBACK(send_cb), gtkconv, + G_CALLBACK(send_menu_cb), gtkconv, 0, 0, NULL); if (gtk_text_buffer_get_char_count(imhtml->text_buffer) == 0) gtk_widget_set_sensitive(menuitem, FALSE); @@ -3868,8 +3873,8 @@ g_signal_connect(G_OBJECT(gtkconv->entry), "key_press_event", G_CALLBACK(entry_key_press_cb), gtkconv); - g_signal_connect(G_OBJECT(gtkconv->entry), "message_send", - G_CALLBACK(send_cb), gtkconv); + g_signal_connect_after(G_OBJECT(gtkconv->entry), "message_send", + G_CALLBACK(send_cb), gtkconv); g_signal_connect_after(G_OBJECT(gtkconv->entry), "button_press_event", G_CALLBACK(entry_stop_rclick_cb), NULL); g_signal_connect(G_OBJECT(gtkconv->entry), "size-allocate", @@ -3959,7 +3964,8 @@ g_signal_connect(G_OBJECT(gtkconv->entry), "key_press_event", G_CALLBACK(entry_key_press_cb), gtkconv); - g_signal_connect(G_OBJECT(gtkconv->entry), "message_send", G_CALLBACK(send_cb), gtkconv); + g_signal_connect_after(G_OBJECT(gtkconv->entry), "message_send", + G_CALLBACK(send_cb), gtkconv); g_signal_connect_after(G_OBJECT(gtkconv->entry), "button_press_event", G_CALLBACK(entry_stop_rclick_cb), NULL); g_signal_connect(G_OBJECT(gtkconv->entry), "size-allocate",