aboutsummaryrefslogtreecommitdiffstats
path: root/meson/test cases/common/145 recursive linking/edge-cases
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/common/145 recursive linking/edge-cases
parente02cda008591317b1625707ff8e115a4841aa889 (diff)
Add submodule dependency filesHEADmaster
Change-Id: Iaf8d18082d3991dec7c0ebbea540f092188eb4ec
Diffstat (limited to 'meson/test cases/common/145 recursive linking/edge-cases')
-rw-r--r--meson/test cases/common/145 recursive linking/edge-cases/libsto.c8
-rw-r--r--meson/test cases/common/145 recursive linking/edge-cases/meson.build9
-rw-r--r--meson/test cases/common/145 recursive linking/edge-cases/shstmain.c16
-rw-r--r--meson/test cases/common/145 recursive linking/edge-cases/stobuilt.c7
-rw-r--r--meson/test cases/common/145 recursive linking/edge-cases/stomain.c16
5 files changed, 56 insertions, 0 deletions
diff --git a/meson/test cases/common/145 recursive linking/edge-cases/libsto.c b/meson/test cases/common/145 recursive linking/edge-cases/libsto.c
new file mode 100644
index 000000000..93f46a88c
--- /dev/null
+++ b/meson/test cases/common/145 recursive linking/edge-cases/libsto.c
@@ -0,0 +1,8 @@
+#include "../lib.h"
+
+int get_builto_value (void);
+
+SYMBOL_EXPORT
+int get_stodep_value (void) {
+ return get_builto_value ();
+}
diff --git a/meson/test cases/common/145 recursive linking/edge-cases/meson.build b/meson/test cases/common/145 recursive linking/edge-cases/meson.build
new file mode 100644
index 000000000..6a46266b4
--- /dev/null
+++ b/meson/test cases/common/145 recursive linking/edge-cases/meson.build
@@ -0,0 +1,9 @@
+# Test https://github.com/mesonbuild/meson/issues/2096
+# Note that removing 'shnodep' from link_with: makes the error go away because
+# then it is added after the static library is added to the link command.
+test('shared-static', executable('shstexe', 'shstmain.c', link_with : [shnodep, stshdep]))
+
+# Static library that needs a symbol defined in an object file. This already
+# works, but good to add a test case early.
+stodep = static_library('stodep', 'libsto.c')
+test('stodep', executable('stodep', 'stomain.c', 'stobuilt.c', link_with : stodep))
diff --git a/meson/test cases/common/145 recursive linking/edge-cases/shstmain.c b/meson/test cases/common/145 recursive linking/edge-cases/shstmain.c
new file mode 100644
index 000000000..334f86788
--- /dev/null
+++ b/meson/test cases/common/145 recursive linking/edge-cases/shstmain.c
@@ -0,0 +1,16 @@
+#include <stdio.h>
+
+#include "../lib.h"
+
+int get_stshdep_value (void);
+
+int main(void) {
+ int val;
+
+ val = get_stshdep_value ();
+ if (val != 1) {
+ printf("st1 value was %i instead of 1\n", val);
+ return -1;
+ }
+ return 0;
+}
diff --git a/meson/test cases/common/145 recursive linking/edge-cases/stobuilt.c b/meson/test cases/common/145 recursive linking/edge-cases/stobuilt.c
new file mode 100644
index 000000000..9cc15bcae
--- /dev/null
+++ b/meson/test cases/common/145 recursive linking/edge-cases/stobuilt.c
@@ -0,0 +1,7 @@
+#include "../lib.h"
+
+
+SYMBOL_EXPORT
+int get_builto_value (void) {
+ return 1;
+}
diff --git a/meson/test cases/common/145 recursive linking/edge-cases/stomain.c b/meson/test cases/common/145 recursive linking/edge-cases/stomain.c
new file mode 100644
index 000000000..a16a89b31
--- /dev/null
+++ b/meson/test cases/common/145 recursive linking/edge-cases/stomain.c
@@ -0,0 +1,16 @@
+#include <stdio.h>
+
+#include "../lib.h"
+
+int get_stodep_value (void);
+
+int main(void) {
+ int val;
+
+ val = get_stodep_value ();
+ if (val != 1) {
+ printf("st1 value was %i instead of 1\n", val);
+ return -1;
+ }
+ return 0;
+}