diff options
author | Jussi Pakkanen <jpakkane@gmail.com> | 2018-05-30 23:32:31 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-05-30 23:32:31 +0300 |
commit | 05f8b1bd7829c425a8a4838394b8c2d5964c7553 (patch) | |
tree | 1cfbbf9280a0f8c4ceeb9c5ee81f86b54ad61066 /mesonbuild/interpreter.py | |
parent | 00654aeb11e110d41567a0ff00300619c705170f (diff) | |
parent | 27b290d6dff14fdb7717d414fb941aca0fd2dc55 (diff) | |
download | meson-05f8b1bd7829c425a8a4838394b8c2d5964c7553.zip meson-05f8b1bd7829c425a8a4838394b8c2d5964c7553.tar.gz meson-05f8b1bd7829c425a8a4838394b8c2d5964c7553.tar.bz2 |
Merge pull request #3643 from mesonbuild/nirbheek/check_header
New compiler method: check_header
Diffstat (limited to 'mesonbuild/interpreter.py')
-rw-r--r-- | mesonbuild/interpreter.py | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/mesonbuild/interpreter.py b/mesonbuild/interpreter.py index c574479..4f2d45e 100644 --- a/mesonbuild/interpreter.py +++ b/mesonbuild/interpreter.py @@ -843,6 +843,7 @@ class CompilerHolder(InterpreterObject): 'compute_int': self.compute_int_method, 'sizeof': self.sizeof_method, 'get_define': self.get_define_method, + 'check_header': self.check_header_method, 'has_header': self.has_header_method, 'has_header_symbol': self.has_header_symbol_method, 'run': self.run_method, @@ -1236,6 +1237,31 @@ class CompilerHolder(InterpreterObject): 'args', 'dependencies', }) + def check_header_method(self, args, kwargs): + if len(args) != 1: + raise InterpreterException('check_header method takes exactly one argument.') + check_stringlist(args) + hname = args[0] + prefix = kwargs.get('prefix', '') + if not isinstance(prefix, str): + raise InterpreterException('Prefix argument of has_header must be a string.') + extra_args = self.determine_args(kwargs) + deps = self.determine_dependencies(kwargs) + haz = self.compiler.check_header(hname, prefix, self.environment, extra_args, deps) + if haz: + h = mlog.green('YES') + else: + h = mlog.red('NO') + mlog.log('Check usable header "%s":' % hname, h) + return haz + + @permittedKwargs({ + 'prefix', + 'no_builtin_args', + 'include_directories', + 'args', + 'dependencies', + }) def has_header_method(self, args, kwargs): if len(args) != 1: raise InterpreterException('has_header method takes exactly one argument.') |