Fix build of MSVC with OpenSSL 3.0.0
authorMichael Paquier <michael@paquier.xyz>
Wed, 20 Oct 2021 07:48:57 +0000 (16:48 +0900)
committerMichael Paquier <michael@paquier.xyz>
Wed, 20 Oct 2021 07:48:57 +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/YW5XKYkq6k7OtrFq@paquier.xyz
Backpatch-through: 9.6

src/tools/msvc/Solution.pm

index cfda5ac18551d9dd7b83f4543e33e4e0d4e9a648..eaec9f14bc1078fb7c9d9c65ebc7e5d5df77c588 100644 (file)
@@ -547,7 +547,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;
@@ -955,7 +956,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;