X-Git-Url: http://git.madism.org/?p=apps%2Fmadmutt.git;a=blobdiff_plain;f=url.c;h=35cb0c1829903ae30b8e91b46b2f4faf833619c8;hp=3d7a333601022fdf243ba9ee80ba221309f7491e;hb=fe23f004535336d4d6103eada14a59173c212edb;hpb=c3e57678c8be193fc137854020f3a90887be97c9 diff --git a/url.c b/url.c index 3d7a333..35cb0c1 100644 --- a/url.c +++ b/url.c @@ -21,6 +21,8 @@ #include "mime.h" +#include "lib/mem.h" + #include static struct mapping_t UrlMap[] = { @@ -170,7 +172,7 @@ int url_ciss_tostring (ciss_url_t * ciss, char *dest, size_t len, int flags) if (ciss->host) { safe_strcat (dest, len, "//"); - len -= (l = strlen (dest)); + len -= (l = mutt_strlen (dest)); dest += l; if (ciss->user) { @@ -179,7 +181,7 @@ int url_ciss_tostring (ciss_url_t * ciss, char *dest, size_t len, int flags) else snprintf (dest, len, "%s@", ciss->user); - len -= (l = strlen (dest)); + len -= (l = mutt_strlen (dest)); dest += l; } @@ -232,16 +234,22 @@ int url_parse_mailto (ENVELOPE * e, char **body, const char *src) if (!ascii_strcasecmp (tag, "body")) { if (body) - mutt_str_replace (body, value); + str_replace (body, value); } else { - taglen = strlen (tag); +#define SAFEPFX (option (OPTSTRICTMAILTO) ? "" : "X-Mailto-") + taglen = mutt_strlen (tag) + mutt_strlen (SAFEPFX); /* mutt_parse_rfc822_line makes some assumptions */ - snprintf (scratch, sizeof (scratch), "%s: %s", tag, value); + snprintf (scratch, sizeof (scratch), "%s%s: %s", SAFEPFX, tag, value); +#undef SAVEPFX scratch[taglen] = '\0'; value = &scratch[taglen + 1]; SKIPWS (value); mutt_parse_rfc822_line (e, NULL, scratch, value, 1, 0, 0, &last); + /* if $strict_mailto is set, force editing headers to let + * users have a look at what we got */ + if (!option (OPTSTRICTMAILTO)) + set_option (OPTEDITHDRS); } }