]> granicus.if.org Git - postgresql/commitdiff
Honor MSVC WindowsSDKVersion if set
authorAndrew Dunstan <andrew@dunslane.net>
Thu, 25 Jul 2019 15:24:23 +0000 (11:24 -0400)
committerAndrew Dunstan <andrew@dunslane.net>
Thu, 25 Jul 2019 15:40:09 +0000 (11:40 -0400)
Add a line to the project file setting the target SDK. Otherwise, in for
example VS2017, if the default but optional 8.1 SDK is not installed the
build will fail.

Patch from Peifeng Qiu, slightly edited by me.

Discussion: https://postgr.es/m/CABmtVJhw1boP_bd4=b3Qv5YnqEdL696NtHFi2ruiyQ6mFHkeQQ@mail.gmail.com

Backpatch to all live branches.

src/tools/msvc/MSBuildProject.pm

index d0f2fe7779eafce420ca6507e2b939da2c0e8e87..6da864393cec3b4534ce91d59275c6331d56e19b 100644 (file)
@@ -38,6 +38,19 @@ EOF
   </ItemGroup>
   <PropertyGroup Label="Globals">
     <ProjectGuid>$self->{guid}</ProjectGuid>
+EOF
+       # Check whether WindowsSDKVersion env variable is present.
+       # Add WindowsTargetPlatformVersion node if so.
+       my $sdkVersion = $ENV{'WindowsSDKVersion'};
+       if (defined($sdkVersion))
+       {
+               # remove trailing backslash if necessary.
+               $sdkVersion, =~  s/\\$//;
+               print $f <<EOF
+    <WindowsTargetPlatformVersion>$sdkVersion</WindowsTargetPlatformVersion>
+EOF
+       }
+       print $f <<EOF;
   </PropertyGroup>
   <Import Project="\$(VCTargetsPath)\\Microsoft.Cpp.Default.props" />
 EOF