]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
gh-103088: Sanitize venv paths when using MSYS or Cygwin Bash (GH-103325)
authorStanislav Syekirin <syekirin@gmail.com>
Tue, 11 Apr 2023 19:20:46 +0000 (21:20 +0200)
committerGitHub <noreply@github.com>
Tue, 11 Apr 2023 19:20:46 +0000 (20:20 +0100)
Lib/venv/scripts/common/activate
Misc/NEWS.d/next/Windows/2023-04-11-09-22-22.gh-issue-103088.6AJEuR.rst [new file with mode: 0644]
PCbuild/find_python.bat

index 6fbc2b8801da0498b4d526bbac11ab5b0d2a4de7..cb898b39670c478074e41e717f9d6a7d266e967b 100644 (file)
@@ -38,8 +38,15 @@ deactivate () {
 # unset irrelevant variables
 deactivate nondestructive
 
-VIRTUAL_ENV="__VENV_DIR__"
-export VIRTUAL_ENV
+# on Windows, a path can contain colons and backslashes and has to be converted:
+if [ "$OSTYPE" = "cygwin" ] || [ "$OSTYPE" = "msys" ] ; then
+    # transform D:\path\to\venv to /d/path/to/venv on MSYS
+    # and to /cygdrive/d/path/to/venv on Cygwin
+    export VIRTUAL_ENV=$(cygpath "__VENV_DIR__")
+else
+    # use the path as-is
+    export VIRTUAL_ENV="__VENV_DIR__"
+fi
 
 _OLD_VIRTUAL_PATH="$PATH"
 PATH="$VIRTUAL_ENV/__VENV_BIN_NAME__:$PATH"
diff --git a/Misc/NEWS.d/next/Windows/2023-04-11-09-22-22.gh-issue-103088.6AJEuR.rst b/Misc/NEWS.d/next/Windows/2023-04-11-09-22-22.gh-issue-103088.6AJEuR.rst
new file mode 100644 (file)
index 0000000..f9f5343
--- /dev/null
@@ -0,0 +1 @@
+Fixes venvs not working in bash on Windows across different disks\r
index 11d6cba7a172c958d919fc616f50918f12786db7..7af5503d80a0fcaa1db35d3baea4273b74f24856 100644 (file)
@@ -42,7 +42,7 @@
 @if NOT "%HOST_PYTHON%"=="" @%HOST_PYTHON% -Ec "import sys; assert sys.version_info[:2] >= (3, 9)" >nul 2>nul && (set PYTHON="%HOST_PYTHON%") && (set _Py_Python_Source=found as HOST_PYTHON) && goto :found
 
 @rem If py.exe finds a recent enough version, use that one
-@for %%p in (3.10 3.9) do @py -%%p -EV >nul 2>&1 && (set PYTHON=py -%%p) && (set _Py_Python_Source=found %%p with py.exe) && goto :found
+@for %%p in (3.11 3.10 3.9) do @py -%%p -EV >nul 2>&1 && (set PYTHON=py -%%p) && (set _Py_Python_Source=found %%p with py.exe) && goto :found
 
 @if NOT exist "%_Py_EXTERNALS_DIR%" mkdir "%_Py_EXTERNALS_DIR%"
 @set _Py_NUGET=%NUGET%