1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-22 14:57:02 +01:00

common,w32: Remove duplicated backslashes when setting the homedir.

* common/homedir.c (copy_dir_with_fixup) [W32]: Fold double
backslashes.
--

This is in general no problem but when we hash or compare the directory
to test whether tit is the standard home directory, we may use a
different socket file and thus a second instance of a daemon.

GnuPG-bug-id: 6833
This commit is contained in:
Werner Koch 2024-01-09 10:09:36 +01:00
parent 5ce7f8189e
commit cc9568cd59
No known key found for this signature in database
GPG Key ID: E3FDFF218E45B72B
2 changed files with 29 additions and 2 deletions

5
NEWS
View File

@ -1,6 +1,9 @@
Noteworthy changes in version 2.2.42 (unreleased)
Noteworthy changes in version 2.2.43 (unreleased)
-------------------------------------------------
* dirmngr: Avoid starting a second instance on Windows via GPGME
based launching. [T6833]
Noteworthy changes in version 2.2.42 (2023-11-28)
-------------------------------------------------

View File

@ -176,7 +176,8 @@ static char *
copy_dir_with_fixup (const char *newdir)
{
char *result = NULL;
char *p;
char *p, *p0;
const char *s;
if (!*newdir)
return NULL;
@ -208,6 +209,29 @@ copy_dir_with_fixup (const char *newdir)
*p-- = 0;
}
/* Hack to mitigate badly doubled backslashes. */
s = result? result : newdir;
if (s[0] == '\\' && s[1] == '\\' && s[2] != '\\')
{
/* UNC (\\Servername\file) or Long UNC (\\?\Servername\file)
* Does not seem to be double quoted. */
}
else if (strstr (s, "\\\\"))
{
/* Double quotes detected. Fold them into one because that is
* what what Windows does. This way we get a unique hash
* regardless of the number of doubled backslashes. */
if (!result)
result = xstrdup (newdir);
for (p0=p=result; *p; p++)
{
*p0++ = *p;
while (*p == '\\' && p[1] == '\\')
p++;
}
*p0 = 0;
}
#else /*!HAVE_W32_SYSTEM*/
if (newdir[strlen (newdir)-1] == '/')