diff options
author | Jussi Pakkanen <jpakkane@gmail.com> | 2020-06-18 18:57:25 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-06-18 18:57:25 +0300 |
commit | 1309b0618344a443ea9e298e0916eb0d2cd34d79 (patch) | |
tree | 17964dc785d9d234aef5385d5d487ae71a8ba173 /mesonbuild/backend/ninjabackend.py | |
parent | 96609da8d26fc05be8845c1edf05c8aa38af047d (diff) | |
parent | 8620ca2066d04b0d61c8f9fc60c218c779bd11fb (diff) | |
download | meson-1309b0618344a443ea9e298e0916eb0d2cd34d79.zip meson-1309b0618344a443ea9e298e0916eb0d2cd34d79.tar.gz meson-1309b0618344a443ea9e298e0916eb0d2cd34d79.tar.bz2 |
Merge pull request #7196 from cconverse711/llvm-cov
coverage: llvm-cov support
Diffstat (limited to 'mesonbuild/backend/ninjabackend.py')
-rw-r--r-- | mesonbuild/backend/ninjabackend.py | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/mesonbuild/backend/ninjabackend.py b/mesonbuild/backend/ninjabackend.py index 8dbb57a..252f646 100644 --- a/mesonbuild/backend/ninjabackend.py +++ b/mesonbuild/backend/ninjabackend.py @@ -968,6 +968,13 @@ int dummy; self.processed_targets[target.get_id()] = True def generate_coverage_command(self, elem, outputs): + targets = self.build.get_targets().values() + use_llvm_cov = False + for target in targets: + for compiler in target.compilers.values(): + if compiler.get_id() == 'clang' and not compiler.info.is_darwin(): + use_llvm_cov = True + break elem.add_item('COMMAND', self.environment.get_build_command() + ['--internal', 'coverage'] + outputs + @@ -975,7 +982,8 @@ int dummy; os.path.join(self.environment.get_source_dir(), self.build.get_subproject_dir()), self.environment.get_build_dir(), - self.environment.get_log_dir()]) + self.environment.get_log_dir()] + + ['--use_llvm_cov'] if use_llvm_cov else []) def generate_coverage_rules(self): e = NinjaBuildElement(self.all_outputs, 'meson-coverage', 'CUSTOM_COMMAND', 'PHONY') |