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) {