Commit 0e681fa4 authored by Michael Paquier's avatar Michael Paquier

Add support for Visual Studio 2022 in build scripts

Documentation and any code paths related to VS are updated to keep the
whole consistent.  Similarly to 2017 and 2019, the version of VS and the
version of nmake that we use to determine which code paths to use for
the build are still inconsistent in their own way.

Backpatch down to 10, so as buildfarm members are able to use this new
version of Visual Studio on all the stable branches supported.

Author: Hans Buschmann
Discussion: https://postgr.es/m/1633101364685.39218@nidsa.net
Backpatch-through: 10
parent 7933bc0d
...@@ -20,9 +20,9 @@ ...@@ -20,9 +20,9 @@
<para> <para>
There are several different ways of building PostgreSQL on There are several different ways of building PostgreSQL on
<productname>Windows</productname>. The simplest way to build with <productname>Windows</productname>. The simplest way to build with
Microsoft tools is to install <productname>Visual Studio 2019</productname> Microsoft tools is to install <productname>Visual Studio 2022</productname>
and use the included compiler. It is also possible to build with the full and use the included compiler. It is also possible to build with the full
<productname>Microsoft Visual C++ 2013 to 2019</productname>. <productname>Microsoft Visual C++ 2013 to 2022</productname>.
In some cases that requires the installation of the In some cases that requires the installation of the
<productname>Windows SDK</productname> in addition to the compiler. <productname>Windows SDK</productname> in addition to the compiler.
</para> </para>
...@@ -69,7 +69,7 @@ ...@@ -69,7 +69,7 @@
<productname>Microsoft Windows SDK</productname>. If you do not already have a <productname>Microsoft Windows SDK</productname>. If you do not already have a
<productname>Visual Studio</productname> environment set up, the easiest <productname>Visual Studio</productname> environment set up, the easiest
ways are to use the compilers from ways are to use the compilers from
<productname>Visual Studio 2019</productname> or those in the <productname>Visual Studio 2022</productname> or those in the
<productname>Windows SDK 10</productname>, which are both free downloads <productname>Windows SDK 10</productname>, which are both free downloads
from Microsoft. from Microsoft.
</para> </para>
...@@ -78,7 +78,7 @@ ...@@ -78,7 +78,7 @@
Both 32-bit and 64-bit builds are possible with the Microsoft Compiler suite. Both 32-bit and 64-bit builds are possible with the Microsoft Compiler suite.
32-bit PostgreSQL builds are possible with 32-bit PostgreSQL builds are possible with
<productname>Visual Studio 2013</productname> to <productname>Visual Studio 2013</productname> to
<productname>Visual Studio 2019</productname>, <productname>Visual Studio 2022</productname>,
as well as standalone Windows SDK releases 8.1a to 10. as well as standalone Windows SDK releases 8.1a to 10.
64-bit PostgreSQL builds are supported with 64-bit PostgreSQL builds are supported with
<productname>Microsoft Windows SDK</productname> version 8.1a to 10 or <productname>Microsoft Windows SDK</productname> version 8.1a to 10 or
...@@ -86,7 +86,7 @@ ...@@ -86,7 +86,7 @@
is supported down to <productname>Windows 7</productname> and is supported down to <productname>Windows 7</productname> and
<productname>Windows Server 2008 R2 SP1</productname> when building with <productname>Windows Server 2008 R2 SP1</productname> when building with
<productname>Visual Studio 2013</productname> to <productname>Visual Studio 2013</productname> to
<productname>Visual Studio 2019</productname>. <productname>Visual Studio 2022</productname>.
<!-- <!--
For 2013 requirements: For 2013 requirements:
https://docs.microsoft.com/en-us/visualstudio/productinfo/vs2013-sysrequirements-vs https://docs.microsoft.com/en-us/visualstudio/productinfo/vs2013-sysrequirements-vs
...@@ -96,6 +96,8 @@ ...@@ -96,6 +96,8 @@
https://docs.microsoft.com/en-us/visualstudio/productinfo/vs2017-system-requirements-vs https://docs.microsoft.com/en-us/visualstudio/productinfo/vs2017-system-requirements-vs
For 2019 requirements: For 2019 requirements:
https://docs.microsoft.com/en-us/visualstudio/releases/2019/system-requirements https://docs.microsoft.com/en-us/visualstudio/releases/2019/system-requirements
For 2022 requirements:
https://docs.microsoft.com/en-us/visualstudio/releases/2022/system-requirements
--> -->
</para> </para>
......
...@@ -508,4 +508,29 @@ sub new ...@@ -508,4 +508,29 @@ sub new
return $self; return $self;
} }
package VC2022Project;
#
# Package that encapsulates a Visual C++ 2022 project file
#
use strict;
use warnings;
use base qw(MSBuildProject);
no warnings qw(redefine); ## no critic
sub new
{
my $classname = shift;
my $self = $classname->SUPER::_new(@_);
bless($self, $classname);
$self->{vcver} = '17.00';
$self->{PlatformToolset} = 'v143';
$self->{ToolsVersion} = '17.0';
return $self;
}
1; 1;
...@@ -4,7 +4,7 @@ MSVC build ...@@ -4,7 +4,7 @@ MSVC build
========== ==========
This directory contains the tools required to build PostgreSQL using This directory contains the tools required to build PostgreSQL using
Microsoft Visual Studio 2013 - 2019. This builds the whole backend, not just Microsoft Visual Studio 2013 - 2022. This builds the whole backend, not just
the libpq frontend library. For more information, see the documentation the libpq frontend library. For more information, see the documentation
chapter "Installation on Windows" and the description below. chapter "Installation on Windows" and the description below.
...@@ -89,11 +89,11 @@ These configuration arguments are passed over to Mkvcbuild::mkvcbuild ...@@ -89,11 +89,11 @@ These configuration arguments are passed over to Mkvcbuild::mkvcbuild
(Mkvcbuild.pm) which creates the Visual Studio project and solution files. (Mkvcbuild.pm) which creates the Visual Studio project and solution files.
It does this by using VSObjectFactory::CreateSolution to create an object It does this by using VSObjectFactory::CreateSolution to create an object
implementing the Solution interface (this could be either VS2013Solution, implementing the Solution interface (this could be either VS2013Solution,
VS2015Solution, VS2017Solution or VS2019Solution, all in Solution.pm, VS2015Solution, VS2017Solution, VS2019Solution or VS2022Solution, all in
depending on the user's build environment) and adding objects implementing Solution.pm, depending on the user's build environment) and adding objects
the corresponding Project interface (VC2013Project, VC2015Project, implementing the corresponding Project interface (VC2013Project,
VC2017Project or VC2019Project from MSBuildProject.pm) to it. VC2015Project, VC2017Project, VC2019Project or VC2022Project from
When Solution::Save is called, the implementations of Solution and Project MSBuildProject.pm) to it. When Solution::Save is called, the implementations
save their content in the appropriate format. of Solution and Project save their content in the appropriate format.
The final step of starting the appropriate build program (msbuild) is The final step of starting the appropriate build program (msbuild) is
performed in build.pl again. performed in build.pl again.
...@@ -1317,6 +1317,34 @@ sub new ...@@ -1317,6 +1317,34 @@ sub new
return $self; return $self;
} }
package VS2022Solution;
#
# Package that encapsulates a Visual Studio 2022 solution file
#
use Carp;
use strict;
use warnings;
use base qw(Solution);
no warnings qw(redefine); ## no critic
sub new
{
my $classname = shift;
my $self = $classname->SUPER::_new(@_);
bless($self, $classname);
$self->{solutionFileVersion} = '12.00';
$self->{vcver} = '17.00';
$self->{visualStudioName} = 'Visual Studio 2022';
$self->{VisualStudioVersion} = '17.0.31903.59';
$self->{MinimumVisualStudioVersion} = '10.0.40219.1';
return $self;
}
sub GetAdditionalHeaders sub GetAdditionalHeaders
{ {
my ($self, $f) = @_; my ($self, $f) = @_;
......
...@@ -61,6 +61,16 @@ sub CreateSolution ...@@ -61,6 +61,16 @@ sub CreateSolution
{ {
return new VS2019Solution(@_); return new VS2019Solution(@_);
} }
# The version of nmake bundled in Visual Studio 2022 is greater
# than 14.30 and less than 14.40. And the version number is
# actually 17.00.
elsif (
($visualStudioVersion ge '14.30' && $visualStudioVersion lt '14.40')
|| $visualStudioVersion eq '17.00')
{
return new VS2022Solution(@_);
}
else else
{ {
croak croak
...@@ -105,6 +115,16 @@ sub CreateProject ...@@ -105,6 +115,16 @@ sub CreateProject
{ {
return new VC2019Project(@_); return new VC2019Project(@_);
} }
# The version of nmake bundled in Visual Studio 2022 is greater
# than 14.30 and less than 14.40. And the version number is
# actually 17.00.
elsif (
($visualStudioVersion ge '14.30' && $visualStudioVersion lt '14.40')
|| $visualStudioVersion eq '17.00')
{
return new VC2022Project(@_);
}
else else
{ {
croak croak
...@@ -134,7 +154,7 @@ sub DetermineVisualStudioVersion ...@@ -134,7 +154,7 @@ sub DetermineVisualStudioVersion
else else
{ {
# fake version # fake version
return '16.00'; return '17.00';
} }
} }
...@@ -143,13 +163,13 @@ sub _GetVisualStudioVersion ...@@ -143,13 +163,13 @@ sub _GetVisualStudioVersion
my ($major, $minor) = @_; my ($major, $minor) = @_;
# The major visual studio that is supported has nmake # The major visual studio that is supported has nmake
# version <= 14.30, so stick with it as the latest version # version <= 14.40, so stick with it as the latest version
# if bumping on something even newer. # if bumping on something even newer.
if ($major >= 14 && $minor >= 30) if ($major >= 14 && $minor >= 40)
{ {
carp carp
"The determined version of Visual Studio is newer than the latest supported version. Returning the latest supported version instead."; "The determined version of Visual Studio is newer than the latest supported version. Returning the latest supported version instead.";
return '14.20'; return '14.30';
} }
elsif ($major < 12) elsif ($major < 12)
{ {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment