Fix string leaks
authorColin Leroy <colin@colino.net>
Mon, 10 Aug 2015 18:58:32 +0000 (20:58 +0200)
committerColin Leroy <colin@colino.net>
Mon, 10 Aug 2015 18:58:32 +0000 (20:58 +0200)
src/plugins/pgpmime/pgpmime.c
src/plugins/smime/smime.c

index afcf94e9ef993d716d6761b3fca50dc300ec50c7..05cef5c6a7a1e599737207c8b4885fa944d04c36 100644 (file)
@@ -544,8 +544,10 @@ gboolean pgpmime_sign(MimeInfo *mimeinfo, PrefsAccount *account, const gchar *fr
        if (result && result->signatures) {
                gpgme_new_signature_t sig = result->signatures;
                if (gpgme_get_protocol(ctx) == GPGME_PROTOCOL_OpenPGP) {
-                       micalg = g_strdup_printf("pgp-%s", g_ascii_strdown(gpgme_hash_algo_name(
-                               result->signatures->hash_algo),-1));
+                       gchar *down_algo = g_ascii_strdown(gpgme_hash_algo_name(
+                               result->signatures->hash_algo), -1);
+                       micalg = g_strdup_printf("pgp-%s", down_algo);
+                       g_free(down_algo);
                } else {
                        micalg = g_strdup(gpgme_hash_algo_name(
                                result->signatures->hash_algo));
index e3970b6a30a0d2bfb19954c03dcc1d06afea4683..5f7068b5133311c5f90e54c04b41c3cc3651a121 100644 (file)
@@ -642,8 +642,10 @@ gboolean smime_sign(MimeInfo *mimeinfo, PrefsAccount *account, const gchar *from
        result = gpgme_op_sign_result(ctx);
        if (result && result->signatures) {
            if (gpgme_get_protocol(ctx) == GPGME_PROTOCOL_OpenPGP) {
-               micalg = g_strdup_printf("pgp-%s", g_ascii_strdown(gpgme_hash_algo_name(
-                           result->signatures->hash_algo),-1));
+               gchar *down_algo = g_ascii_strdown(gpgme_hash_algo_name(
+                           result->signatures->hash_algo), -1);
+               micalg = g_strdup_printf("pgp-%s", down_algo);
+               g_free(down_algo);
            } else {
                micalg = g_strdup(gpgme_hash_algo_name(
                            result->signatures->hash_algo));