From 5b58e865188f04250b269ab5aa82034a15413994 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ole=20Andr=C3=A9=20Vadla=20Ravn=C3=A5s?= Date: Thu, 11 Apr 2024 21:58:23 +0200 Subject: [PATCH] ninja: Use single target for Swift module and object files Newer toolchains support it. --- mesonbuild/backend/ninjabackend.py | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/mesonbuild/backend/ninjabackend.py b/mesonbuild/backend/ninjabackend.py index 8db4a4254515..88b22cb4662a 100644 --- a/mesonbuild/backend/ninjabackend.py +++ b/mesonbuild/backend/ninjabackend.py @@ -2193,7 +2193,8 @@ def generate_swift_target(self, target): else: raise InvalidArguments(f'Swift target {target.get_basename()} contains a non-swift source file.') os.makedirs(self.get_target_private_dir_abs(target), exist_ok=True) - compile_args = swiftc.get_compile_only_args() + compile_args = swiftc.get_mod_gen_args() + compile_args += swiftc.get_compile_only_args() compile_args += swiftc.get_optimization_args(target.get_option(OptionKey('optimization'))) compile_args += swiftc.get_debug_args(target.get_option(OptionKey('debug'))) compile_args += swiftc.get_module_args(module_name) @@ -2244,18 +2245,12 @@ def generate_swift_target(self, target): rulename = self.compiler_to_rule_name(swiftc) - # Swiftc does not seem to be able to emit objects and module files in one go. - elem = NinjaBuildElement(self.all_outputs, rel_objects, rulename, abssrc) + elem = NinjaBuildElement(self.all_outputs, [out_module_name] + rel_objects, rulename, abssrc) elem.add_dep(in_module_files + rel_generated + other_generated) elem.add_dep(abs_headers) elem.add_item('ARGS', compile_args + header_imports + abs_generated + module_includes) elem.add_item('RUNDIR', rundir) self.add_build(elem) - elem = NinjaBuildElement(self.all_outputs, out_module_name, rulename, abssrc) - elem.add_dep(in_module_files + rel_generated + other_generated) - elem.add_item('ARGS', compile_args + abs_generated + module_includes + swiftc.get_mod_gen_args()) - elem.add_item('RUNDIR', rundir) - self.add_build(elem) if isinstance(target, build.StaticLibrary): elem = self.generate_link(target, self.get_target_filename(target), rel_objects, self.build.static_linker[target.for_machine])