diff options
author | Nirbheek Chauhan <nirbheek@centricular.com> | 2018-05-30 14:05:55 +0530 |
---|---|---|
committer | Nirbheek Chauhan <nirbheek@centricular.com> | 2018-05-30 15:25:39 +0530 |
commit | ff07314a865d960aac2c377a94de766b68888ee5 (patch) | |
tree | 3ac92f0913cd680c0e565f88e5f518248bb3d77b /mesonbuild/compilers/c.py | |
parent | c87c42b736197b726f3cca47e92bc836c773085e (diff) | |
download | meson-ff07314a865d960aac2c377a94de766b68888ee5.zip meson-ff07314a865d960aac2c377a94de766b68888ee5.tar.gz meson-ff07314a865d960aac2c377a94de766b68888ee5.tar.bz2 |
New compiler method: check_header
This checks not only for existence, but also for usability of the
header, which means it does a full compilation and not just
pre-processing or __has_include.
Fixes https://github.com/mesonbuild/meson/issues/2246
Diffstat (limited to 'mesonbuild/compilers/c.py')
-rw-r--r-- | mesonbuild/compilers/c.py | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/mesonbuild/compilers/c.py b/mesonbuild/compilers/c.py index 13b3dcc..4cc9660 100644 --- a/mesonbuild/compilers/c.py +++ b/mesonbuild/compilers/c.py @@ -266,6 +266,12 @@ class CCompiler(Compiler): code = 'int main(int argc, char **argv) { int class=0; return class; }\n' return self.sanity_check_impl(work_dir, environment, 'sanitycheckc.c', code) + def check_header(self, hname, prefix, env, extra_args=None, dependencies=None): + fargs = {'prefix': prefix, 'header': hname} + code = '''{prefix} + #include <{header}>''' + return self.compiles(code.format(**fargs), env, extra_args, dependencies) + def has_header(self, hname, prefix, env, extra_args=None, dependencies=None): fargs = {'prefix': prefix, 'header': hname} code = '''{prefix} |