[balsa/gtk4: 73/76] libbalsa-gpgme: Build with gtk4




commit ce45ca05c206eb17776224af1bfb0fe68f12bae4
Author: Peter Bloomfield <PeterBloomfield bellsouth net>
Date:   Thu Oct 8 21:33:10 2020 -0400

    libbalsa-gpgme: Build with gtk4

 libbalsa/libbalsa-gpgme-keys.c    | 120 +++++++++++++++++++++-----------------
 libbalsa/libbalsa-gpgme-widgets.c |  96 +++++++++++++++---------------
 2 files changed, 113 insertions(+), 103 deletions(-)
---
diff --git a/libbalsa/libbalsa-gpgme-keys.c b/libbalsa/libbalsa-gpgme-keys.c
index 768786ac4..807e5e35d 100644
--- a/libbalsa/libbalsa-gpgme-keys.c
+++ b/libbalsa/libbalsa-gpgme-keys.c
@@ -61,7 +61,6 @@ static gboolean gpgme_import_key(gpgme_ctx_t   ctx,
                                                                 GError      **error);
 static gchar *gpgme_import_res_to_gchar(gpgme_import_result_t import_result)
        G_GNUC_WARN_UNUSED_RESULT;
-static gboolean show_keyserver_dialog(gpointer user_data);
 static void keyserver_op_free(keyserver_op_t *keyserver_op);
 
 
@@ -454,45 +453,76 @@ check_key(const gpgme_key_t key,
  * \return always NULL
  *
  * Use the passed key server thread data to call libbalsa_gpgme_list_keys().  On success, check if exactly 
\em one key has been
- * returned and call gpgme_keyserver_do_import() as to import or update it in this case.  Call 
show_keyserver_dialog() as idle
- * callback to present the user the results.
+ * returned and call gpgme_keyserver_do_import() as to import or update it in this case.
  */
+
+typedef struct {
+    keyserver_op_t *keyserver_op;
+    GList *keys;
+} gpgme_keyserver_data;
+
+static gboolean
+gpgme_keyserver_idle(gpointer user_data)
+{
+    gpgme_keyserver_data *data = user_data;
+    GtkWidget *dialog;
+
+    if (data->keys == NULL) {
+        dialog = gtk_message_dialog_new(data->keyserver_op->parent,
+                                        GTK_DIALOG_DESTROY_WITH_PARENT | libbalsa_dialog_flags(),
+                                        GTK_MESSAGE_INFO, GTK_BUTTONS_CLOSE,
+                                        _
+                                        ("Cannot find a key with fingerprint %s on the key server."),
+                                        data->keyserver_op->fingerprint);
+    } else if (data->keys->next != NULL) {
+        /* more than one key found */
+        dialog = gtk_message_dialog_new(data->keyserver_op->parent,
+                                        GTK_DIALOG_DESTROY_WITH_PARENT | libbalsa_dialog_flags(),
+                                        GTK_MESSAGE_WARNING,
+                                        GTK_BUTTONS_CLOSE,
+                                        ngettext
+                                        ("Found %u key with fingerprint %s on the key server. Please check 
and import the proper key manually.",
+                                         "Found %u keys with fingerprint %s on the key server. Please check 
and import the proper key manually.",
+                                         g_list_length(data->keys)), g_list_length(data->keys),
+                                        data->keyserver_op->fingerprint);
+    } else {
+        dialog = gpgme_keyserver_do_import(data->keyserver_op, (gpgme_key_t) data->keys->data);
+    }
+
+    g_list_free_full(data->keys, (GDestroyNotify) gpgme_key_unref);
+    g_free(data);
+
+    g_signal_connect(dialog, "response", G_CALLBACK(gtk_window_destroy), NULL);
+    gtk_widget_show(dialog);
+
+    return G_SOURCE_REMOVE;
+}
+
 static gpointer
 gpgme_keyserver_run(gpointer user_data)
 {
-       keyserver_op_t *keyserver_op = (keyserver_op_t *) user_data;
-       GList *keys = NULL;
-       gboolean result;
-       GError *error = NULL;
-
-       result = libbalsa_gpgme_list_keys(keyserver_op->gpgme_ctx, &keys, NULL, keyserver_op->fingerprint, 
FALSE, TRUE, FALSE, &error);
-       if (result) {
-               GtkWidget *dialog;
-
-               if (keys == NULL) {
-                       dialog = gtk_message_dialog_new(keyserver_op->parent,
-                               GTK_DIALOG_DESTROY_WITH_PARENT | libbalsa_dialog_flags(), GTK_MESSAGE_INFO, 
GTK_BUTTONS_CLOSE,
-                               _("Cannot find a key with fingerprint %s on the key server."), 
keyserver_op->fingerprint);
-               } else if (keys->next != NULL) {
-                       /* more than one key found */
-                       dialog = gtk_message_dialog_new(keyserver_op->parent,
-                               GTK_DIALOG_DESTROY_WITH_PARENT | libbalsa_dialog_flags(), 
GTK_MESSAGE_WARNING, GTK_BUTTONS_CLOSE,
-                               ngettext("Found %u key with fingerprint %s on the key server. Please check 
and import the proper key manually.",
-                                        "Found %u keys with fingerprint %s on the key server. Please check 
and import the proper key manually.",
-                                        g_list_length(keys)),
-                               g_list_length(keys), keyserver_op->fingerprint);
-               } else {
-                       dialog = gpgme_keyserver_do_import(keyserver_op, (gpgme_key_t) keys->data);
-               }
-               g_list_free_full(keys, (GDestroyNotify) gpgme_key_unref);
-               g_idle_add(show_keyserver_dialog, dialog);
-       } else {
-               libbalsa_information(LIBBALSA_INFORMATION_ERROR, _("Searching the key server failed: %s"), 
error->message);
-               g_error_free(error);
-       }
-       keyserver_op_free(keyserver_op);
-
-       return NULL;
+    keyserver_op_t *keyserver_op = (keyserver_op_t *) user_data;
+    GList *keys = NULL;
+    gboolean result;
+    GError *error = NULL;
+
+    result = libbalsa_gpgme_list_keys(keyserver_op->gpgme_ctx, &keys, NULL,
+                                      keyserver_op->fingerprint, FALSE, TRUE, FALSE, &error);
+
+    if (result) {
+        gpgme_keyserver_data *data = g_new(gpgme_keyserver_data, 1);
+        data->keys = keys;
+        data->keyserver_op = keyserver_op;
+        g_idle_add(gpgme_keyserver_idle, data);
+    } else {
+        libbalsa_information(LIBBALSA_INFORMATION_ERROR, _("Searching the key server failed: %s"),
+                             error->message);
+        g_error_free(error);
+    }
+
+    keyserver_op_free(keyserver_op);
+
+    return NULL;
 }
 
 
@@ -641,24 +671,6 @@ gpgme_import_res_to_gchar(gpgme_import_result_t import_result)
 }
 
 
