|
- diff -Naur Python-3.8.0-orig/Modules/getpath.c Python-3.8.0/Modules/getpath.c
- --- Python-3.8.0-orig/Modules/getpath.c 2019-10-22 10:02:47.765731400 +0300
- +++ Python-3.8.0/Modules/getpath.c 2019-10-22 10:02:49.637734700 +0300
- @@ -1393,6 +1393,36 @@
- return status;
- }
-
- +#ifdef MS_WINDOWS
- + if (calculate->path_env) {
- + wchar_t *module_path, *norm_path;
- + // Add path of executable/dll to system path. This
- + // is so that the correct tcl??.dll and tk??.dll get used.
- + module_path = calculate->dll_path[0] ? calculate->dll_path : pathconfig->program_full_path;
- + norm_path = (wchar_t *)alloca(sizeof(wchar_t) * (wcslen(module_path) + 1));
- + if (norm_path) {
- + wchar_t *slashes, *end, *new_path;
- + wcscpy(norm_path, module_path);
- + slashes = wcschr(norm_path, L'/');
- + while (slashes) {
- + *slashes = L'\\';
- + slashes = wcschr(slashes + 1, L'/');
- + }
- + end = wcsrchr(norm_path, L'\\') ? wcsrchr(norm_path, L'\\') : norm_path + wcslen(norm_path);
- + end[1] = L'\0';
- +
- + new_path = (wchar_t *)alloca(sizeof(wchar_t) * (wcslen(L"PATH=") + wcslen(calculate->path_env) + 1 + wcslen(norm_path) + 1));
- + if (new_path) {
- + wcscpy(new_path, L"PATH=");
- + wcscat(new_path, calculate->path_env);
- + wcscat(new_path, L";");
- + wcscat(new_path, norm_path);
- + _wputenv(new_path);
- + }
- + }
- + }
- +#endif
- +
- if ((!calculate->prefix_found || !calculate->exec_prefix_found) &&
- calculate->warnings)
- {
|