Fix build of MSVC with OpenSSL 3.0.0
authorMichael Paquier
Wed, 20 Oct 2021 07:48:24 +0000 (16:48 +0900)
committerMichael Paquier
Wed, 20 Oct 2021 07:48:24 +0000 (16:48 +0900)
The build scripts of Visual Studio would fail to detect properly a 3.0.0
build as the check on the second digit was failing.  This is adjusted
where needed, allowing the builds to complete.  Note that the MSIs of
OpenSSL mentioned in the documentation have not changed any library
names for Win32 and Win64, making this change straight-forward.

Reported-by: htalaco, via github
Reviewed-by: Daniel Gustafsson
Discussion: https://postgr.es/m/[email protected]
Backpatch-through: 9.6

src/tools/msvc/Solution.pm

index 165a93987ac4f3ee3dd3835ebe4bee3260ea012c..43fd1be08883277d9311c5a9bbab5b3b58992fc8 100644 (file)
@@ -549,7 +549,8 @@ sub GenerateFiles
        my ($digit1, $digit2, $digit3) = $self->GetOpenSSLVersion();
 
        # More symbols are needed with OpenSSL 1.1.0 and above.
-       if ($digit1 >= '1' && $digit2 >= '1' && $digit3 >= '0')
+       if (   ($digit1 >= '3' && $digit2 >= '0' && $digit3 >= '0')
+           || ($digit1 >= '1' && $digit2 >= '1' && $digit3 >= '0'))
        {
            $define{HAVE_ASN1_STRING_GET0_DATA} = 1;
            $define{HAVE_BIO_GET_DATA}          = 1;
@@ -957,7 +958,8 @@ sub AddProject
        # changed their library names from:
        # - libeay to libcrypto
        # - ssleay to libssl
-       if ($digit1 >= '1' && $digit2 >= '1' && $digit3 >= '0')
+       if (   ($digit1 >= '3' && $digit2 >= '0' && $digit3 >= '0')
+           || ($digit1 >= '1' && $digit2 >= '1' && $digit3 >= '0'))
        {
            my $dbgsuffix;
            my $libsslpath;