From 93fb264a7c44db337fe6d509ca49e47d186a603a Mon Sep 17 00:00:00 2001 From: Paolo Bonzini Date: Fri, 10 Jan 2025 10:22:49 +0100 Subject: [PATCH 1/2] clippy: skip "linker" blocks in target_sources Signed-off-by: Paolo Bonzini --- mesonbuild/scripts/clippy.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/mesonbuild/scripts/clippy.py b/mesonbuild/scripts/clippy.py index c4746e3fdb28..6d282e4f81e9 100644 --- a/mesonbuild/scripts/clippy.py +++ b/mesonbuild/scripts/clippy.py @@ -33,7 +33,7 @@ def warn_missing_clippy(self, machine: str) -> None: def __call__(self, target: T.Dict[str, T.Any]) -> T.Iterable[T.Coroutine[None, None, int]]: for src_block in target['target_sources']: - if src_block['language'] == 'rust': + if 'compiler' in src_block and src_block['language'] == 'rust': clippy = getattr(self.tools, src_block['machine']) if not clippy: self.warn_missing_clippy(src_block['machine']) From da36f924954a23a7fd34819386c241132bd668b3 Mon Sep 17 00:00:00 2001 From: Paolo Bonzini Date: Fri, 10 Jan 2025 10:22:49 +0100 Subject: [PATCH 2/2] ninjabackend: ensure structured_sources are populated before running clippy Signed-off-by: Paolo Bonzini --- mesonbuild/backend/ninjabackend.py | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/mesonbuild/backend/ninjabackend.py b/mesonbuild/backend/ninjabackend.py index 70122c3794bc..cd35d2fcc300 100644 --- a/mesonbuild/backend/ninjabackend.py +++ b/mesonbuild/backend/ninjabackend.py @@ -503,6 +503,7 @@ def __init__(self, build: T.Optional[build.Build], interpreter: T.Optional[Inter self.ninja_filename = 'build.ninja' self.fortran_deps: T.Dict[str, T.Dict[str, File]] = {} self.all_outputs: T.Set[str] = set() + self.all_structured_sources: T.Set[str] = set() self.introspection_data = {} self.created_llvm_ir_rule = PerMachine(False, False) self.rust_crates: T.Dict[str, RustCrate] = {} @@ -1951,7 +1952,6 @@ def generate_rust_target(self, target: build.BuildTarget) -> None: if target.structured_sources.needs_copy(): _ods, main_rust_file = self.__generate_sources_structure(Path( self.get_target_private_dir(target)) / 'structured', target.structured_sources) - orderdeps.extend(_ods) else: # The only way to get here is to have only files in the "root" # positional argument, which are all generated into the same @@ -1965,12 +1965,15 @@ def generate_rust_target(self, target: build.BuildTarget) -> None: else: main_rust_file = os.path.join(g.get_subdir(), g.get_outputs()[0]) + _ods = [] for f in target.structured_sources.as_list(): if isinstance(f, File): - orderdeps.append(f.rel_to_builddir(self.build_to_src)) + _ods.append(f.rel_to_builddir(self.build_to_src)) else: - orderdeps.extend([os.path.join(self.build_to_src, f.subdir, s) - for s in f.get_outputs()]) + _ods.extend([os.path.join(self.build_to_src, f.subdir, s) + for s in f.get_outputs()]) + self.all_structured_sources.update(_ods) + orderdeps.extend(_ods) for i in target.get_sources(): if not rustc.can_compile(i): @@ -3715,6 +3718,7 @@ def generate_clippy(self) -> None: for crate in self.rust_crates.values(): if crate.crate_type in {'rlib', 'dylib', 'proc-macro'}: elem.add_dep(crate.target_name) + elem.add_dep(list(self.all_structured_sources)) self.add_build(elem) def generate_scanbuild(self) -> None: