aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild/interpreter/interpreter.py
diff options
context:
space:
mode:
authorDylan Baker <dylan@pnwbakers.com>2021-06-14 15:36:16 -0700
committerDylan Baker <dylan@pnwbakers.com>2021-06-22 09:13:41 -0700
commitf4d2efbed3a589bc7dbb129778eb2debb1f5fb2e (patch)
tree9c9ebbd1d8eb7f25db760e6101d6e856346190aa /mesonbuild/interpreter/interpreter.py
parent251dff56fb074cd718da81c21e104cd26d897869 (diff)
downloadmeson-f4d2efbed3a589bc7dbb129778eb2debb1f5fb2e.zip
meson-f4d2efbed3a589bc7dbb129778eb2debb1f5fb2e.tar.gz
meson-f4d2efbed3a589bc7dbb129778eb2debb1f5fb2e.tar.bz2
interpreter: use typed_kwargs for install_headers
Diffstat (limited to 'mesonbuild/interpreter/interpreter.py')
-rw-r--r--mesonbuild/interpreter/interpreter.py23
1 files changed, 11 insertions, 12 deletions
diff --git a/mesonbuild/interpreter/interpreter.py b/mesonbuild/interpreter/interpreter.py
index 3b881e8..8513054 100644
--- a/mesonbuild/interpreter/interpreter.py
+++ b/mesonbuild/interpreter/interpreter.py
@@ -1885,23 +1885,22 @@ This will become a hard error in the future.''' % kwargs['input'], location=self
mlog.debug('Adding benchmark', mlog.bold(t.name, True))
@typed_pos_args('install_headers', varargs=(str, mesonlib.File), min_varargs=1)
+ @typed_kwargs(
+ 'install_headers',
+ KwargInfo('install_dir', (str, None)),
+ KwargInfo('subdir', (str, None)),
+ _INSTALL_MODE_KW.evolve(since='0.47.0'),
+ )
def func_install_headers(self, node: mparser.BaseNode,
args: T.Tuple[T.List['mesonlib.FileOrString']],
- kwargs) -> build.Headers:
+ kwargs: 'kwargs.FuncInstallHeaders') -> build.Headers:
source_files = self.source_strings_to_files(args[0])
- install_mode = self._get_kwarg_install_mode(kwargs)
-
- install_subdir = kwargs.get('subdir', '')
- if not isinstance(install_subdir, str):
- raise InterpreterException('subdir keyword argument must be a string')
- elif os.path.isabs(install_subdir):
+ install_subdir = kwargs['subdir']
+ if install_subdir is not None and os.path.isabs(install_subdir):
mlog.deprecation('Subdir keyword must not be an absolute path. This will be a hard error in the next release.')
- install_dir = kwargs.get('install_dir', None)
- if install_dir is not None and not isinstance(install_dir, str):
- raise InterpreterException('install_dir keyword argument must be a string if provided')
-
- h = build.Headers(source_files, install_subdir, install_dir, install_mode, self.subproject)
+ h = build.Headers(source_files, install_subdir, kwargs['install_dir'],
+ kwargs['install_mode'], self.subproject)
self.build.headers.append(h)
return h