-/** \brief Display a dialogue
- *
- * \param user_data dialogue widget, cast'ed to GtkWidget *
- * \return always FALSE
- *
- * This helper function, called as idle callback, just shows the passed dialogue.
- */
-static gboolean
-show_keyserver_dialog(gpointer user_data)
-{
-       GtkWidget *dialog = GTK_WIDGET(user_data);
-
-    gtk_dialog_run(GTK_DIALOG(dialog));
-    gtk_widget_destroy(dialog);
-       return FALSE;
-}
-
-
 /** \brief Free a key server thread data structure
  *
  * \param keyserver_op key server thread data
diff --git a/libbalsa/libbalsa-gpgme-widgets.c b/libbalsa/libbalsa-gpgme-widgets.c
index 244499f30..b04b43120 100644
--- a/libbalsa/libbalsa-gpgme-widgets.c
+++ b/libbalsa/libbalsa-gpgme-widgets.c
@@ -132,9 +132,9 @@ libbalsa_gpgme_key(const gpgme_key_t     key,
 
                uid_box = gtk_box_new(GTK_ORIENTATION_VERTICAL, 2);
                gtk_widget_set_margin_start(uid_box, 12);
-               gtk_container_add(GTK_CONTAINER(uid_expander), uid_box);
+               gtk_expander_set_child(GTK_EXPANDER(uid_expander), uid_box);
                for (uid = key->uids->next; uid != NULL; uid = uid->next) {
-                       gtk_container_add(GTK_CONTAINER(uid_box), create_key_uid_widget(uid));
+                       gtk_box_append(GTK_BOX(uid_box), create_key_uid_widget(uid));
                }
        }
 
@@ -151,7 +151,7 @@ libbalsa_gpgme_key(const gpgme_key_t     key,
                issuer_grid = gtk_grid_new();
                gtk_widget_set_margin_start(issuer_grid, 12);
                gtk_grid_set_column_spacing(GTK_GRID(issuer_grid), 6);
-               gtk_container_add(GTK_CONTAINER(issuer_expander), issuer_grid);
+               gtk_expander_set_child(GTK_EXPANDER(issuer_expander), issuer_grid);
 
                if (key->issuer_name != NULL) {
                        uid_readable = libbalsa_cert_subject_readable(key->issuer_name);
@@ -209,7 +209,7 @@ libbalsa_gpgme_key(const gpgme_key_t     key,
 
                subkey_box = gtk_box_new(GTK_ORIENTATION_VERTICAL, 2);
                gtk_widget_set_margin_start(subkey_box, 12);
-               gtk_container_add(GTK_CONTAINER(subkey_expander), subkey_box);
+               gtk_expander_set_child(GTK_EXPANDER(subkey_expander), subkey_box);
 
                for (subkey = key->subkeys; subkey != NULL; subkey = subkey->next) {
                        if (fingerprint != NULL) {
@@ -222,7 +222,7 @@ libbalsa_gpgme_key(const gpgme_key_t     key,
 
                                     gtk_widget_set_margin_top(subkey_widget, 2);
                                     gtk_widget_set_margin_bottom(subkey_widget, 2);
-                                    gtk_container_add(GTK_CONTAINER(subkey_box), subkey_widget);
+                                    gtk_box_append(GTK_BOX(subkey_box), subkey_widget);
                                }
                        } else if ((((subkey_capa & GPG_SUBKEY_CAP_SIGN) != 0U) && (subkey->can_sign != 0)) ||
                                           (((subkey_capa & GPG_SUBKEY_CAP_ENCRYPT) != 0U) && 
(subkey->can_encrypt != 0)) ||
@@ -232,7 +232,7 @@ libbalsa_gpgme_key(const gpgme_key_t     key,
 
                             gtk_widget_set_margin_top(subkey_widget, 2);
                             gtk_widget_set_margin_bottom(subkey_widget, 2);
-                            gtk_container_add(GTK_CONTAINER(subkey_box), subkey_widget);
+                            gtk_box_append(GTK_BOX(subkey_box), subkey_widget);
                        } else {
                                /* do not print this subkey */
                        }
