From b49b9f52b29896cce58a1e3dbeb1b6cf54420d45 Mon Sep 17 00:00:00 2001 From: Hemmo Nieminen Date: Fri, 17 Jun 2022 00:00:00 +0300 Subject: interpreter: fix a subproject check with symlinks The check for whether or not a file is allowed to be accessed from a subproject fails if the subproject is accessed via a symlink. Use the absolute path of the subproject without resolving symlinks to fix the check. Extend unit test 106 to check for this in the future. --- test cases/unit/106 subproject symlink/cp.py | 6 ++++++ test cases/unit/106 subproject symlink/meson.build | 11 +++++++++-- .../symlinked_subproject/datadir/datafile | 1 + .../symlinked_subproject/datadir/meson.build | 1 + .../106 subproject symlink/symlinked_subproject/meson.build | 9 ++++++++- 5 files changed, 25 insertions(+), 3 deletions(-) create mode 100644 test cases/unit/106 subproject symlink/cp.py create mode 100644 test cases/unit/106 subproject symlink/symlinked_subproject/datadir/datafile create mode 100644 test cases/unit/106 subproject symlink/symlinked_subproject/datadir/meson.build (limited to 'test cases') diff --git a/test cases/unit/106 subproject symlink/cp.py b/test cases/unit/106 subproject symlink/cp.py new file mode 100644 index 0000000..adb0547 --- /dev/null +++ b/test cases/unit/106 subproject symlink/cp.py @@ -0,0 +1,6 @@ +#!/usr/bin/env python3 + +from sys import argv +from shutil import copy + +copy(argv[1], argv[2]) diff --git a/test cases/unit/106 subproject symlink/meson.build b/test cases/unit/106 subproject symlink/meson.build index 51c78c7..6766c8e 100644 --- a/test cases/unit/106 subproject symlink/meson.build +++ b/test cases/unit/106 subproject symlink/meson.build @@ -1,8 +1,15 @@ project('foo', 'c') -symlinked_subproject = subproject('symlinked_subproject') +symlinked_subproject = subproject('symlinked_subproject').get_variable('dep') executable('foo', sources : 'main.c', - dependencies : symlinked_subproject.get_variable('dep') + dependencies : symlinked_subproject +) + +custom_target( + input : symlinked_subproject.get_variable('datadir') / 'datafile', + output : 'datafile_copy', + command : [find_program('cp.py'), '@INPUT@', '@OUTPUT@'], + build_always : true ) diff --git a/test cases/unit/106 subproject symlink/symlinked_subproject/datadir/datafile b/test cases/unit/106 subproject symlink/symlinked_subproject/datadir/datafile new file mode 100644 index 0000000..6a68294 --- /dev/null +++ b/test cases/unit/106 subproject symlink/symlinked_subproject/datadir/datafile @@ -0,0 +1 @@ +hello meson diff --git a/test cases/unit/106 subproject symlink/symlinked_subproject/datadir/meson.build b/test cases/unit/106 subproject symlink/symlinked_subproject/datadir/meson.build new file mode 100644 index 0000000..cbeb0a9 --- /dev/null +++ b/test cases/unit/106 subproject symlink/symlinked_subproject/datadir/meson.build @@ -0,0 +1 @@ +install_data('datafile') diff --git a/test cases/unit/106 subproject symlink/symlinked_subproject/meson.build b/test cases/unit/106 subproject symlink/symlinked_subproject/meson.build index 61440c7..3930465 100644 --- a/test cases/unit/106 subproject symlink/symlinked_subproject/meson.build +++ b/test cases/unit/106 subproject symlink/symlinked_subproject/meson.build @@ -1,3 +1,10 @@ project('symlinked_subproject', 'c', version : '1.0.0') -dep = declare_dependency(sources : 'src.c') +dep = declare_dependency( + sources : 'src.c', + variables : { + 'datadir': meson.current_source_dir() / 'datadir' + } +) + +subdir('datadir') -- cgit v1.1