From 3e197c7a6740d564ad52fb7901c07d5ff49460f5 Mon Sep 17 00:00:00 2001 From: Alexey Izbyshev Date: Thu, 1 Mar 2018 12:13:56 +0300 Subject: [PATCH] bpo-32903: Fix a memory leak in os.chdir() on Windows (GH-5801) --- .../2018-02-28-11-03-24.bpo-32903.1SXY4t.rst | 2 ++ Modules/posixmodule.c | 14 +++++++------- 2 files changed, 9 insertions(+), 7 deletions(-) create mode 100644 Misc/NEWS.d/next/Windows/2018-02-28-11-03-24.bpo-32903.1SXY4t.rst diff --git a/Misc/NEWS.d/next/Windows/2018-02-28-11-03-24.bpo-32903.1SXY4t.rst b/Misc/NEWS.d/next/Windows/2018-02-28-11-03-24.bpo-32903.1SXY4t.rst new file mode 100644 index 0000000000..a20a414790 --- /dev/null +++ b/Misc/NEWS.d/next/Windows/2018-02-28-11-03-24.bpo-32903.1SXY4t.rst @@ -0,0 +1,2 @@ +Fix a memory leak in os.chdir() on Windows if the current directory is set +to a UNC path. diff --git a/Modules/posixmodule.c b/Modules/posixmodule.c index 4b59229883..6bba8ee26e 100644 --- a/Modules/posixmodule.c +++ b/Modules/posixmodule.c @@ -1529,15 +1529,15 @@ win32_wchdir(LPCWSTR path) return FALSE; } } - if (wcsncmp(new_path, L"\\\\", 2) == 0 || - wcsncmp(new_path, L"//", 2) == 0) - /* UNC path, nothing to do. */ - return TRUE; - env[1] = new_path[0]; - result = SetEnvironmentVariableW(env, new_path); + int is_unc_like_path = (wcsncmp(new_path, L"\\\\", 2) == 0 || + wcsncmp(new_path, L"//", 2) == 0); + if (!is_unc_like_path) { + env[1] = new_path[0]; + result = SetEnvironmentVariableW(env, new_path); + } if (new_path != path_buf) PyMem_RawFree(new_path); - return result; + return result ? TRUE : FALSE; } #endif -- 2.40.0