From d30fdae24b9549342183ac65cf1726f7ebcada9d Mon Sep 17 00:00:00 2001 From: Werner Koch Date: Thu, 4 Sep 2008 10:35:41 +0000 Subject: Workaround for a mingw runtime bug. --- sm/certdump.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 'sm/certdump.c') diff --git a/sm/certdump.c b/sm/certdump.c index 91539017f..9dbd24566 100644 --- a/sm/certdump.c +++ b/sm/certdump.c @@ -979,7 +979,13 @@ gpgsm_format_keydesc (ksba_cert_t cert) buffer = p = xtrymalloc (strlen (name) * 3 + 1); for (s=name; *s; s++) { - if (*s < ' ' || *s == '+') + /* We also escape the quote character to work around a bug in + the mingw32 runtime which does not correcty handle command + line quoting. We correctly double the quote mark when + calling a program (i.e. gpg-protec-tool), but the pre-main + code does not notice the double quote as an escaped + quote. */ + if (*s < ' ' || *s == '+' || *s == '\"') { sprintf (p, "%%%02X", *(unsigned char *)s); p += 3; -- cgit v1.2.3