blob: 39a37da8b78d6c9da8e9a1d5041f120c3296dab9 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
// file: format/export -*- C++ -*-
#pragma once
// Normally we don't export class templates (but do complete specializations),
// inline functions, and classes with only inline member functions. Exporting
// classes that inherit from non-exported/imported bases (e.g., std::string)
// will end up badly. The only known workarounds are to not inherit or to not
// export. Also, MinGW GCC doesn't like seeing non-exported function being
// used before their inline definition. The workaround is to reorder code. In
// the end it's all trial and error.
#if defined(LIBFORMAT_STATIC) // Using static.
# define LIBFORMAT_EXPORT
#elif defined(LIBFORMAT_STATIC_BUILD) // Building static.
# define LIBFORMAT_EXPORT
#elif defined(LIBFORMAT_SHARED) // Using shared.
# ifdef _WIN32
# define LIBFORMAT_EXPORT __declspec(dllimport)
# else
# define LIBFORMAT_EXPORT
# endif
#elif defined(LIBFORMAT_SHARED_BUILD) // Building shared.
# ifdef _WIN32
# define LIBFORMAT_EXPORT __declspec(dllexport)
# else
# define LIBFORMAT_EXPORT
# endif
#else
// If none of the above macros are defined, then we assume we are being used
// by some third-party build system that cannot/doesn't signal the library
// type. Note that this fallback works for both static and shared but in case
// of shared will be sub-optimal compared to having dllimport.
//
# define LIBFORMAT_EXPORT // Using static or shared.
#endif
|