[balsa/gtk4] message-window: Do not use gtk_widget_show()
- From: Peter Bloomfield <peterb src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [balsa/gtk4] message-window: Do not use gtk_widget_show()
- Date: Sat, 31 Oct 2020 21:22:27 +0000 (UTC)
commit 63d40785679b91ffc3a72bc19315178cf84e292d
Author: Peter Bloomfield <PeterBloomfield bellsouth net>
Date: Sat Oct 31 15:57:18 2020 -0400
message-window: Do not use gtk_widget_show()
when not needed.
src/message-window.c | 128 ++++++++++++++++++++++++++++-----------------------
1 file changed, 70 insertions(+), 58 deletions(-)
---
diff --git a/src/message-window.c b/src/message-window.c
index 1e9be203f..047874877 100644
--- a/src/message-window.c
+++ b/src/message-window.c
@@ -114,22 +114,23 @@ mw_set_part_buttons_sensitive(MessageWindow * mw, BalsaMessage * msg)
}
static gboolean
-message_window_idle_handler(MessageWindow * mw)
+message_window_idle_handler(gpointer user_data)
{
+ MessageWindow *mw = user_data;
BalsaMessage *msg;
mw->idle_handler_id = 0;
msg = BALSA_MESSAGE(mw->bmessage);
- if (!balsa_message_set(msg,
- libbalsa_message_get_mailbox(mw->message),
- libbalsa_message_get_msgno(mw->message))) {
- gtk_widget_destroy(mw->window);
- return FALSE;
+ if (balsa_message_set(msg,
+ libbalsa_message_get_mailbox(mw->message),
+ libbalsa_message_get_msgno(mw->message))) {
+ balsa_message_grab_focus(msg);
+ } else {
+ gtk_window_destroy(GTK_WINDOW(mw->window));
}
- balsa_message_grab_focus(msg);
- return FALSE;
+ return G_SOURCE_REMOVE;
}
/* ===================================================================
@@ -200,7 +201,7 @@ mw_bindex_closed_cb(gpointer data, GObject *bindex)
{
MessageWindow *mw = data;
mw->bindex = NULL;
- gtk_widget_destroy(mw->window);
+ gtk_window_destroy(GTK_WINDOW(mw->window));
}
static void
@@ -299,16 +300,6 @@ mw_show_all_headers_change_state(GSimpleAction * action,
* end of GAction callbacks for toggle and radio buttons
*/
-static void
-mw_menubar_foreach(GtkWidget *widget, gpointer data)
-{
- GtkWidget **move_menu = data;
- GtkMenuItem *item = GTK_MENU_ITEM(widget);
-
- if (strcmp(gtk_menu_item_get_label(item), _("M_ove")) == 0)
- *move_menu = widget;
-}
-
static void
mw_set_buttons_sensitive(MessageWindow * mw)
{
@@ -319,7 +310,7 @@ mw_set_buttons_sensitive(MessageWindow * mw)
mailbox = libbalsa_message_get_mailbox(mw->message);
if (mailbox == NULL) {
- gtk_widget_destroy(mw->window);
+ gtk_window_destroy(GTK_WINDOW(mw->window));
return;
}
@@ -355,9 +346,8 @@ mw_set_message(MessageWindow * mw, LibBalsaMessage * message)
if (message) {
g_object_set_data(G_OBJECT(message), BALSA_MESSAGE_WINDOW_KEY, mw);
- if (!mw->idle_handler_id)
- mw->idle_handler_id =
- g_idle_add((GSourceFunc) message_window_idle_handler, mw);
+ if (mw->idle_handler_id == 0)
+ mw->idle_handler_id = g_idle_add(message_window_idle_handler, mw);
mw_set_buttons_sensitive(mw);
}
}
@@ -397,7 +387,7 @@ static void
mw_expunged_cb(LibBalsaMailbox * mailbox, guint msgno, MessageWindow * mw)
{
if (mw->message != NULL && (guint) libbalsa_message_get_msgno(mw->message) == msgno)
- gtk_widget_destroy(mw->window);
+ gtk_window_destroy(GTK_WINDOW(mw->window));
}
static void
@@ -531,7 +521,7 @@ mw_close_activated(GSimpleAction * action, GVariant * parameter,
gpointer data)
{
MessageWindow *mw = (MessageWindow *) data;
- gtk_widget_destroy(mw->window);
+ gtk_window_destroy(GTK_WINDOW(mw->window));
}
static void
@@ -583,13 +573,12 @@ mw_set_selected(MessageWindow * mw, void (*select_func) (BalsaIndex *))
if ((tmp = g_object_get_data(G_OBJECT(message),
BALSA_MESSAGE_WINDOW_KEY))) {
if (tmp == mw) {
- gtk_window_present_with_time(GTK_WINDOW(tmp->window),
- gtk_get_current_event_time());
+ gtk_window_present(GTK_WINDOW(tmp->window));
g_object_unref(message);
return;
}
/* Close the other window */
- gtk_widget_destroy(tmp->window);
+ gtk_window_destroy(GTK_WINDOW(tmp->window));
}
mw_set_message(mw, message);
@@ -623,7 +612,7 @@ message_window_move_message(MessageWindow * mw, LibBalsaMailbox * mailbox)
if (mw->message == original)
/* Either action-after-move was CLOSE, or we failed to select
* another message; either way, we close the window. */
- gtk_widget_destroy(mw->window);
+ gtk_window_destroy(GTK_WINDOW(mw->window));
}
static void
@@ -810,6 +799,43 @@ move_to_activated(GSimpleAction *action,
}
}
+static void
+mw_menubar_set_mru_menu(GtkWidget *menubar)
+{
+ GMenuModel *model;
+ int i;
+ int n;
+ int move_position = -1;
+
+ model = gtk_popover_menu_bar_get_menu_model(GTK_POPOVER_MENU_BAR(menubar));
+ n = g_menu_model_get_n_items(model);
+ for (i = 0; i < n; i++) {
+ const char *label;
+
+ if (g_menu_model_get_item_attribute(model, i, "label", "s", &label) &&
+ strcmp(label, "M_ove") == 0) {
+ move_position = i;
+ break;
+ }
+ }
+
+ if (move_position >= 0) {
+ GMenuItem *item;
+ GMenu *mru_menu;
+
+ item = g_menu_item_new_from_model(model, i);
+
+ mru_menu = balsa_mblist_mru_menu(&balsa_app.folder_mru, "message-window.move-to");
+ g_menu_item_set_submenu(item, G_MENU_MODEL(mru_menu));
+ g_object_unref(mru_menu);
+
+ /* Replace the existing submenu */
+ g_menu_remove(G_MENU(model), move_position);
+ g_menu_insert_item(G_MENU(model), move_position, item);
+ g_object_unref(item);
+ }
+}
+
void
message_window_new(LibBalsaMailbox * mailbox, guint msgno)
{
@@ -819,7 +845,6 @@ message_window_new(LibBalsaMailbox * mailbox, guint msgno)
BalsaToolbarModel *model;
GError *error = NULL;
GtkWidget *menubar;
- GtkWidget *move_menu, *submenu;
GtkWidget *vbox;
static const gchar *const header_options[] =
{ "none", "selected", "all" };
@@ -829,57 +854,53 @@ message_window_new(LibBalsaMailbox * mailbox, guint msgno)
static const GActionEntry message_window_entries[] = {
{"move-to", move_to_activated, "s"},
};
- GMenu *mru_menu;
- if (!mailbox || !msgno)
+ if (mailbox == NULL || msgno == 0)
return;
message = libbalsa_mailbox_get_message(mailbox, msgno);
- if (message
- && (mw = g_object_get_data(G_OBJECT(message),
- BALSA_MESSAGE_WINDOW_KEY))) {
- gtk_window_present_with_time(GTK_WINDOW(mw->window),
- gtk_get_current_event_time());
+ if (message != NULL
+ && (mw = g_object_get_data(G_OBJECT(message),
+ BALSA_MESSAGE_WINDOW_KEY)) != NULL) {
+ gtk_window_present(GTK_WINDOW(mw->window));
g_object_unref(message);
return;
}
mw = g_malloc0(sizeof(MessageWindow));
- mw->window = window =
- gtk_application_window_new(balsa_app.application);
+ mw->window = window = gtk_application_window_new(balsa_app.application);
vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 0);
- gtk_container_add(GTK_CONTAINER(window), vbox);
+ gtk_window_set_child(GTK_WINDOW(window), vbox);
/* Set up the GMenu structures */
menubar = libbalsa_window_get_menu_bar(GTK_APPLICATION_WINDOW(window),
win_entries,
G_N_ELEMENTS(win_entries),
resource_path, &error, mw);
- if (!menubar) {
+ if (menubar == NULL) {
libbalsa_information(LIBBALSA_INFORMATION_WARNING,
_("Error adding from %s: %s\n"), resource_path,
error->message);
g_error_free(error);
return;
}
- gtk_widget_show(menubar);
#if HAVE_MACOSX_DESKTOP
libbalsa_macosx_menu(window, GTK_MENU_SHELL(menubar));
#else
- gtk_container_add(GTK_CONTAINER(vbox), menubar);
+ gtk_box_append(GTK_BOX(vbox), menubar);
#endif
+ mw_menubar_set_mru_menu(menubar);
+
mw->headers_shown = balsa_app.shown_headers;
mw->show_all_headers = FALSE;
model = message_window_get_toolbar_model();
mw->toolbar = balsa_toolbar_new(model, G_ACTION_MAP(window));
- gtk_container_add(GTK_CONTAINER(vbox), mw->toolbar);
-
- gtk_window_set_role(GTK_WINDOW(window), "message");
+ gtk_box_append(GTK_BOX(vbox), mw->toolbar);
g_signal_connect(window, "destroy",
G_CALLBACK(destroy_message_window), mw);
@@ -903,19 +924,11 @@ message_window_new(LibBalsaMailbox * mailbox, guint msgno)
gtk_widget_insert_action_group(GTK_WIDGET(mw->window),
"message-window",
G_ACTION_GROUP(simple));
+ action = g_action_map_lookup_action(G_ACTION_MAP(simple), "move-to");
g_object_unref(simple);
- mru_menu =
- balsa_mblist_mru_menu(&balsa_app.folder_mru, "message-window.move-to");
- submenu = gtk_menu_new_from_model(G_MENU_MODEL(mru_menu));
- g_object_unref(mru_menu);
-
- gtk_container_foreach(GTK_CONTAINER(menubar), mw_menubar_foreach,
- &move_menu);
- gtk_menu_item_set_submenu(GTK_MENU_ITEM(move_menu), submenu);
-
if (libbalsa_mailbox_get_readonly(mailbox)) {
- gtk_widget_set_sensitive(move_menu, FALSE);
+ g_simple_action_set_enabled(G_SIMPLE_ACTION(action), FALSE);
mw_disable_trash(mw);
}
if (mailbox == balsa_app.trash)
@@ -924,8 +937,7 @@ message_window_new(LibBalsaMailbox * mailbox, guint msgno)
gtk_widget_set_vexpand(mw->bmessage, TRUE);
gtk_widget_set_valign(mw->bmessage, GTK_ALIGN_FILL);
- gtk_container_add(GTK_CONTAINER(vbox), mw->bmessage);
- gtk_widget_show(vbox);
+ gtk_box_append(GTK_BOX(vbox), mw->bmessage);
g_signal_connect(mw->bmessage, "select-part",
G_CALLBACK(mw_select_part_cb), mw);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]