@@ -412,21 +412,21 @@ libbalsa_key_dialog(GtkWindow            *parent,
        content_area = gtk_dialog_get_content_area(GTK_DIALOG(dialog));
 
        hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 12);
-       gtk_container_set_border_width(GTK_CONTAINER(hbox), 6);
+       g_object_set(hbox, "margin", 6, NULL);
         gtk_widget_set_vexpand(hbox, TRUE);
         gtk_widget_set_valign(hbox, GTK_ALIGN_FILL);
-       gtk_container_add(GTK_CONTAINER(content_area), hbox);
+       gtk_box_append(GTK_BOX(content_area), hbox);
        gtk_box_set_homogeneous(GTK_BOX(hbox), FALSE);
 
        /* standard key icon; "application-certificate" would be an alternative... */
-       icon = gtk_image_new_from_icon_name("dialog-password", GTK_ICON_SIZE_DIALOG);
-       gtk_container_add(GTK_CONTAINER(hbox), icon);
+       icon = gtk_image_new_from_icon_name("dialog-password");
+       gtk_box_append(GTK_BOX(hbox), icon);
        gtk_widget_set_valign(icon, GTK_ALIGN_START);
 
        vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 6);
         gtk_widget_set_hexpand(vbox, TRUE);
         gtk_widget_set_halign(vbox, GTK_ALIGN_FILL);
-       gtk_container_add(GTK_CONTAINER(hbox), vbox);
+       gtk_box_append(GTK_BOX(hbox), vbox);
        gtk_box_set_homogeneous(GTK_BOX(vbox), FALSE);
 
        if (message1 != NULL) {
@@ -436,27 +436,25 @@ libbalsa_key_dialog(GtkWindow            *parent,
                markup = g_markup_printf_escaped("<b><big>%s</big></b>", message1);
                gtk_label_set_markup(GTK_LABEL(label), markup);
                g_free(markup);
-               gtk_container_add(GTK_CONTAINER(vbox), label);
+               gtk_box_append(GTK_BOX(vbox), label);
        }
 
        if (message2 != NULL) {
                label = libbalsa_create_wrap_label(message2, FALSE);
-               gtk_container_add(GTK_CONTAINER(vbox), label);
+               gtk_box_append(GTK_BOX(vbox), label);
        }
 
-       scrolledw = gtk_scrolled_window_new(NULL, NULL);
+       scrolledw = gtk_scrolled_window_new();
         gtk_widget_set_vexpand(scrolledw, TRUE);
         gtk_widget_set_valign(scrolledw, GTK_ALIGN_FILL);
         gtk_widget_set_margin_top(scrolledw, 6);
         gtk_widget_set_margin_bottom(scrolledw, 6);
-       gtk_container_add(GTK_CONTAINER(vbox), scrolledw);
+       gtk_box_append(GTK_BOX(vbox), scrolledw);
        gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolledw), GTK_POLICY_NEVER, 
