mdbx: fix static library build on Windows.

This commit is contained in:
Leonid Yuriev 2019-10-24 11:51:25 +03:00
parent 411ed3e578
commit ed515d4642
2 changed files with 11 additions and 5 deletions

12
mdbx.h
View File

@ -643,6 +643,13 @@ extern "C" {
#endif
/**** MDBX version information ************************************************/
#if defined(LIBMDBX_IMPORTS)
#define LIBMDBX_VERINFO_API __dll_import
#else
#define LIBMDBX_VERINFO_API __dll_export
#endif /* LIBMDBX_VERINFO_API */
typedef struct mdbx_version_info {
uint8_t major;
uint8_t minor;
@ -656,7 +663,7 @@ typedef struct mdbx_version_info {
} git;
const char *sourcery /* sourcery anchor for pinning */;
} mdbx_version_info;
extern LIBMDBX_API const mdbx_version_info mdbx_version;
extern LIBMDBX_VERINFO_API const mdbx_version_info mdbx_version;
/* MDBX build information.
* WARNING: Some strings could be NULL in case no corresponding information was
@ -668,8 +675,7 @@ typedef struct mdbx_build_info {
const char *compiler /* compiler */;
const char *flags /* CFLAGS */;
} mdbx_build_info;
extern LIBMDBX_API const mdbx_build_info mdbx_build;
extern LIBMDBX_VERINFO_API const mdbx_build_info mdbx_build;
#if defined(_WIN32) || defined(_WIN64)
#if !MDBX_BUILD_SHARED_LIBRARY

View File

@ -26,7 +26,7 @@
static void mdbx_winnt_import(void);
#ifdef MDBX_BUILD_SHARED_LIBRARY
#if MDBX_BUILD_SHARED_LIBRARY
#if MDBX_AVOID_CRT && defined(NDEBUG)
/* DEBUG/CHECKED builds still require MSVC's CRT for runtime checks.
*
@ -35,7 +35,7 @@ static void mdbx_winnt_import(void);
* automatically use DllMainCRTStartup() from CRT library, which also
* automatically call DllMain() from our mdbx.dll */
#pragma comment(linker, "/ENTRY:DllMain")
#endif
#endif /* MDBX_AVOID_CRT */
BOOL APIENTRY DllMain(HANDLE module, DWORD reason, LPVOID reserved)
#else