aboutsummaryrefslogtreecommitdiffstats
path: root/meson/test cases/unit/67 static link
diff options
context:
space:
mode:
authorAngelos Mouzakitis <a.mouzakitis@virtualopensystems.com>2023-10-10 14:33:42 +0000
committerAngelos Mouzakitis <a.mouzakitis@virtualopensystems.com>2023-10-10 14:33:42 +0000
commitaf1a266670d040d2f4083ff309d732d648afba2a (patch)
tree2fc46203448ddcc6f81546d379abfaeb323575e9 /meson/test cases/unit/67 static link
parente02cda008591317b1625707ff8e115a4841aa889 (diff)
Add submodule dependency filesHEADmaster
Change-Id: Iaf8d18082d3991dec7c0ebbea540f092188eb4ec
Diffstat (limited to 'meson/test cases/unit/67 static link')
-rw-r--r--meson/test cases/unit/67 static link/lib/func1.c9
-rw-r--r--meson/test cases/unit/67 static link/lib/func10.c4
-rw-r--r--meson/test cases/unit/67 static link/lib/func11.c6
-rw-r--r--meson/test cases/unit/67 static link/lib/func12.c7
-rw-r--r--meson/test cases/unit/67 static link/lib/func14.c4
-rw-r--r--meson/test cases/unit/67 static link/lib/func15.c6
-rw-r--r--meson/test cases/unit/67 static link/lib/func16.c6
-rw-r--r--meson/test cases/unit/67 static link/lib/func17.c4
-rw-r--r--meson/test cases/unit/67 static link/lib/func18.c6
-rw-r--r--meson/test cases/unit/67 static link/lib/func19.c7
-rw-r--r--meson/test cases/unit/67 static link/lib/func2.c6
-rw-r--r--meson/test cases/unit/67 static link/lib/func3.c4
-rw-r--r--meson/test cases/unit/67 static link/lib/func4.c6
-rw-r--r--meson/test cases/unit/67 static link/lib/func5.c4
-rw-r--r--meson/test cases/unit/67 static link/lib/func6.c6
-rw-r--r--meson/test cases/unit/67 static link/lib/func7.c4
-rw-r--r--meson/test cases/unit/67 static link/lib/func8.c6
-rw-r--r--meson/test cases/unit/67 static link/lib/func9.c6
-rw-r--r--meson/test cases/unit/67 static link/lib/meson.build80
-rw-r--r--meson/test cases/unit/67 static link/meson.build32
-rw-r--r--meson/test cases/unit/67 static link/test1.c7
-rw-r--r--meson/test cases/unit/67 static link/test2.c6
-rw-r--r--meson/test cases/unit/67 static link/test3.c6
-rw-r--r--meson/test cases/unit/67 static link/test4.c6
-rw-r--r--meson/test cases/unit/67 static link/test5.c6
25 files changed, 244 insertions, 0 deletions
diff --git a/meson/test cases/unit/67 static link/lib/func1.c b/meson/test cases/unit/67 static link/lib/func1.c
new file mode 100644
index 000000000..cc934ad04
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func1.c
@@ -0,0 +1,9 @@
+int func1()
+{
+ return 1;
+}
+
+int func1b()
+{
+ return 1;
+}
diff --git a/meson/test cases/unit/67 static link/lib/func10.c b/meson/test cases/unit/67 static link/lib/func10.c
new file mode 100644
index 000000000..75a911fb7
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func10.c
@@ -0,0 +1,4 @@
+int func10()
+{
+ return 1;
+}
diff --git a/meson/test cases/unit/67 static link/lib/func11.c b/meson/test cases/unit/67 static link/lib/func11.c
new file mode 100644
index 000000000..1d5119b47
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func11.c
@@ -0,0 +1,6 @@
+int func10();
+
+int func11()
+{
+ return func10() + 1;
+}
diff --git a/meson/test cases/unit/67 static link/lib/func12.c b/meson/test cases/unit/67 static link/lib/func12.c
new file mode 100644
index 000000000..73db5c073
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func12.c
@@ -0,0 +1,7 @@
+int func10();
+int func11();
+
+int func12()
+{
+ return func10() + func11();
+}
diff --git a/meson/test cases/unit/67 static link/lib/func14.c b/meson/test cases/unit/67 static link/lib/func14.c
new file mode 100644
index 000000000..0277319fc
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func14.c
@@ -0,0 +1,4 @@
+int func14()
+{
+ return 1;
+}
diff --git a/meson/test cases/unit/67 static link/lib/func15.c b/meson/test cases/unit/67 static link/lib/func15.c
new file mode 100644
index 000000000..78303cc2f
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func15.c
@@ -0,0 +1,6 @@
+int func14();
+
+int func15()
+{
+ return func14() + 1;
+}
diff --git a/meson/test cases/unit/67 static link/lib/func16.c b/meson/test cases/unit/67 static link/lib/func16.c
new file mode 100644
index 000000000..379b6829f
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func16.c
@@ -0,0 +1,6 @@
+int func15();
+
+int func16()
+{
+ return func15() + 1;
+}
diff --git a/meson/test cases/unit/67 static link/lib/func17.c b/meson/test cases/unit/67 static link/lib/func17.c
new file mode 100644
index 000000000..d1d8ec498
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func17.c
@@ -0,0 +1,4 @@
+int func17()
+{
+ return 1;
+}
diff --git a/meson/test cases/unit/67 static link/lib/func18.c b/meson/test cases/unit/67 static link/lib/func18.c
new file mode 100644
index 000000000..c149085ba
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func18.c
@@ -0,0 +1,6 @@
+int func17();
+
+int func18()
+{
+ return func17() + 1;
+}
diff --git a/meson/test cases/unit/67 static link/lib/func19.c b/meson/test cases/unit/67 static link/lib/func19.c
new file mode 100644
index 000000000..69120e4bf
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func19.c
@@ -0,0 +1,7 @@
+int func17();
+int func18();
+
+int func19()
+{
+ return func17() + func18();
+}
diff --git a/meson/test cases/unit/67 static link/lib/func2.c b/meson/test cases/unit/67 static link/lib/func2.c
new file mode 100644
index 000000000..6b8f53935
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func2.c
@@ -0,0 +1,6 @@
+int func1();
+
+int func2()
+{
+ return func1() + 1;
+}
diff --git a/meson/test cases/unit/67 static link/lib/func3.c b/meson/test cases/unit/67 static link/lib/func3.c
new file mode 100644
index 000000000..04f9f8939
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func3.c
@@ -0,0 +1,4 @@
+int func3()
+{
+ return 1;
+}
diff --git a/meson/test cases/unit/67 static link/lib/func4.c b/meson/test cases/unit/67 static link/lib/func4.c
new file mode 100644
index 000000000..c44c99099
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func4.c
@@ -0,0 +1,6 @@
+int func3();
+
+int func4()
+{
+ return func3() + 1;
+}
diff --git a/meson/test cases/unit/67 static link/lib/func5.c b/meson/test cases/unit/67 static link/lib/func5.c
new file mode 100644
index 000000000..8e078641c
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func5.c
@@ -0,0 +1,4 @@
+int func5()
+{
+ return 1;
+}
diff --git a/meson/test cases/unit/67 static link/lib/func6.c b/meson/test cases/unit/67 static link/lib/func6.c
new file mode 100644
index 000000000..276fe7d48
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func6.c
@@ -0,0 +1,6 @@
+int func5();
+
+int func6()
+{
+ return func5() + 1;
+}
diff --git a/meson/test cases/unit/67 static link/lib/func7.c b/meson/test cases/unit/67 static link/lib/func7.c
new file mode 100644
index 000000000..8c1a5368d
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func7.c
@@ -0,0 +1,4 @@
+int func7()
+{
+ return 1;
+}
diff --git a/meson/test cases/unit/67 static link/lib/func8.c b/meson/test cases/unit/67 static link/lib/func8.c
new file mode 100644
index 000000000..b7b6cd545
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func8.c
@@ -0,0 +1,6 @@
+int func7();
+
+int func8()
+{
+ return func7() + 1;
+}
diff --git a/meson/test cases/unit/67 static link/lib/func9.c b/meson/test cases/unit/67 static link/lib/func9.c
new file mode 100644
index 000000000..852252d1a
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/func9.c
@@ -0,0 +1,6 @@
+int func8();
+
+int func9()
+{
+ return func8() + 1;
+}
diff --git a/meson/test cases/unit/67 static link/lib/meson.build b/meson/test cases/unit/67 static link/lib/meson.build
new file mode 100644
index 000000000..8f95fc454
--- /dev/null
+++ b/meson/test cases/unit/67 static link/lib/meson.build
@@ -0,0 +1,80 @@
+project('test static link libs', 'c')
+
+pkg = import('pkgconfig')
+
+# libfunc2 should contain both func1() and func2() symbols
+libfunc1 = static_library('func1', 'func1.c',
+ install : false)
+libfunc2 = static_library('func2', 'func2.c',
+ link_whole : libfunc1,
+ install : true)
+
+# Same as above, but with link_with instead of link_whole,
+# libfunc4 should contain both func3() and func4() symbols
+libfunc3 = static_library('func3', 'func3.c',
+ install : false)
+libfunc4 = static_library('func4', 'func4.c',
+ link_with : libfunc3,
+ install : true)
+
+# Same as above, but also generate an pkg-config file. Use both_libraries() to
+# make sure a complete .pc file gets generated. libfunc5 should not be mentioned
+# into the .pc file because it's not installed.
+libfunc5 = static_library('func5', 'func5.c',
+ install : false)
+libfunc6 = both_libraries('func6', 'func6.c',
+ link_with : libfunc5,
+ install : true)
+pkg.generate(libfunc6)
+
+# libfunc9 should contain both func8() and func9() but not func7() because that
+# one gets installed. Also test that link_with and link_whole works the same way
+# because libfunc8 is uninstalled.
+libfunc7 = static_library('func7', 'func7.c',
+ install : true)
+libfunc8 = static_library('func8', 'func8.c',
+ link_with : libfunc7,
+ install : false)
+libfunc9_linkwith = static_library('func9_linkwith', 'func9.c',
+ link_with : libfunc8,
+ install : true)
+libfunc9_linkwhole = static_library('func9_linkwhole', 'func9.c',
+ link_whole : libfunc8,
+ install : true)
+
+# Pattern found in mesa:
+# - libfunc11 uses func10()
+# - libfunc12 uses both func10() and func11()
+# When a shared library link_whole on libfunc12, we ensure we don't include
+# func10.c.o twice which would fail to link.
+libfunc10 = static_library('func10', 'func10.c',
+ install : false)
+libfunc11 = static_library('func11', 'func11.c',
+ link_with : libfunc10,
+ install : false)
+libfunc12 = static_library('func12', 'func12.c',
+ link_with : [libfunc10, libfunc11],
+ install : false)
+libfunc13 = shared_library('func13', link_whole : libfunc12)
+
+# libfunc16 should contain func14(), func15() and func16()
+libfunc14 = static_library('func14', 'func14.c',
+ install : false)
+libfunc15 = static_library('func15', 'func15.c',
+ link_with : libfunc14,
+ install : false)
+libfunc16 = static_library('func16', 'func16.c',
+ link_with : libfunc15,
+ install : true)
+
+# Verify func17.c.o gets included only once into libfunc19, otherwise
+# func19-shared would failed with duplicated symbol.
+libfunc17 = static_library('func17', 'func17.c',
+ install : false)
+libfunc18 = static_library('func18', 'func18.c',
+ link_with : libfunc17,
+ install : false)
+libfunc19 = static_library('func19', 'func19.c',
+ link_whole : [libfunc17, libfunc18],
+ install : false)
+shared_library('func19-shared', link_whole : [libfunc19])
diff --git a/meson/test cases/unit/67 static link/meson.build b/meson/test cases/unit/67 static link/meson.build
new file mode 100644
index 000000000..dac17f810
--- /dev/null
+++ b/meson/test cases/unit/67 static link/meson.build
@@ -0,0 +1,32 @@
+project('test static link', 'c')
+
+cc = meson.get_compiler('c')
+
+# Verify that installed libfunc2.a is usable
+func2_dep = cc.find_library('func2')
+test('test1', executable('test1', 'test1.c', dependencies : func2_dep))
+
+# Verify that installed libfunc4.a is usable
+func4_dep = cc.find_library('func4')
+test('test2', executable('test2', 'test2.c', dependencies : func4_dep))
+
+# Verify that installed pkg-config file is usable for both shared and static link
+func6_static_dep = dependency('func6', static : true)
+test('test3-static', executable('test3-static', 'test3.c',
+ dependencies : func6_static_dep))
+func6_shared_dep = dependency('func6', static : false)
+test('test3-shared', executable('test3-shared', 'test3.c',
+ dependencies : func6_shared_dep))
+
+# Verify that installed libfunc9.a contains func8() and func8() but not func7()
+func7_dep = cc.find_library('func7')
+func9_linkwhole_dep = cc.find_library('func9_linkwhole')
+test('test4-linkwhole', executable('test4-linkwhole', 'test4.c',
+ dependencies : [func7_dep, func9_linkwhole_dep]))
+func9_linkwith_dep = cc.find_library('func9_linkwith')
+test('test4-linkwith', executable('test4-linkwith', 'test4.c',
+ dependencies : [func7_dep, func9_linkwith_dep]))
+
+# Verify that installed libfunc16.a is usable
+libfunc16_dep = cc.find_library('func16')
+test('test5', executable('test5', 'test5.c', dependencies: libfunc16_dep))
diff --git a/meson/test cases/unit/67 static link/test1.c b/meson/test cases/unit/67 static link/test1.c
new file mode 100644
index 000000000..ffc9b9eb9
--- /dev/null
+++ b/meson/test cases/unit/67 static link/test1.c
@@ -0,0 +1,7 @@
+int func1b();
+int func2();
+
+int main(int argc, char *argv[])
+{
+ return func2() + func1b() == 3 ? 0 : 1;
+}
diff --git a/meson/test cases/unit/67 static link/test2.c b/meson/test cases/unit/67 static link/test2.c
new file mode 100644
index 000000000..561422af0
--- /dev/null
+++ b/meson/test cases/unit/67 static link/test2.c
@@ -0,0 +1,6 @@
+int func4();
+
+int main(int argc, char *argv[])
+{
+ return func4() == 2 ? 0 : 1;
+}
diff --git a/meson/test cases/unit/67 static link/test3.c b/meson/test cases/unit/67 static link/test3.c
new file mode 100644
index 000000000..1216064dc
--- /dev/null
+++ b/meson/test cases/unit/67 static link/test3.c
@@ -0,0 +1,6 @@
+int func6();
+
+int main(int argc, char *argv[])
+{
+ return func6() == 2 ? 0 : 1;
+}
diff --git a/meson/test cases/unit/67 static link/test4.c b/meson/test cases/unit/67 static link/test4.c
new file mode 100644
index 000000000..7c281e026
--- /dev/null
+++ b/meson/test cases/unit/67 static link/test4.c
@@ -0,0 +1,6 @@
+int func9();
+
+int main(int argc, char *argv[])
+{
+ return func9() == 3 ? 0 : 1;
+}
diff --git a/meson/test cases/unit/67 static link/test5.c b/meson/test cases/unit/67 static link/test5.c
new file mode 100644
index 000000000..6020f0e7c
--- /dev/null
+++ b/meson/test cases/unit/67 static link/test5.c
@@ -0,0 +1,6 @@
+int func16();
+
+int main(int argc, char *argv[])
+{
+ return func16() == 3 ? 0 : 1;
+}