From 3c23f937b209e776f20ac59eb1316d78777dfa06 Mon Sep 17 00:00:00 2001 From: Paolo Bonzini Date: Mon, 9 Dec 2024 15:28:45 +0100 Subject: [PATCH] modernize Rust template Signed-off-by: Paolo Bonzini --- mesonbuild/templates/rusttemplates.py | 27 +++++++++++++++------------ mesonbuild/templates/sampleimpl.py | 12 +++++++----- 2 files changed, 22 insertions(+), 17 deletions(-) diff --git a/mesonbuild/templates/rusttemplates.py b/mesonbuild/templates/rusttemplates.py index 5bb7e4c19006..1dbf5b614115 100644 --- a/mesonbuild/templates/rusttemplates.py +++ b/mesonbuild/templates/rusttemplates.py @@ -20,25 +20,28 @@ pub fn {function_name}() -> i32 {{ return internal_function(); }} -''' -lib_rust_test_template = '''extern crate {crate_file}; +#[cfg(test)] +mod tests {{ + use super::*; -fn main() {{ - println!("printing: {{}}", {crate_file}::{function_name}()); + #[test] + fn test_function() {{ + assert_eq!({function_name}(), 0); + }} }} ''' lib_rust_meson_template = '''project('{project_name}', 'rust', - version : '{version}', - default_options : ['warning_level=3']) + version : '{version}', meson_version: '>=1.3.0', + default_options : ['rust_std=2021', 'warning_level=3']) + +rust = import('rust') shlib = static_library('{lib_name}', '{source_file}', install : true) -test_exe = executable('{test_exe_name}', '{test_source_file}', - link_with : shlib) -test('{test_name}', test_exe) +rust.test('{test_name}', shlib) # Make this library usable as a Meson subproject. {ltoken}_dep = declare_dependency( @@ -54,8 +57,8 @@ ''' hello_rust_meson_template = '''project('{project_name}', 'rust', - version : '{version}', - default_options : ['warning_level=3']) + version : '{version}', meson_version: '>=1.3.0', + default_options : ['rust_std=2021', 'warning_level=3']) exe = executable('{exe_name}', '{source_name}', install : true) @@ -70,7 +73,7 @@ class RustProject(FileImpl): exe_template = hello_rust_template exe_meson_template = hello_rust_meson_template lib_template = lib_rust_template - lib_test_template = lib_rust_test_template + lib_test_template = None lib_meson_template = lib_rust_meson_template def lib_kwargs(self) -> T.Dict[str, str]: diff --git a/mesonbuild/templates/sampleimpl.py b/mesonbuild/templates/sampleimpl.py index 570a370b8e3f..c222a1bf9aa7 100644 --- a/mesonbuild/templates/sampleimpl.py +++ b/mesonbuild/templates/sampleimpl.py @@ -41,7 +41,7 @@ def lib_template(self) -> str: pass @abc.abstractproperty - def lib_test_template(self) -> str: + def lib_test_template(self) -> T.Optional[str]: pass @abc.abstractproperty @@ -85,8 +85,9 @@ def create_library(self) -> None: } with open(lib_name, 'w', encoding='utf-8') as f: f.write(self.lib_template.format(**kwargs)) - with open(test_name, 'w', encoding='utf-8') as f: - f.write(self.lib_test_template.format(**kwargs)) + if self.lib_test_template: + with open(test_name, 'w', encoding='utf-8') as f: + f.write(self.lib_test_template.format(**kwargs)) with open('meson.build', 'w', encoding='utf-8') as f: f.write(self.lib_meson_template.format(**kwargs)) @@ -132,8 +133,9 @@ def create_library(self) -> None: kwargs = self.lib_kwargs() with open(lib_name, 'w', encoding='utf-8') as f: f.write(self.lib_template.format(**kwargs)) - with open(test_name, 'w', encoding='utf-8') as f: - f.write(self.lib_test_template.format(**kwargs)) + if self.lib_test_template: + with open(test_name, 'w', encoding='utf-8') as f: + f.write(self.lib_test_template.format(**kwargs)) with open('meson.build', 'w', encoding='utf-8') as f: f.write(self.lib_meson_template.format(**kwargs))