From: Dr. Stephen Henson Date: Thu, 18 Nov 2010 22:56:42 +0000 (+0000) Subject: PR: 2374 X-Git-Tag: OpenSSL_1_0_0c~25 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=3c96907f2b9462045a15929e8692a0482775c757;p=oweals%2Fopenssl.git PR: 2374 Submitted by: Guenter Reviewed by: steve Don't compile capi ENGINE on mingw32 --- diff --git a/engines/e_capi.c b/engines/e_capi.c index e2a7cb58b0..5871491fd6 100644 --- a/engines/e_capi.c +++ b/engines/e_capi.c @@ -76,10 +76,16 @@ * CertGetCertificateContextProperty. CERT_KEY_PROV_INFO_PROP_ID is * one of possible values you can pass to function in question. By * checking if it's defined we can see if wincrypt.h and accompanying - * crypt32.lib are in shape. Yes, it's rather "weak" test and if - * compilation fails, then re-configure with -DOPENSSL_NO_CAPIENG. + * crypt32.lib are in shape. The native MingW32 headers up to and + * including __W32API_VERSION 3.14 lack of struct DSSPUBKEY and the + * defines CERT_STORE_PROV_SYSTEM_A and CERT_STORE_READONLY_FLAG, + * so we check for these too and avoid compiling. + * Yes, it's rather "weak" test and if compilation fails, + * then re-configure with -DOPENSSL_NO_CAPIENG. */ -#ifdef CERT_KEY_PROV_INFO_PROP_ID +#if defined(CERT_KEY_PROV_INFO_PROP_ID) && \ + defined(CERT_STORE_PROV_SYSTEM_A) && \ + defined(CERT_STORE_READONLY_FLAG) # define __COMPILE_CAPIENG #endif /* CERT_KEY_PROV_INFO_PROP_ID */ #endif /* OPENSSL_NO_CAPIENG */