---
 crypto.c | 27 +++++++++++++++++----------
 1 file changed, 17 insertions(+), 10 deletions(-)

diff --git a/crypto.c b/crypto.c
index 6f4a6db9d0f1..7cd7b69d1221 100644
--- a/crypto.c
+++ b/crypto.c
@@ -24,14 +24,20 @@

 /* Create a GPG context (GMime 2.6) */
 static notmuch_crypto_context_t *
-create_gpg_context (void)
+create_gpg_context (notmuch_crypto_t *crypto)
 {
     notmuch_crypto_context_t *gpgctx;

+    if (crypto->gpgctx)
+       return crypto->gpgctx;
+
     /* TODO: GMimePasswordRequestFunc */
     gpgctx = g_mime_gpg_context_new (NULL, "gpg");
-    if (! gpgctx)
+    if (! gpgctx) {
+       fprintf (stderr, "Failed to construct gpg context.\n");
        return NULL;
+    }
+    crypto->gpgctx = gpgctx;

     g_mime_gpg_context_set_use_agent ((GMimeGpgContext *) gpgctx, TRUE);
     g_mime_gpg_context_set_always_trust ((GMimeGpgContext *) gpgctx, FALSE);
@@ -43,17 +49,23 @@ create_gpg_context (void)

 /* Create a GPG context (GMime 2.4) */
 static notmuch_crypto_context_t *
-create_gpg_context (void)
+create_gpg_context (notmuch_crypto_t *crypto)
 {
     GMimeSession *session;
     notmuch_crypto_context_t *gpgctx;

+    if (crypto->gpgctx)
+       return crypto->gpgctx;
+
     session = g_object_new (g_mime_session_get_type (), NULL);
     gpgctx = g_mime_gpg_context_new (session, "gpg");
     g_object_unref (session);

-    if (! gpgctx)
+    if (! gpgctx) {
+       fprintf (stderr, "Failed to construct gpg context.\n");
        return NULL;
+    }
+    crypto->gpgctx = gpgctx;

     g_mime_gpg_context_set_always_trust ((GMimeGpgContext *) gpgctx, FALSE);

@@ -82,12 +94,7 @@ notmuch_crypto_get_context (notmuch_crypto_t *crypto, const 
char *protocol)
      */
     if (strcasecmp (protocol, "application/pgp-signature") == 0 ||
        strcasecmp (protocol, "application/pgp-encrypted") == 0) {
-       if (! crypto->gpgctx) {
-           crypto->gpgctx = create_gpg_context ();
-           if (! crypto->gpgctx)
-               fprintf (stderr, "Failed to construct gpg context.\n");
-       }
-       cryptoctx = crypto->gpgctx;
+       cryptoctx = create_gpg_context (crypto);
     } else {
        fprintf (stderr, "Unknown or unsupported cryptographic protocol.\n");
     }
-- 
2.1.4

Reply via email to