aboutsummaryrefslogtreecommitdiffstats
path: root/meson/test cases/unit/40 external, internal library rpath
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/40 external, internal library rpath
parente02cda008591317b1625707ff8e115a4841aa889 (diff)
Add submodule dependency filesHEADmaster
Change-Id: Iaf8d18082d3991dec7c0ebbea540f092188eb4ec
Diffstat (limited to 'meson/test cases/unit/40 external, internal library rpath')
-rw-r--r--meson/test cases/unit/40 external, internal library rpath/built library/bar.c7
-rw-r--r--meson/test cases/unit/40 external, internal library rpath/built library/meson.build26
-rw-r--r--meson/test cases/unit/40 external, internal library rpath/built library/meson_options.txt1
-rw-r--r--meson/test cases/unit/40 external, internal library rpath/built library/prog.c7
-rw-r--r--meson/test cases/unit/40 external, internal library rpath/external library/bar.c6
-rw-r--r--meson/test cases/unit/40 external, internal library rpath/external library/faa.c4
-rw-r--r--meson/test cases/unit/40 external, internal library rpath/external library/foo.c4
-rw-r--r--meson/test cases/unit/40 external, internal library rpath/external library/meson.build22
8 files changed, 77 insertions, 0 deletions
diff --git a/meson/test cases/unit/40 external, internal library rpath/built library/bar.c b/meson/test cases/unit/40 external, internal library rpath/built library/bar.c
new file mode 100644
index 000000000..4f5662ebd
--- /dev/null
+++ b/meson/test cases/unit/40 external, internal library rpath/built library/bar.c
@@ -0,0 +1,7 @@
+int foo_system_value (void);
+int faa_system_value (void);
+
+int bar_built_value (int in)
+{
+ return faa_system_value() + foo_system_value() + in;
+}
diff --git a/meson/test cases/unit/40 external, internal library rpath/built library/meson.build b/meson/test cases/unit/40 external, internal library rpath/built library/meson.build
new file mode 100644
index 000000000..07fe7bb2b
--- /dev/null
+++ b/meson/test cases/unit/40 external, internal library rpath/built library/meson.build
@@ -0,0 +1,26 @@
+project('built library', 'c')
+
+cc = meson.get_compiler('c')
+
+if host_machine.system() != 'cygwin'
+ # bar_in_system has undefined symbols, but still must be found
+ bar_system_dep = cc.find_library('bar_in_system')
+endif
+
+foo_system_dep = cc.find_library('foo_in_system')
+
+faa_pkg_dep = dependency('faa_pkg')
+
+l = shared_library('bar_built', 'bar.c',
+ install: true,
+ dependencies : [foo_system_dep, faa_pkg_dep])
+
+if host_machine.system() == 'darwin'
+ e = executable('prog', 'prog.c', link_with: l, install: true)
+ test('testprog', e)
+elif host_machine.system() == 'linux'
+ e = executable('prog', 'prog.c', link_with: l, install: true,
+ install_rpath: '$ORIGIN/..' / get_option('libdir'),
+ )
+ test('testprog', e)
+endif
diff --git a/meson/test cases/unit/40 external, internal library rpath/built library/meson_options.txt b/meson/test cases/unit/40 external, internal library rpath/built library/meson_options.txt
new file mode 100644
index 000000000..aa1d2ec9b
--- /dev/null
+++ b/meson/test cases/unit/40 external, internal library rpath/built library/meson_options.txt
@@ -0,0 +1 @@
+option('foo_system_path', type: 'string', value: '')
diff --git a/meson/test cases/unit/40 external, internal library rpath/built library/prog.c b/meson/test cases/unit/40 external, internal library rpath/built library/prog.c
new file mode 100644
index 000000000..e3d4cf63f
--- /dev/null
+++ b/meson/test cases/unit/40 external, internal library rpath/built library/prog.c
@@ -0,0 +1,7 @@
+int bar_built_value (int in);
+
+int main (int argc, char *argv[])
+{
+ // this will evaluate to 0
+ return bar_built_value(10) - (42 + 1969 + 10);
+}
diff --git a/meson/test cases/unit/40 external, internal library rpath/external library/bar.c b/meson/test cases/unit/40 external, internal library rpath/external library/bar.c
new file mode 100644
index 000000000..c6f42d651
--- /dev/null
+++ b/meson/test cases/unit/40 external, internal library rpath/external library/bar.c
@@ -0,0 +1,6 @@
+int some_undefined_func (void);
+
+int bar_system_value (void)
+{
+ return some_undefined_func ();
+}
diff --git a/meson/test cases/unit/40 external, internal library rpath/external library/faa.c b/meson/test cases/unit/40 external, internal library rpath/external library/faa.c
new file mode 100644
index 000000000..473357516
--- /dev/null
+++ b/meson/test cases/unit/40 external, internal library rpath/external library/faa.c
@@ -0,0 +1,4 @@
+int faa_system_value (void)
+{
+ return 1969;
+}
diff --git a/meson/test cases/unit/40 external, internal library rpath/external library/foo.c b/meson/test cases/unit/40 external, internal library rpath/external library/foo.c
new file mode 100644
index 000000000..a34e4a885
--- /dev/null
+++ b/meson/test cases/unit/40 external, internal library rpath/external library/foo.c
@@ -0,0 +1,4 @@
+int foo_system_value (void)
+{
+ return 42;
+}
diff --git a/meson/test cases/unit/40 external, internal library rpath/external library/meson.build b/meson/test cases/unit/40 external, internal library rpath/external library/meson.build
new file mode 100644
index 000000000..06ffa0f72
--- /dev/null
+++ b/meson/test cases/unit/40 external, internal library rpath/external library/meson.build
@@ -0,0 +1,22 @@
+project('system library', 'c', default_options : ['b_lundef=false'])
+
+shared_library('foo_in_system', 'foo.c', install : true)
+l = shared_library('faa_pkg', 'faa.c', install: true)
+
+if host_machine.system() == 'darwin'
+ ldflags = ['-framework', 'CoreFoundation', '-framework', 'CoreMedia']
+ allow_undef_args = ['-Wl,-undefined,dynamic_lookup']
+else
+ ldflags = ['-Wl,-rpath,${libdir}']
+ allow_undef_args = []
+endif
+
+pkg = import('pkgconfig')
+pkg.generate(name: 'faa_pkg',
+ libraries: [l] + ldflags,
+ description: 'FAA, a pkg-config test library')
+
+# cygwin DLLs can't have undefined symbols
+if host_machine.system() != 'cygwin'
+ shared_library('bar_in_system', 'bar.c', install : true, link_args : allow_undef_args)
+endif