aboutsummaryrefslogtreecommitdiffstats
path: root/meson/test cases/common/178 bothlibraries
diff options
context:
space:
mode:
Diffstat (limited to 'meson/test cases/common/178 bothlibraries')
-rw-r--r--meson/test cases/common/178 bothlibraries/dummy.py8
-rw-r--r--meson/test cases/common/178 bothlibraries/libfile.c7
-rw-r--r--meson/test cases/common/178 bothlibraries/main.c8
-rw-r--r--meson/test cases/common/178 bothlibraries/meson.build50
-rw-r--r--meson/test cases/common/178 bothlibraries/mylib.h13
5 files changed, 86 insertions, 0 deletions
diff --git a/meson/test cases/common/178 bothlibraries/dummy.py b/meson/test cases/common/178 bothlibraries/dummy.py
new file mode 100644
index 000000000..9e838bae9
--- /dev/null
+++ b/meson/test cases/common/178 bothlibraries/dummy.py
@@ -0,0 +1,8 @@
+#!/usr/bin/env python3
+
+from pathlib import Path
+import sys
+
+if __name__ == '__main__':
+ Path(sys.argv[1]).write_text('Hello World\n')
+ raise SystemExit(0)
diff --git a/meson/test cases/common/178 bothlibraries/libfile.c b/meson/test cases/common/178 bothlibraries/libfile.c
new file mode 100644
index 000000000..f5e228ec1
--- /dev/null
+++ b/meson/test cases/common/178 bothlibraries/libfile.c
@@ -0,0 +1,7 @@
+#include "mylib.h"
+
+DO_EXPORT int retval = 42;
+
+DO_EXPORT int func(void) {
+ return retval;
+}
diff --git a/meson/test cases/common/178 bothlibraries/main.c b/meson/test cases/common/178 bothlibraries/main.c
new file mode 100644
index 000000000..8237bae0a
--- /dev/null
+++ b/meson/test cases/common/178 bothlibraries/main.c
@@ -0,0 +1,8 @@
+#include "mylib.h"
+
+DO_IMPORT int func(void);
+DO_IMPORT int retval;
+
+int main(void) {
+ return func() == retval ? 0 : 1;
+}
diff --git a/meson/test cases/common/178 bothlibraries/meson.build b/meson/test cases/common/178 bothlibraries/meson.build
new file mode 100644
index 000000000..f3191cc5d
--- /dev/null
+++ b/meson/test cases/common/178 bothlibraries/meson.build
@@ -0,0 +1,50 @@
+project('both libraries linking test', 'c')
+
+both_libs = both_libraries('mylib', 'libfile.c')
+dep = declare_dependency(link_with: both_libs)
+exe_shared = executable('prog-shared', 'main.c', link_with : both_libs.get_shared_lib())
+exe_static = executable('prog-static', 'main.c',
+ c_args : ['-DSTATIC_COMPILATION'],
+ link_with : both_libs.get_static_lib())
+exe_both = executable('prog-both', 'main.c', link_with : both_libs)
+exe_dep = executable('prog-dep', 'main.c', dependencies : [dep])
+
+# Try using it in a custom_target
+custom_target('tgt_a',
+ command: [
+ find_program('./dummy.py'),
+ '@OUTPUT@',
+ both_libs,
+ ],
+ output: ['hello1.txt'],
+ input: [both_libs],
+)
+
+test('runtest-shared', exe_shared)
+test('runtest-static', exe_static)
+test('runtest-both', exe_both)
+test('runtest-dep', exe_dep)
+
+# Same as above, but using build_target()
+both_libs2 = build_target('mylib2', 'libfile.c', target_type: 'both_libraries')
+exe_shared2 = executable('prog-shared2', 'main.c',
+ link_with : both_libs2.get_shared_lib())
+exe_static2 = executable('prog-static2', 'main.c',
+ c_args : ['-DSTATIC_COMPILATION'],
+ link_with : both_libs2.get_static_lib())
+exe_both2 = executable('prog-both2', 'main.c', link_with : both_libs2)
+
+# Test {set,get}_variable
+set_variable('both_libs2', both_libs)
+both_libs3 = get_variable('both_libs')
+
+# Ensure that calling the build target methods also works
+assert(both_libs.name() == 'mylib')
+assert(both_libs2.name() == 'mylib')
+assert(both_libs3.name() == 'mylib')
+assert(both_libs2.get_shared_lib().name() == 'mylib')
+assert(both_libs3.get_static_lib().name() == 'mylib')
+
+test('runtest-shared-2', exe_shared2)
+test('runtest-static-2', exe_static2)
+test('runtest-both-2', exe_both2)
diff --git a/meson/test cases/common/178 bothlibraries/mylib.h b/meson/test cases/common/178 bothlibraries/mylib.h
new file mode 100644
index 000000000..1038a0142
--- /dev/null
+++ b/meson/test cases/common/178 bothlibraries/mylib.h
@@ -0,0 +1,13 @@
+#pragma once
+
+#ifdef _WIN32
+ #ifdef STATIC_COMPILATION
+ #define DO_IMPORT extern
+ #else
+ #define DO_IMPORT __declspec(dllimport)
+ #endif
+ #define DO_EXPORT __declspec(dllexport)
+#else
+ #define DO_IMPORT extern
+ #define DO_EXPORT
+#endif