Mercurial > pidgin
changeset 11951:b6fa01513d76
[gaim-migrate @ 14242]
sf patch #1343345, from Sadrul Habib Chowdhury
This is a pretty rockin' patch that makes our statusbox not
emit the changed signal when we set the status programatically.
It fixes "gaim -n" and selecting either of the saved status options
committer: Tailor Script <tailor@pidgin.im>
author | Mark Doliner <mark@kingant.net> |
---|---|
date | Wed, 02 Nov 2005 05:14:35 +0000 (2005-11-02) |
parents | 2b9ca8861ca5 |
children | 565d2e437c04 |
files | src/gtkstatusbox.c |
diffstat | 1 files changed, 44 insertions(+), 17 deletions(-) [+] |
line wrap: on
line diff
--- a/src/gtkstatusbox.c Wed Nov 02 04:41:40 2005 +0000 +++ b/src/gtkstatusbox.c Wed Nov 02 05:14:35 2005 +0000 @@ -289,6 +289,13 @@ current_savedstatus_name = gaim_prefs_get_string("/core/status/current"); saved_status = gaim_savedstatus_find(current_savedstatus_name); + + /* + * Suppress the "changed" signal because the status + * was changed programmatically. + */ + gtk_widget_set_sensitive(GTK_WIDGET(status_box), FALSE); + if (saved_status == NULL) { /* Default to "available" */ @@ -322,8 +329,19 @@ message = gaim_savedstatus_get_message(saved_status); if (message != NULL) + { + /* + * Suppress the "changed" signal because the status + * was changed programmatically. + */ + gtk_widget_set_sensitive(GTK_WIDGET(status_box->imhtml), FALSE); gtk_imhtml_append_text(GTK_IMHTML(status_box->imhtml), message, 0); + gtk_widget_set_sensitive(GTK_WIDGET(status_box->imhtml), TRUE); + } } + + /* Stop suppressing the "changed" signal. */ + gtk_widget_set_sensitive(GTK_WIDGET(status_box), TRUE); } static void @@ -659,7 +677,8 @@ char *message; GaimSavedStatus *saved_status; - gtk_combo_box_get_active_iter(GTK_COMBO_BOX(status_box), &iter); + if (!gtk_combo_box_get_active_iter(GTK_COMBO_BOX(status_box), &iter)) + return; gtk_tree_model_get(GTK_TREE_MODEL(status_box->dropdown_store), &iter, TYPE_COLUMN, &type, TITLE_COLUMN, &title, -1); @@ -728,18 +747,21 @@ g_source_remove(status_box->typing); status_box->typing = 0; - if (type == GTK_GAIM_STATUS_BOX_TYPE_CUSTOM) + if (GTK_WIDGET_IS_SENSITIVE(GTK_WIDGET(status_box))) { - gaim_gtk_status_editor_show(NULL); - update_to_reflect_current_status(status_box); - return; - } + if (type == GTK_GAIM_STATUS_BOX_TYPE_CUSTOM) + { + gaim_gtk_status_editor_show(NULL); + update_to_reflect_current_status(status_box); + return; + } - if (type == GTK_GAIM_STATUS_BOX_TYPE_SAVED) - { - gaim_gtk_status_window_show(); - update_to_reflect_current_status(status_box); - return; + if (type == GTK_GAIM_STATUS_BOX_TYPE_SAVED) + { + gaim_gtk_status_window_show(); + update_to_reflect_current_status(status_box); + return; + } } /* @@ -767,14 +789,16 @@ if (status_box->imhtml_visible) { gtk_widget_show_all(status_box->vbox); - status_box->typing = g_timeout_add(3000, (GSourceFunc)remove_typing_cb, status_box); + if (GTK_WIDGET_IS_SENSITIVE(GTK_WIDGET(status_box))) + status_box->typing = g_timeout_add(3000, (GSourceFunc)remove_typing_cb, status_box); gtk_imhtml_clear(GTK_IMHTML(status_box->imhtml)); gtk_widget_grab_focus(status_box->imhtml); } else { gtk_widget_hide_all(status_box->vbox); - activate_currently_selected_status(status_box); + if (GTK_WIDGET_IS_SENSITIVE(GTK_WIDGET(status_box))) + activate_currently_selected_status(status_box); } gtk_gaim_status_box_refresh(status_box); } @@ -782,11 +806,14 @@ static void imhtml_changed_cb(GtkTextBuffer *buffer, void *data) { GtkGaimStatusBox *box = (GtkGaimStatusBox*)data; - if (box->typing) { - gtk_gaim_status_box_pulse_typing(box); - g_source_remove(box->typing); + if (GTK_WIDGET_IS_SENSITIVE(GTK_WIDGET(box))) + { + if (box->typing) { + gtk_gaim_status_box_pulse_typing(box); + g_source_remove(box->typing); + } + box->typing = g_timeout_add(3000, (GSourceFunc)remove_typing_cb, box); } - box->typing = g_timeout_add(3000, (GSourceFunc)remove_typing_cb, box); gtk_gaim_status_box_refresh(box); }