diff options
author | Steve Dower <steve.dower@python.org> | 2020-03-11 23:24:30 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-03-11 23:24:30 (GMT) |
commit | 894adc18b4fb7246b762276a50a332c0e4f0e0f0 (patch) | |
tree | 5557b444ef206216757ad78c5c5e920a338e51d8 | |
parent | 196f1eb6adcfc6a7239330ef508b8bf9dff9940f (diff) | |
download | cpython-894adc18b4fb7246b762276a50a332c0e4f0e0f0.zip cpython-894adc18b4fb7246b762276a50a332c0e4f0e0f0.tar.gz cpython-894adc18b4fb7246b762276a50a332c0e4f0e0f0.tar.bz2 |
bpo-39930: Fix MSBuild detection for Build Tools (GH-18938)
Ensure we detect Build Tools installs using the newer logic, and skip looking in the registry for VS 2017.
-rw-r--r-- | PCbuild/find_msbuild.bat | 9 | ||||
-rw-r--r-- | PCbuild/pyproject.props | 34 |
2 files changed, 27 insertions, 16 deletions
diff --git a/PCbuild/find_msbuild.bat b/PCbuild/find_msbuild.bat index bc9d00c..ce7e71e 100644 --- a/PCbuild/find_msbuild.bat +++ b/PCbuild/find_msbuild.bat @@ -32,20 +32,13 @@ @rem VS 2017 and later provide vswhere.exe, which can be used @if not exist "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" goto :skip_vswhere @set _Py_MSBuild_Root= -@for /F "tokens=*" %%i in ('"%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -property installationPath -latest -prerelease') DO @(set _Py_MSBuild_Root=%%i\MSBuild) +@for /F "tokens=*" %%i in ('"%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -property installationPath -latest -prerelease -products * -requires Microsoft.VisualStudio.Component.VC.Tools.x86.x64') DO @(set _Py_MSBuild_Root=%%i\MSBuild) @if not defined _Py_MSBuild_Root goto :skip_vswhere @for %%j in (Current 15.0) DO @if exist "%_Py_MSBuild_Root%\%%j\Bin\msbuild.exe" (set MSBUILD="%_Py_MSBuild_Root%\%%j\Bin\msbuild.exe") @set _Py_MSBuild_Root= @if defined MSBUILD @if exist %MSBUILD% (set _Py_MSBuild_Source=Visual Studio installation) & goto :found :skip_vswhere -@rem VS 2017 sets exactly one install as the "main" install, so we may find MSBuild in there. -@reg query "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\VisualStudio\SxS\VS7" /v 15.0 /reg:32 >nul 2>nul -@if NOT ERRORLEVEL 1 @for /F "tokens=1,2*" %%i in ('reg query "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\VisualStudio\SxS\VS7" /v 15.0 /reg:32') DO @( - @if "%%i"=="15.0" @if exist "%%k\MSBuild\15.0\Bin\msbuild.exe" @(set MSBUILD="%%k\MSBuild\15.0\Bin\msbuild.exe") -) -@if exist %MSBUILD% (set _Py_MSBuild_Source=Visual Studio 2017 registry) & goto :found - @rem VS 2015 and earlier register MSBuild separately, so we can find it. @reg query "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSBuild\ToolsVersions\14.0" /v MSBuildToolsPath /reg:32 >nul 2>nul @if NOT ERRORLEVEL 1 @for /F "tokens=1,2*" %%i in ('reg query "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSBuild\ToolsVersions\14.0" /v MSBuildToolsPath /reg:32') DO @( diff --git a/PCbuild/pyproject.props b/PCbuild/pyproject.props index 061c225..bb918b2 100644 --- a/PCbuild/pyproject.props +++ b/PCbuild/pyproject.props @@ -201,23 +201,41 @@ public override bool Execute() { </Target> - <Target Name="FindVCRuntime" Returns="VCRuntimeDLL"> - <PropertyGroup Condition="$(PlatformToolset) != 'v140'"> - <VCRedistDir>$(VCInstallDir)\Redist\MSVC\$(VCToolsRedistVersion)\</VCRedistDir> - <VCRedistDir Condition="$(Platform) == 'Win32'">$(VCRedistDir)x86\</VCRedistDir> - <VCRedistDir Condition="$(Platform) != 'Win32'">$(VCRedistDir)$(Platform)\</VCRedistDir> - </PropertyGroup> + <Target Name="FindVCRedistDir"> + <!-- Hard coded path for VS 2015 --> <PropertyGroup Condition="$(PlatformToolset) == 'v140'"> <VCRedistDir>$(VCInstallDir)\redist\</VCRedistDir> + </PropertyGroup> + + <!-- Search for version number in some broken Build Tools installs --> + <ItemGroup Condition="$(VCRedistDir) == '' and $(VCToolsRedistVersion) == ''"> + <_RedistFiles Include="$(VCInstallDir)\Redist\MSVC\*\*.*" /> + </ItemGroup> + <PropertyGroup Condition="$(VCRedistDir) == '' and $(VCToolsRedistVersion) == ''"> + <_RedistDir>%(_RedistFiles.Directory)</_RedistDir> + <VCToolsRedistVersion>$([System.IO.Path]::GetFileName($(_RedistDir.Trim(`\`))))</VCToolsRedistVersion> + </PropertyGroup> + + <!-- Use correct path for VS 2017 and later --> + <PropertyGroup Condition="$(VCRedistDir) == ''"> + <VCRedistDir>$(VCInstallDir)\Redist\MSVC\$(VCToolsRedistVersion)\</VCRedistDir> + </PropertyGroup> + + <PropertyGroup> <VCRedistDir Condition="$(Platform) == 'Win32'">$(VCRedistDir)x86\</VCRedistDir> <VCRedistDir Condition="$(Platform) != 'Win32'">$(VCRedistDir)$(Platform)\</VCRedistDir> </PropertyGroup> + <Message Text="VC Redist Directory: $(VCRedistDir)" /> + <Message Text="VC Redist Version: $(VCToolsRedistVersion)" /> + </Target> + + <Target Name="FindVCRuntime" Returns="VCRuntimeDLL" DependsOnTargets="FindVCRedistDir"> <ItemGroup Condition="$(VCInstallDir) != ''"> <VCRuntimeDLL Include="$(VCRedistDir)\Microsoft.VC*.CRT\vcruntime*.dll" /> </ItemGroup> - <Warning Text="vcruntime14*.dll not found under $(VCInstallDir)" Condition="@(VCRuntimeDLL) == ''" /> - <Message Text="VCRuntimeDLL: @(VCRuntimeDLL)" Importance="high" /> + <Warning Text="vcruntime*.dll not found under $(VCRedistDir)." Condition="@(VCRuntimeDLL) == ''" /> + <Message Text="VC Runtime DLL(s):%0A- @(VCRuntimeDLL,'%0A- ')" /> </Target> </Project> |