[PATCH v2] ntdll: Avoid matching the config directory for /windows/ in lookup_unix_name().

Alexandre Julliard julliard at winehq.org
Wed Apr 3 14:11:00 CDT 2019


Zebediah Figura <z.figura12 at gmail.com> writes:

> Wine-Bug: https://bugs.winehq.org/show_bug.cgi?id=46863
> Signed-off-by: Zebediah Figura <z.figura12 at gmail.com>
> ---
>  dlls/ntdll/directory.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/dlls/ntdll/directory.c b/dlls/ntdll/directory.c
> index b46c2a6736..717873551b 100644
> --- a/dlls/ntdll/directory.c
> +++ b/dlls/ntdll/directory.c
> @@ -2638,7 +2638,7 @@ static NTSTATUS lookup_unix_name( const WCHAR *name, int name_len, char **buffer
>          char *p;
>          unix_name[pos + ret] = 0;
>          for (p = unix_name + pos ; *p; p++) if (*p == '\\') *p = '/';
> -        if (!redirect || (!strstr( unix_name, "/windows/") && strncmp( unix_name, "windows/", 8 )))
> +        if (!redirect || strncmp( unix_name + pos, "/windows/", 9 ))

There's no reason that /windows/ would be at the start of the
path. Redirections should also work when accessed from the Z: drive for
instance.

-- 
Alexandre Julliard
julliard at winehq.org



More information about the wine-devel mailing list