* spawn.cc (spawn_guts): Only try to remove long path prefix from
runpath if runpath is not NULL.
This commit is contained in:
@@ -1,3 +1,8 @@
|
|||||||
|
2010-01-25 Corinna Vinschen <corinna@vinschen.de>
|
||||||
|
|
||||||
|
* spawn.cc (spawn_guts): Only try to remove long path prefix from
|
||||||
|
runpath if runpath is not NULL.
|
||||||
|
|
||||||
2010-01-25 Corinna Vinschen <corinna@vinschen.de>
|
2010-01-25 Corinna Vinschen <corinna@vinschen.de>
|
||||||
|
|
||||||
* nlsfuncs.cc (__get_lcid_from_locale): Fix a comment. Handle special
|
* nlsfuncs.cc (__get_lcid_from_locale): Fix a comment. Handle special
|
||||||
|
@@ -489,23 +489,24 @@ spawn_guts (const char *prog_arg, const char *const *argv,
|
|||||||
}
|
}
|
||||||
|
|
||||||
runpath = null_app_name ? NULL : real_path.get_wide_win32_path (runpath);
|
runpath = null_app_name ? NULL : real_path.get_wide_win32_path (runpath);
|
||||||
{ /* If the executable path length is < MAX_PATH, make sure the long path
|
if (runpath)
|
||||||
win32 prefix is removed from the path to make subsequent native Win32
|
{ /* If the executable path length is < MAX_PATH, make sure the long path
|
||||||
child processes happy which are not long path aware. */
|
win32 prefix is removed from the path to make subsequent native Win32
|
||||||
USHORT len = real_path.get_nt_native_path ()->Length;
|
child processes happy which are not long path aware. */
|
||||||
if (len < (MAX_PATH + 4) * sizeof (WCHAR)
|
USHORT len = real_path.get_nt_native_path ()->Length;
|
||||||
|| (runpath[5] != L':' /* UNC path */
|
if (len < (MAX_PATH + 4) * sizeof (WCHAR)
|
||||||
&& len < (MAX_PATH + 6) * sizeof (WCHAR)))
|
|| (runpath[5] != L':' /* UNC path */
|
||||||
{
|
&& len < (MAX_PATH + 6) * sizeof (WCHAR)))
|
||||||
PWCHAR r = runpath + 4;
|
{
|
||||||
if (r[1] != L':') /* UNC path */
|
PWCHAR r = runpath + 4;
|
||||||
*(r += 2) = L'\\';
|
if (r[1] != L':') /* UNC path */
|
||||||
if (!RtlIsDosDeviceName_U (r))
|
*(r += 2) = L'\\';
|
||||||
runpath = r;
|
if (!RtlIsDosDeviceName_U (r))
|
||||||
else if (*r == L'\\')
|
runpath = r;
|
||||||
*r = L'C';
|
else if (*r == L'\\')
|
||||||
}
|
*r = L'C';
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
syscall_printf ("null_app_name %d (%W, %.9500W)", null_app_name,
|
syscall_printf ("null_app_name %d (%W, %.9500W)", null_app_name,
|
||||||
runpath, wone_line);
|
runpath, wone_line);
|
||||||
|
Reference in New Issue
Block a user