diff options
author | David Seifert <soap@gentoo.org> | 2018-03-19 08:16:25 -0700 |
---|---|---|
committer | Jussi Pakkanen <jpakkane@gmail.com> | 2018-03-19 23:37:14 +0200 |
commit | 7eb187c5f2cf55c6d441db08a87bac02cb58a9dc (patch) | |
tree | 57d824083ff7a54fc08752b4574b23bcb8853ed3 /test cases | |
parent | 50c66f1f5c099cb1286dab8a646bed55f39d1e3e (diff) | |
download | meson-7eb187c5f2cf55c6d441db08a87bac02cb58a9dc.zip meson-7eb187c5f2cf55c6d441db08a87bac02cb58a9dc.tar.gz meson-7eb187c5f2cf55c6d441db08a87bac02cb58a9dc.tar.bz2 |
Add -Wl,-dead_strip_dylibs support
* `-Wl,-dead_strip_dylibs` is the analogue
of `-Wl,--as-needed` on macOS.
Diffstat (limited to 'test cases')
-rw-r--r-- | test cases/common/183 as-needed/config.h | 14 | ||||
-rw-r--r-- | test cases/common/183 as-needed/libA.cpp | 7 | ||||
-rw-r--r-- | test cases/common/183 as-needed/libA.h | 5 | ||||
-rw-r--r-- | test cases/common/183 as-needed/libB.cpp | 19 | ||||
-rw-r--r-- | test cases/common/183 as-needed/main.cpp | 7 | ||||
-rw-r--r-- | test cases/common/183 as-needed/meson.build | 13 |
6 files changed, 65 insertions, 0 deletions
diff --git a/test cases/common/183 as-needed/config.h b/test cases/common/183 as-needed/config.h new file mode 100644 index 0000000..b8fb60f --- /dev/null +++ b/test cases/common/183 as-needed/config.h @@ -0,0 +1,14 @@ +#if defined _WIN32 || defined __CYGWIN__ + #if defined BUILDING_DLL + #define DLL_PUBLIC __declspec(dllexport) + #else + #define DLL_PUBLIC __declspec(dllimport) + #endif +#else + #if defined __GNUC__ + #define DLL_PUBLIC __attribute__ ((visibility("default"))) + #else + #pragma message ("Compiler does not support symbol visibility.") + #define DLL_PUBLIC + #endif +#endif diff --git a/test cases/common/183 as-needed/libA.cpp b/test cases/common/183 as-needed/libA.cpp new file mode 100644 index 0000000..5f45bc0 --- /dev/null +++ b/test cases/common/183 as-needed/libA.cpp @@ -0,0 +1,7 @@ +#define BUILDING_DLL + +#include "libA.h" + +namespace meson_test_as_needed { + DLL_PUBLIC bool linked = false; +} diff --git a/test cases/common/183 as-needed/libA.h b/test cases/common/183 as-needed/libA.h new file mode 100644 index 0000000..8e76d22 --- /dev/null +++ b/test cases/common/183 as-needed/libA.h @@ -0,0 +1,5 @@ +#include "config.h" + +namespace meson_test_as_needed { + DLL_PUBLIC extern bool linked; +} diff --git a/test cases/common/183 as-needed/libB.cpp b/test cases/common/183 as-needed/libB.cpp new file mode 100644 index 0000000..a872394 --- /dev/null +++ b/test cases/common/183 as-needed/libB.cpp @@ -0,0 +1,19 @@ +#include "libA.h" + +#undef DLL_PUBLIC +#define BUILDING_DLL +#include "config.h" + +namespace meson_test_as_needed { + namespace { + bool set_linked() { + linked = true; + return true; + } + bool stub = set_linked(); + } + + DLL_PUBLIC int libB_unused_func() { + return 0; + } +} diff --git a/test cases/common/183 as-needed/main.cpp b/test cases/common/183 as-needed/main.cpp new file mode 100644 index 0000000..cecb2ff --- /dev/null +++ b/test cases/common/183 as-needed/main.cpp @@ -0,0 +1,7 @@ +#include <cstdlib> + +#include "libA.h" + +int main() { + return (meson_test_as_needed::linked == false ? EXIT_SUCCESS : EXIT_FAILURE); +} diff --git a/test cases/common/183 as-needed/meson.build b/test cases/common/183 as-needed/meson.build new file mode 100644 index 0000000..3b54aaa --- /dev/null +++ b/test cases/common/183 as-needed/meson.build @@ -0,0 +1,13 @@ +project('as-needed test', 'cpp') + +# Idea behind this test is to have -Wl,--as-needed prune +# away unneeded linkages, which would otherwise cause global +# static initialiser side-effects to set a boolean to true. + +# Credits for portable ISO C++ idea go to sarum9in + +libA = library('A', 'libA.cpp') +libB = library('B', 'libB.cpp', link_with : libA) + +main_exe = executable('C', 'main.cpp', link_with : [libA, libB]) +test('main test', main_exe) |