aboutsummaryrefslogtreecommitdiffstats
path: root/meson/test cases/common/226 link depends indexed custom target
diff options
context:
space:
mode:
Diffstat (limited to 'meson/test cases/common/226 link depends indexed custom target')
-rw-r--r--meson/test cases/common/226 link depends indexed custom target/check_arch.py32
-rw-r--r--meson/test cases/common/226 link depends indexed custom target/foo.c15
-rw-r--r--meson/test cases/common/226 link depends indexed custom target/make_file.py8
-rw-r--r--meson/test cases/common/226 link depends indexed custom target/meson.build25
4 files changed, 80 insertions, 0 deletions
diff --git a/meson/test cases/common/226 link depends indexed custom target/check_arch.py b/meson/test cases/common/226 link depends indexed custom target/check_arch.py
new file mode 100644
index 000000000..927bf87c0
--- /dev/null
+++ b/meson/test cases/common/226 link depends indexed custom target/check_arch.py
@@ -0,0 +1,32 @@
+#!/usr/bin/env python3
+
+import re
+import sys
+import shutil
+import subprocess
+
+exepath = sys.argv[1]
+want_arch = sys.argv[2]
+dummy_output = sys.argv[3]
+
+with open(dummy_output, 'w') as f:
+ f.write('')
+
+if not shutil.which('dumpbin'):
+ print('dumpbin not found, skipping')
+ sys.exit(0)
+
+out = subprocess.check_output(['dumpbin', '/HEADERS', exepath],
+ universal_newlines=True)
+for line in out.split('\n'):
+ m = re.match(r'.* machine \(([A-Za-z0-9]+)\)$', line)
+ if m:
+ arch = m.groups()[0].lower()
+
+if arch == 'arm64':
+ arch = 'aarch64'
+elif arch == 'x64':
+ arch = 'x86_64'
+
+if arch != want_arch:
+ raise RuntimeError(f'Wanted arch {want_arch} but exe uses {arch}')
diff --git a/meson/test cases/common/226 link depends indexed custom target/foo.c b/meson/test cases/common/226 link depends indexed custom target/foo.c
new file mode 100644
index 000000000..58c86a62b
--- /dev/null
+++ b/meson/test cases/common/226 link depends indexed custom target/foo.c
@@ -0,0 +1,15 @@
+#include <stdio.h>
+
+int main(void) {
+ const char *fn = DEPFILE;
+ FILE *f = fopen(fn, "r");
+ if (!f) {
+ printf("could not open %s", fn);
+ return 1;
+ }
+ else {
+ printf("successfully opened %s", fn);
+ }
+
+ return 0;
+}
diff --git a/meson/test cases/common/226 link depends indexed custom target/make_file.py b/meson/test cases/common/226 link depends indexed custom target/make_file.py
new file mode 100644
index 000000000..6a43b7d05
--- /dev/null
+++ b/meson/test cases/common/226 link depends indexed custom target/make_file.py
@@ -0,0 +1,8 @@
+#!/usr/bin/env python3
+import sys
+
+with open(sys.argv[1], 'w') as f:
+ print('# this file does nothing', file=f)
+
+with open(sys.argv[2], 'w') as f:
+ print('# this file does nothing', file=f)
diff --git a/meson/test cases/common/226 link depends indexed custom target/meson.build b/meson/test cases/common/226 link depends indexed custom target/meson.build
new file mode 100644
index 000000000..c41c4c1e7
--- /dev/null
+++ b/meson/test cases/common/226 link depends indexed custom target/meson.build
@@ -0,0 +1,25 @@
+project('link_depends_indexed_custom_target', 'c')
+
+if meson.backend().startswith('vs')
+ # FIXME: Broken on the VS backends
+ error('MESON_SKIP_TEST see https://github.com/mesonbuild/meson/issues/1799')
+endif
+
+cmd = find_program('make_file.py')
+
+dep_files = custom_target('gen_dep',
+ command: [cmd, '@OUTPUT@'],
+ output: ['dep_file1', 'dep_file2'])
+
+exe = executable('foo', 'foo.c',
+ link_depends: dep_files[1],
+ c_args: ['-DDEPFILE="' + dep_files[0].full_path()+ '"'])
+
+check_arch = find_program('check_arch.py')
+custom_target('check-arch',
+ command: [check_arch, exe, host_machine.cpu_family(), '@OUTPUT@'],
+ build_by_default: true,
+ output: 'dummy.txt')
+
+# check that dep_file1 exists, which means that link_depends target ran
+test('runtest', exe)