2015-01-26 17:35:10 +01:00
|
|
|
---
|
2016-11-23 11:17:15 +01:00
|
|
|
crypt-gpgme.c | 2 +-
|
|
|
|
lib.c | 12 ++++++++++++
|
|
|
|
lib.h | 1 +
|
|
|
|
pager.c | 2 +-
|
|
|
|
pgp.c | 24 ++++++++++++------------
|
|
|
|
5 files changed, 27 insertions(+), 14 deletions(-)
|
2015-01-26 17:35:10 +01:00
|
|
|
|
2016-11-23 11:17:15 +01:00
|
|
|
--- crypt-gpgme.c
|
|
|
|
+++ crypt-gpgme.c 2016-11-23 10:06:56.163851435 +0000
|
|
|
|
@@ -2313,7 +2313,7 @@ static void copy_clearsigned (gpgme_data
|
|
|
|
|
|
|
|
if (armor_header)
|
|
|
|
{
|
|
|
|
- if (buf[0] == '\n')
|
|
|
|
+ if (buf[0] == '\n' || (buf[0] == '\r' && buf[1] == '\n'))
|
|
|
|
armor_header = 0;
|
|
|
|
continue;
|
|
|
|
}
|
2013-05-29 12:28:08 +02:00
|
|
|
--- lib.c
|
2015-01-26 17:35:10 +01:00
|
|
|
+++ lib.c 2013-05-29 09:31:53.000000000 +0000
|
2016-05-12 16:10:16 +02:00
|
|
|
@@ -880,6 +880,18 @@ int mutt_strcmp(const char *a, const cha
|
2013-05-29 12:28:08 +02:00
|
|
|
return strcmp(NONULL(a), NONULL(b));
|
|
|
|
}
|
|
|
|
|
|
|
|
+int mutt_strxcmp(const char *a, const char *b)
|
|
|
|
+{
|
|
|
|
+ size_t xa, xb;
|
|
|
|
+ xa = strcspn(NONULL(a), "\r\n");
|
|
|
|
+ xb = strcspn(NONULL(b), "\r\n");
|
|
|
|
+ if (xb != xa)
|
|
|
|
+ return -1;
|
|
|
|
+ if (!xa)
|
|
|
|
+ return 0;
|
|
|
|
+ return strncmp(NONULL(a), NONULL(b), xa);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
int mutt_strcasecmp(const char *a, const char *b)
|
|
|
|
{
|
|
|
|
return strcasecmp(NONULL(a), NONULL(b));
|
|
|
|
--- lib.h
|
2015-01-26 17:35:10 +01:00
|
|
|
+++ lib.h 2013-05-29 09:25:22.000000000 +0000
|
|
|
|
@@ -197,6 +197,7 @@ int mutt_copy_bytes (FILE *, FILE *, siz
|
2013-05-29 12:28:08 +02:00
|
|
|
int mutt_rx_sanitize_string (char *, size_t, const char *);
|
|
|
|
int mutt_strcasecmp (const char *, const char *);
|
|
|
|
int mutt_strcmp (const char *, const char *);
|
|
|
|
+int mutt_strxcmp (const char *, const char *);
|
|
|
|
int mutt_strncasecmp (const char *, const char *, size_t);
|
|
|
|
int mutt_strncmp (const char *, const char *, size_t);
|
|
|
|
int mutt_strcoll (const char *, const char *);
|
|
|
|
--- pager.c
|
2015-01-26 17:35:10 +01:00
|
|
|
+++ pager.c 2013-05-29 09:31:53.000000000 +0000
|
2016-05-12 16:10:16 +02:00
|
|
|
@@ -774,7 +774,7 @@ resolve_types (char *buf, char *raw, str
|
2013-05-29 12:28:08 +02:00
|
|
|
else if (check_attachment_marker ((char *) raw) == 0)
|
|
|
|
lineInfo[n].type = MT_COLOR_ATTACHMENT;
|
|
|
|
#endif
|
|
|
|
- else if (mutt_strcmp ("-- \n", buf) == 0 || mutt_strcmp ("-- \r\n", buf) == 0)
|
|
|
|
+ else if (mutt_strxcmp ("-- \n", buf) == 0)
|
|
|
|
{
|
|
|
|
i = n + 1;
|
|
|
|
|
|
|
|
--- pgp.c
|
2015-01-26 17:35:10 +01:00
|
|
|
+++ pgp.c 2015-01-26 15:48:02.361518080 +0000
|
2016-05-12 16:10:16 +02:00
|
|
|
@@ -302,7 +302,7 @@ static void pgp_copy_clearsigned (FILE *
|
2015-01-26 17:35:10 +01:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
- if (mutt_strcmp (buf, "-----BEGIN PGP SIGNATURE-----\n") == 0)
|
|
|
|
+ if (mutt_strxcmp (buf, "-----BEGIN PGP SIGNATURE-----\n") == 0)
|
|
|
|
break;
|
|
|
|
|
|
|
|
if (armor_header)
|
2016-05-12 16:10:16 +02:00
|
|
|
@@ -368,14 +368,14 @@ int pgp_application_pgp_handler (BODY *m
|
2015-01-26 17:35:10 +01:00
|
|
|
{
|
2013-05-29 12:28:08 +02:00
|
|
|
clearsign = 0;
|
|
|
|
|
|
|
|
- if (mutt_strcmp ("MESSAGE-----\n", buf + 15) == 0)
|
|
|
|
+ if (mutt_strxcmp ("MESSAGE-----\n", buf + 15) == 0)
|
|
|
|
needpass = 1;
|
|
|
|
- else if (mutt_strcmp ("SIGNED MESSAGE-----\n", buf + 15) == 0)
|
|
|
|
+ else if (mutt_strxcmp ("SIGNED MESSAGE-----\n", buf + 15) == 0)
|
|
|
|
{
|
|
|
|
clearsign = 1;
|
|
|
|
needpass = 0;
|
|
|
|
}
|
|
|
|
- else if (!mutt_strcmp ("PUBLIC KEY BLOCK-----\n", buf + 15))
|
|
|
|
+ else if (!mutt_strxcmp ("PUBLIC KEY BLOCK-----\n", buf + 15))
|
|
|
|
{
|
|
|
|
needpass = 0;
|
|
|
|
pgp_keyblock = 1;
|
2016-05-12 16:10:16 +02:00
|
|
|
@@ -408,10 +408,10 @@ int pgp_application_pgp_handler (BODY *m
|
2013-05-29 12:28:08 +02:00
|
|
|
|
|
|
|
fputs (buf, tmpfp);
|
|
|
|
|
|
|
|
- if ((needpass && mutt_strcmp ("-----END PGP MESSAGE-----\n", buf) == 0) ||
|
|
|
|
+ if ((needpass && mutt_strxcmp ("-----END PGP MESSAGE-----\n", buf) == 0) ||
|
|
|
|
(!needpass
|
|
|
|
- && (mutt_strcmp ("-----END PGP SIGNATURE-----\n", buf) == 0
|
|
|
|
- || mutt_strcmp ("-----END PGP PUBLIC KEY BLOCK-----\n",buf) == 0)))
|
|
|
|
+ && (mutt_strxcmp ("-----END PGP SIGNATURE-----\n", buf) == 0
|
|
|
|
+ || mutt_strxcmp ("-----END PGP PUBLIC KEY BLOCK-----\n",buf) == 0)))
|
|
|
|
break;
|
|
|
|
/* remember optional Charset: armor header as defined by RfC4880 */
|
|
|
|
if (mutt_strncmp ("Charset: ", buf, 9) == 0)
|
2016-05-12 16:10:16 +02:00
|
|
|
@@ -645,11 +645,11 @@ static int pgp_check_traditional_one_bod
|
2013-05-29 12:28:08 +02:00
|
|
|
{
|
|
|
|
if (mutt_strncmp ("-----BEGIN PGP ", buf, 15) == 0)
|
|
|
|
{
|
|
|
|
- if (mutt_strcmp ("MESSAGE-----\n", buf + 15) == 0)
|
|
|
|
+ if (mutt_strxcmp ("MESSAGE-----\n", buf + 15) == 0)
|
|
|
|
enc = 1;
|
|
|
|
- else if (mutt_strcmp ("SIGNED MESSAGE-----\n", buf + 15) == 0)
|
|
|
|
+ else if (mutt_strxcmp ("SIGNED MESSAGE-----\n", buf + 15) == 0)
|
|
|
|
sgn = 1;
|
|
|
|
- else if (mutt_strcmp ("PUBLIC KEY BLOCK-----\n", buf + 15) == 0)
|
|
|
|
+ else if (mutt_strxcmp ("PUBLIC KEY BLOCK-----\n", buf + 15) == 0)
|
|
|
|
key = 1;
|
|
|
|
}
|
|
|
|
}
|
2016-05-12 16:10:16 +02:00
|
|
|
@@ -1197,9 +1197,9 @@ BODY *pgp_sign_message (BODY *a)
|
2013-05-29 12:28:08 +02:00
|
|
|
*/
|
|
|
|
while (fgets (buffer, sizeof (buffer) - 1, pgpout) != NULL)
|
|
|
|
{
|
|
|
|
- if (mutt_strcmp ("-----BEGIN PGP MESSAGE-----\n", buffer) == 0)
|
|
|
|
+ if (mutt_strxcmp ("-----BEGIN PGP MESSAGE-----\n", buffer) == 0)
|
|
|
|
fputs ("-----BEGIN PGP SIGNATURE-----\n", fp);
|
|
|
|
- else if (mutt_strcmp("-----END PGP MESSAGE-----\n", buffer) == 0)
|
|
|
|
+ else if (mutt_strxcmp("-----END PGP MESSAGE-----\n", buffer) == 0)
|
|
|
|
fputs ("-----END PGP SIGNATURE-----\n", fp);
|
|
|
|
else
|
|
|
|
fputs (buffer, fp);
|