GTK_POLICY_AUTOMATIC);
        gtk_scrolled_window_set_min_content_height(GTK_SCROLLED_WINDOW(scrolledw), 120);
 
        key_data = libbalsa_gpgme_key(key, NULL, subkey_capa, TRUE);
-       gtk_container_add(GTK_CONTAINER(scrolledw), key_data);
-
-       gtk_widget_show_all(hbox);
+       gtk_box_append(GTK_BOX(scrolledw), key_data);
 
        return dialog;
 }
@@ -606,33 +604,34 @@ create_key_uid_widget(const gpgme_user_id_t uid)
  * a warning icon prepended.  In both cases, the label is start-justified, selectable and line-wrappable.
  */
 static GtkWidget *
-create_key_label_with_warn(const gchar *text,
-                                                  gboolean     warn)
+create_key_label_with_warn(const gchar * text, gboolean warn)
 {
-       GtkWidget *result;
-
-       if (warn) {
-               GtkWidget *icon;
-               GtkWidget *label;
-               gchar *buf;
-
-               result = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 6);
-               icon = gtk_image_new_from_icon_name("dialog-warning", GTK_ICON_SIZE_MENU);
-               gtk_container_add(GTK_CONTAINER(result), icon);
-               buf = g_markup_printf_escaped("<span fgcolor=\"red\">%s</span>", text);
-               label = libbalsa_create_wrap_label(buf, TRUE);
-               g_free(buf);
-               gtk_label_set_selectable(GTK_LABEL(label), TRUE);
-               gtk_widget_set_hexpand(label, TRUE);
-                gtk_widget_set_halign(label, GTK_ALIGN_FILL);
-               gtk_container_add(GTK_CONTAINER(result), label);
-       } else {
-               result = libbalsa_create_wrap_label(text, FALSE);
-               gtk_widget_set_hexpand(result, TRUE);
-               gtk_label_set_selectable(GTK_LABEL(result), TRUE);
-       }
-
-       return result;
+    GtkWidget *result;
+
+    if (warn) {
+        GtkWidget *icon;
+        GtkWidget *label;
+        gchar *buf;
+
+        result = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 6);
+        icon = gtk_image_new_from_icon_name("dialog-warning");
+        gtk_box_append(GTK_BOX(result), icon);
+
+        buf = g_markup_printf_escaped("<span fgcolor=\"red\">%s</span>", text);
+        label = libbalsa_create_wrap_label(buf, TRUE);
+        g_free(buf);
+
+        gtk_label_set_selectable(GTK_LABEL(label), TRUE);
+        gtk_widget_set_hexpand(label, TRUE);
+        gtk_widget_set_halign(label, GTK_ALIGN_FILL);
+        gtk_box_append(GTK_BOX(result), label);
+    } else {
+        result = libbalsa_create_wrap_label(text, FALSE);
+        gtk_widget_set_hexpand(result, TRUE);
+        gtk_label_set_selectable(GTK_LABEL(result), TRUE);
+    }
+
+    return result;
 }
 
 
@@ -781,7 +780,7 @@ smime_show_chain(GtkWidget *button, gpointer G_GNUC_UNUSED user_data)
        GtkWidget *chain;
 
        dialog = gtk_dialog_new_with_buttons("Certificate Chain",
-               GTK_WINDOW(gtk_widget_get_toplevel(button)),
+               GTK_WINDOW(gtk_widget_get_root(button)),
                GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT | libbalsa_dialog_flags(),
                _("_Close"), GTK_RESPONSE_CLOSE, NULL);
        geometry_manager_attach(GTK_WINDOW(dialog), "CertChain");
@@ -791,9 +790,8 @@ smime_show_chain(GtkWidget *button, gpointer G_GNUC_UNUSED user_data)
         gtk_widget_set_valign(chain, GTK_ALIGN_FILL);
         gtk_widget_set_margin_top(chain, 6);
         gtk_widget_set_margin_bottom(chain, 6);
-       gtk_container_add(GTK_CONTAINER(vbox), chain);
+       gtk_box_append(GTK_BOX(vbox), chain);
 
-       gtk_widget_show_all(vbox);
-       gtk_dialog_run(GTK_DIALOG(dialog));
-       gtk_widget_destroy(dialog);
+        g_signal_connect(dialog, "response", G_CALLBACK(gtk_window_destroy), NULL);
+        gtk_widget_show(dialog);
 }


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]