From e2cb6e37671c283c31ef5494012ec462f3fb87ec Mon Sep 17 00:00:00 2001 From: Hari Babu Date: Wed, 20 Mar 2019 18:35:56 +1100 Subject: [PATCH] Support building with visual studio 2019 --- doc/src/sgml/install-windows.sgml | 22 +++++++++-------- src/tools/msvc/MSBuildProject.pm | 25 +++++++++++++++++++ src/tools/msvc/README | 10 ++++---- src/tools/msvc/Solution.pm | 28 +++++++++++++++++++++ src/tools/msvc/VSObjectFactory.pm | 41 ++++++++++++++++++++++++------- 5 files changed, 102 insertions(+), 24 deletions(-) diff --git a/doc/src/sgml/install-windows.sgml b/doc/src/sgml/install-windows.sgml index 22a2ffd55e..cc5c9e81da 100644 --- a/doc/src/sgml/install-windows.sgml +++ b/doc/src/sgml/install-windows.sgml @@ -19,10 +19,10 @@ There are several different ways of building PostgreSQL on Windows. The simplest way to build with - Microsoft tools is to install Visual Studio Express 2017 + Microsoft tools is to install Visual Studio Express 2019 for Windows Desktop and use the included compiler. It is also possible to build with the full - Microsoft Visual C++ 2013 to 2017. + Microsoft Visual C++ 2013 to 2019. In some cases that requires the installation of the Windows SDK in addition to the compiler. @@ -69,24 +69,24 @@ Visual Studio Express or some versions of the Microsoft Windows SDK. If you do not already have a Visual Studio environment set up, the easiest - ways are to use the compilers from Visual Studio Express 2017 + ways are to use the compilers from Visual Studio Express 2019 for Windows Desktop or those in the Windows SDK - 8.1, which are both free downloads from Microsoft. + 10, which are both free downloads from Microsoft. Both 32-bit and 64-bit builds are possible with the Microsoft Compiler suite. 32-bit PostgreSQL builds are possible with Visual Studio 2013 to - Visual Studio 2017 (including Express editions), - as well as standalone Windows SDK releases 6.0 to 8.1. + Visual Studio 2019 (including Express editions), + as well as standalone Windows SDK releases 8.1a to 10. 64-bit PostgreSQL builds are supported with - Microsoft Windows SDK version 6.0a to 8.1 or + Microsoft Windows SDK version 8.1a to 10 or Visual Studio 2013 and above. Compilation is supported down to Windows 7 and Windows Server 2008 R2 SP1 when building with Visual Studio 2013 to - Visual Studio 2017. + Visual Studio 2019. @@ -166,7 +168,7 @@ $ENV{MSBFLAGS}="/m"; If your build environment doesn't ship with a supported version of the Microsoft Windows SDK it is recommended that you upgrade to the latest version (currently - version 7.1), available for download from + version 10), available for download from . @@ -175,7 +177,7 @@ $ENV{MSBFLAGS}="/m"; If you install a Windows SDK including the Visual C++ Compilers, you don't need Visual Studio to build. - Note that as of Version 8.0a the Windows SDK no longer ships with a + Note that as of Version 8.1a the Windows SDK no longer ships with a complete command-line build environment. diff --git a/src/tools/msvc/MSBuildProject.pm b/src/tools/msvc/MSBuildProject.pm index 149213378c..ca965bdf1a 100644 --- a/src/tools/msvc/MSBuildProject.pm +++ b/src/tools/msvc/MSBuildProject.pm @@ -467,4 +467,29 @@ sub new return $self; } +package VC2019Project; + +# +# Package that encapsulates a Visual C++ 2019 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} = '16.00'; + $self->{PlatformToolset} = 'v142'; + $self->{ToolsVersion} = '16.0'; + + return $self; +} + 1; diff --git a/src/tools/msvc/README b/src/tools/msvc/README index 4ab81d3402..45d71541fc 100644 --- a/src/tools/msvc/README +++ b/src/tools/msvc/README @@ -4,7 +4,7 @@ MSVC build ========== This directory contains the tools required to build PostgreSQL using -Microsoft Visual Studio 2013 - 2017. This builds the whole backend, not just +Microsoft Visual Studio 2013 - 2019. This builds the whole backend, not just the libpq frontend library. For more information, see the documentation chapter "Installation on Windows" and the description below. @@ -89,10 +89,10 @@ These configuration arguments are passed over to Mkvcbuild::mkvcbuild (Mkvcbuild.pm) which creates the Visual Studio project and solution files. It does this by using VSObjectFactory::CreateSolution to create an object implementing the Solution interface (this could be either a VS2013Solution, -or a VS2015Solution or a VS2017Solution, all in Solution.pm, depending on -the user's build environment) and adding objects implementing the corresponding -Project interface (VC2013Project or VC2015Project or VC2017Project from -MSBuildProject.pm) to it. +or a VS2015Solution or a VS2017Solution or a VS2019Solution, all in Solution.pm, +depending on the user's build environment) and adding objects implementing +the corresponding Project interface (VC2013Project or VC2015Project or VC2017Project +or VC2019Project from MSBuildProject.pm) to it. When Solution::Save is called, the implementations of Solution and Project save their content in the appropriate format. The final step of starting the appropriate build program (msbuild) is diff --git a/src/tools/msvc/Solution.pm b/src/tools/msvc/Solution.pm index 90a8d69e99..7ce440e314 100644 --- a/src/tools/msvc/Solution.pm +++ b/src/tools/msvc/Solution.pm @@ -889,6 +889,34 @@ sub new return $self; } +package VS2019Solution; + +# +# Package that encapsulates a Visual Studio 2017 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} = '16.00'; + $self->{visualStudioName} = 'Visual Studio 2019'; + $self->{VisualStudioVersion} = '16.0.32.32432'; + $self->{MinimumVisualStudioVersion} = '10.0.40219.1'; + + return $self; +} + sub GetAdditionalHeaders { my ($self, $f) = @_; diff --git a/src/tools/msvc/VSObjectFactory.pm b/src/tools/msvc/VSObjectFactory.pm index 1a94cd866e..b39e51f2da 100644 --- a/src/tools/msvc/VSObjectFactory.pm +++ b/src/tools/msvc/VSObjectFactory.pm @@ -39,15 +39,24 @@ sub CreateSolution return new VS2015Solution(@_); } - # visual 2017 hasn't changed the nmake version to 15, so adjust the check to support it. + # visual 2017 nmake version is greather than 14.10 and less than 14.20. + # so adjust the check to support it. elsif (($visualStudioVersion ge '14.10') - or ($visualStudioVersion eq '15.00')) + and ($visualStudioVersion lt '14.20')) { return new VS2017Solution(@_); } + + # visual 2019 nmake version is greather than 14.20 and less than 14.30 (expected). + # so adjust the check to support it. + elsif (($visualStudioVersion ge '14.20') + and ($visualStudioVersion lt '14.30')) + { + return new VS2019Solution(@_); + } else { - croak $visualStudioVersion; + carp $visualStudioVersion; croak "The requested Visual Studio version is not supported."; } } @@ -70,15 +79,28 @@ sub CreateProject return new VC2015Project(@_); } - # visual 2017 hasn't changed the nmake version to 15, so adjust the check to support it. - elsif (($visualStudioVersion ge '14.10') + # visual 2017 nmake version is greather than 14.10 and less than 14.20. + # but the version number is 15.00 + # so adjust the check to support it. + elsif ((($visualStudioVersion ge '14.10') + and ($visualStudioVersion lt '14.20')) or ($visualStudioVersion eq '15.00')) { return new VC2017Project(@_); } + + # visual 2019 nmake version is greather than 14.20 and less than 14.30 (expected). + # but the version number is 16.00 + # so adjust the check to support it. + elsif ((($visualStudioVersion ge '14.20') + and ($visualStudioVersion lt '14.30')) + or ($visualStudioVersion eq '16.00')) + { + return new VC2019Project(@_); + } else { - croak $visualStudioVersion; + carp $visualStudioVersion; croak "The requested Visual Studio version is not supported."; } } @@ -106,18 +128,19 @@ sub _GetVisualStudioVersion { my ($major, $minor) = @_; - # visual 2017 hasn't changed the nmake version to 15, so still using the older version for comparison. + # The major visual stuido that is suppored nmake version is >= 14.20 and < 15. if ($major > 14) { carp "The determined version of Visual Studio is newer than the latest supported version. Returning the latest supported version instead."; return '14.00'; } - elsif ($major < 6) + elsif ($major < 12) { croak - "Unable to determine Visual Studio version: Visual Studio versions before 6.0 aren't supported."; + "Unable to determine Visual Studio version: Visual Studio versions before 12.0 aren't supported."; } + return "$major.$minor"; } -- 2.20.1.windows.1