aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild/backend
diff options
context:
space:
mode:
authorDylan Baker <dylan@pnwbakers.com>2021-10-01 09:48:56 -0700
committerDylan Baker <dylan@pnwbakers.com>2022-03-07 12:33:33 -0800
commit0d0a4fa0fe02ca8297743a5a8e64ee72060cc990 (patch)
tree9c8285ffcfe13b0ffc916c67bf211e2462b5bdf6 /mesonbuild/backend
parent7d1431a06039cb29bc2585929a9fbac58bdedb0e (diff)
downloadmeson-0d0a4fa0fe02ca8297743a5a8e64ee72060cc990.zip
meson-0d0a4fa0fe02ca8297743a5a8e64ee72060cc990.tar.gz
meson-0d0a4fa0fe02ca8297743a5a8e64ee72060cc990.tar.bz2
backends/ninja: Add support for structured sources with rust
Diffstat (limited to 'mesonbuild/backend')
-rw-r--r--mesonbuild/backend/ninjabackend.py43
1 files changed, 43 insertions, 0 deletions
diff --git a/mesonbuild/backend/ninjabackend.py b/mesonbuild/backend/ninjabackend.py
index a8616b8..fdd5cd3 100644
--- a/mesonbuild/backend/ninjabackend.py
+++ b/mesonbuild/backend/ninjabackend.py
@@ -54,6 +54,7 @@ if T.TYPE_CHECKING:
from .._typing import ImmutableListProtocol
from ..linkers import DynamicLinker, StaticLinker
from ..compilers.cs import CsCompiler
+ from ..interpreter.interpreter import SourceOutputs
FORTRAN_INCLUDE_PAT = r"^\s*#?include\s*['\"](\w+\.\w+)['\"]"
@@ -1662,6 +1663,29 @@ class NinjaBackend(backends.Backend):
elem.add_orderdep(instr)
self.add_build(elem)
+ def __generate_compile_structure(self, target: build.BuildTarget) -> T.Tuple[T.List[str], T.Optional[str]]:
+ first_file: T.Optional[str] = None
+ orderdeps: T.List[str] = []
+ root = Path(self.get_target_private_dir(target)) / 'structured'
+ for path, files in target.structured_sources.sources.items():
+ for file in files:
+ if isinstance(file, (str, File)):
+ if isinstance(file, str):
+ file = File.from_absolute_file(file)
+ out = root / path / Path(file.fname).name
+ orderdeps.append(str(out))
+ self._generate_copy_target(file, out)
+ if first_file is None:
+ first_file = str(out)
+ else:
+ for f in file.get_outputs():
+ out = root / path / f
+ orderdeps.append(str(out))
+ self._generate_copy_target(str(Path(file.subdir) / f), out)
+ if first_file is None:
+ first_file = str(out)
+ return orderdeps, first_file
+
def generate_rust_target(self, target: build.BuildTarget) -> None:
rustc = target.compilers['rust']
# Rust compiler takes only the main file as input and
@@ -1682,6 +1706,25 @@ class NinjaBackend(backends.Backend):
orderdeps: T.List[str] = []
main_rust_file = None
+ if target.structured_sources:
+ if target.structured_sources.needs_copy(target):
+ _ods, main_rust_file = self.__generate_compile_structure(target)
+ orderdeps.extend(_ods)
+ else:
+ g = target.structured_sources.first_file()
+ if isinstance(g, str):
+ g = File.from_source_file(self.environment.source_dir, target.subdir, g)
+
+ if isinstance(g, File):
+ main_rust_file = g.rel_to_builddir(self.build_to_src)
+ elif isinstance(g, GeneratedList):
+ main_rust_file = os.path.join(self.get_target_private_dir(target), i)
+ else:
+ main_rust_file = os.path.join(g.get_subdir(), i)
+ orderdeps.extend([os.path.join(self.build_to_src, target.subdir, s)
+ for s in target.structured_sources.as_list()])
+
+
for i in target.get_sources():
if not rustc.can_compile(i):
raise InvalidArguments(f'Rust target {target.get_basename()} contains a non-rust source file.')