From a0339c1ef84032b47997fdcd503332a52ffd88bf Mon Sep 17 00:00:00 2001 From: Avasam Date: Sat, 14 Sep 2024 19:39:30 -0400 Subject: [PATCH 1/3] Fix cross-platform compilation using `distutils._msvccompiler.MSVCCompiler` Actually use the `plat_name` param in `MSVCCompiler.initialize` Added tests --- distutils/_msvccompiler.py | 2 +- distutils/tests/test_msvccompiler.py | 24 ++++++++++++++++++++++++ newsfragments/298.bugfix.rst | 1 + 3 files changed, 26 insertions(+), 1 deletion(-) create mode 100644 newsfragments/298.bugfix.rst diff --git a/distutils/_msvccompiler.py b/distutils/_msvccompiler.py index e7652218..97b067c6 100644 --- a/distutils/_msvccompiler.py +++ b/distutils/_msvccompiler.py @@ -284,7 +284,7 @@ def initialize(self, plat_name=None): f"--plat-name must be one of {tuple(_vcvars_names)}" ) - plat_spec = _get_vcvars_spec(get_host_platform(), get_platform()) + plat_spec = _get_vcvars_spec(get_host_platform(), plat_name) vc_env = _get_vc_env(plat_spec) if not vc_env: diff --git a/distutils/tests/test_msvccompiler.py b/distutils/tests/test_msvccompiler.py index 71129cae..028dcdf5 100644 --- a/distutils/tests/test_msvccompiler.py +++ b/distutils/tests/test_msvccompiler.py @@ -2,11 +2,13 @@ import os import sys +import sysconfig import threading import unittest.mock as mock from distutils import _msvccompiler from distutils.errors import DistutilsPlatformError from distutils.tests import support +from distutils.util import get_platform import pytest @@ -28,6 +30,28 @@ def _find_vcvarsall(plat_spec): 'wont find this version', ) + @pytest.mark.skipif( + not sysconfig.get_platform().startswith("win"), + reason="Only run test for non-mingw Windows platforms", + ) + @pytest.mark.parametrize( + "plat_name, expected", + [ + ("win-arm64", "win-arm64"), + ("win-amd64", "win-amd64"), + (None, get_platform()), + ], + ) + def test_cross_platform_compilation_paths(self, monkeypatch, plat_name, expected): + compiler = _msvccompiler.MSVCCompiler() + + # makes sure that the right target platform name is used + def _get_vcvars_spec(host_platform, platform): + assert platform == expected + + monkeypatch.setattr(_msvccompiler, '_get_vcvars_spec', _get_vcvars_spec) + compiler.initialize(plat_name) + @needs_winreg def test_get_vc_env_unicode(self): test_var = 'ṰḖṤṪ┅ṼẨṜ' diff --git a/newsfragments/298.bugfix.rst b/newsfragments/298.bugfix.rst new file mode 100644 index 00000000..eeb10466 --- /dev/null +++ b/newsfragments/298.bugfix.rst @@ -0,0 +1 @@ +Fix cross-platform compilation using `distutils._msvccompiler.MSVCCompiler` -- by :user:`saschanaz` and :user:`Avasam` From d38d1a3e241f3c9a07dad4d1b70f5e1350b7b64e Mon Sep 17 00:00:00 2001 From: "Jason R. Coombs" Date: Sun, 15 Sep 2024 10:26:46 -0400 Subject: [PATCH 2/3] Move the comment to the docstring. --- distutils/tests/test_msvccompiler.py | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/distutils/tests/test_msvccompiler.py b/distutils/tests/test_msvccompiler.py index 028dcdf5..ceb15d3a 100644 --- a/distutils/tests/test_msvccompiler.py +++ b/distutils/tests/test_msvccompiler.py @@ -43,9 +43,11 @@ def _find_vcvarsall(plat_spec): ], ) def test_cross_platform_compilation_paths(self, monkeypatch, plat_name, expected): + """ + Ensure a specified target platform is passed to _get_vcvars_spec. + """ compiler = _msvccompiler.MSVCCompiler() - # makes sure that the right target platform name is used def _get_vcvars_spec(host_platform, platform): assert platform == expected From f15beb8b79a0180c662e832e5517ab42ddb8c946 Mon Sep 17 00:00:00 2001 From: "Jason R. Coombs" Date: Sun, 15 Sep 2024 10:27:33 -0400 Subject: [PATCH 3/3] Use double-backticks for rst compatibility. --- newsfragments/298.bugfix.rst | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/newsfragments/298.bugfix.rst b/newsfragments/298.bugfix.rst index eeb10466..a357d34f 100644 --- a/newsfragments/298.bugfix.rst +++ b/newsfragments/298.bugfix.rst @@ -1 +1 @@ -Fix cross-platform compilation using `distutils._msvccompiler.MSVCCompiler` -- by :user:`saschanaz` and :user:`Avasam` +Fix cross-platform compilation using ``distutils._msvccompiler.MSVCCompiler`` -- by :user:`saschanaz` and :user:`Avasam`