[balsa/72-message-window] message-window: Wait for "changed" signal
- From: Peter Bloomfield <peterb src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [balsa/72-message-window] message-window: Wait for "changed" signal
- Date: Mon, 4 Apr 2022 15:54:05 +0000 (UTC)
commit befb1f2e1749d552ff2955760d5b329b5791eb0d
Author: Peter Bloomfield <PeterBloomfield bellsouth net>
Date: Sun Apr 3 18:27:50 2022 -0400
message-window: Wait for "changed" signal
from BalsaIndex before fetching the new msgno and displaying the
corresponding LibBalsaMessage.
Contributes to https://gitlab.gnome.org/GNOME/balsa/-/issues/72
src/message-window.c | 37 +++++++++++++++++++++++++++++++++----
1 file changed, 33 insertions(+), 4 deletions(-)
---
diff --git a/src/message-window.c b/src/message-window.c
index 933774c3c..46c5413b3 100644
--- a/src/message-window.c
+++ b/src/message-window.c
@@ -52,6 +52,7 @@ struct _MessageWindow {
int headers_shown;
int show_all_headers;
guint idle_handler_id;
+ guint index_changed_id;
};
/*
@@ -367,6 +368,11 @@ static void
destroy_message_window(GtkWidget * widget, MessageWindow * mw)
{
if (mw->bindex) { /* BalsaIndex still exists */
+ if (mw->index_changed_id != 0) {
+ g_signal_handler_disconnect(mw->bindex, mw->index_changed_id);
+ mw->index_changed_id = 0;
+ }
+
g_object_weak_unref(G_OBJECT(mw->bindex), mw_bindex_closed_cb, mw);
g_signal_handlers_disconnect_matched(mw->bindex,
G_SIGNAL_MATCH_DATA, 0, 0,
@@ -566,16 +572,25 @@ mw_find_in_message_activated(GSimpleAction * action, GVariant * parameter,
balsa_message_find_in_message(BALSA_MESSAGE(mw->bmessage));
}
+/*
+ * Handler for BalsaIndex "index-changed" signal
+ *
+ * We connect to this signal in mw_set_selected(), after calling select_func(),
+ * to find the msgno of the newly selected message, and immediately disconnect it. *
+ */
static void
-mw_set_selected(MessageWindow * mw, void (*select_func) (BalsaIndex *))
+mw_index_changed(BalsaIndex *bindex,
+ gpointer user_data)
{
+ MessageWindow *mw = user_data;
guint msgno;
LibBalsaMessage *message;
MessageWindow *tmp;
- balsa_index_set_next_msgno(mw->bindex, libbalsa_message_get_msgno(mw->message));
- select_func(mw->bindex);
- msgno = balsa_index_get_next_msgno(mw->bindex);
+ g_signal_handler_disconnect(bindex, mw->index_changed_id);
+ mw->index_changed_id = 0;
+
+ msgno = balsa_index_get_next_msgno(bindex);
message = libbalsa_mailbox_get_message(libbalsa_message_get_mailbox(mw->message), msgno);
if (!message)
return;
@@ -595,6 +610,20 @@ mw_set_selected(MessageWindow * mw, void (*select_func) (BalsaIndex *))
mw_set_message(mw, message);
}
+static void
+mw_set_selected(MessageWindow * mw, void (*select_func) (BalsaIndex *))
+{
+ /* We must wait until the BalsaIndex's "selection-changed" signal is
+ * handled, as it seems to no longer be synchronous. */
+ if (mw->index_changed_id == 0) {
+ mw->index_changed_id = g_signal_connect(mw->bindex, "index-changed",
+ G_CALLBACK(mw_index_changed), mw);
+ }
+
+ balsa_index_set_next_msgno(mw->bindex, libbalsa_message_get_msgno(mw->message));
+ select_func(mw->bindex);
+}
+
static void
message_window_move_message(MessageWindow * mw, LibBalsaMailbox * mailbox)
{
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]