diff --git a/docs/markdown/Rust-module.md b/docs/markdown/Rust-module.md index bbc92fc2582c..60d12238da3c 100644 --- a/docs/markdown/Rust-module.md +++ b/docs/markdown/Rust-module.md @@ -57,6 +57,9 @@ It takes the following keyword arguments - `input`: a list of Files, Strings, or CustomTargets. The first element is the header bindgen will parse, additional elements are dependencies. - `output`: the name of the output rust file +- `output_inline_wrapper`: the name of the optional output c file containing + wrappers for static inline function. This requires `bindgen` `0.64` or + newer (*since 1.3.0*). - `include_directories`: A list of `include_directories` or `string` objects, these are passed to clang as `-I` arguments *(string since 1.0.0)* - `c_args`: a list of string arguments to pass to clang untouched diff --git a/mesonbuild/modules/rust.py b/mesonbuild/modules/rust.py index 0bda2c250bce..a9742cbdb945 100644 --- a/mesonbuild/modules/rust.py +++ b/mesonbuild/modules/rust.py @@ -49,6 +49,7 @@ class FuncBindgen(TypedDict): include_directories: T.List[IncludeDirs] input: T.List[SourceInputs] output: str + output_inline_wrapper: str dependencies: T.List[T.Union[Dependency, ExternalLibrary]] @@ -191,6 +192,12 @@ def test(self, state: ModuleState, args: T.Tuple[str, BuildTarget], kwargs: Func ), INCLUDE_DIRECTORIES.evolve(since_values={ContainerTypeInfo(list, str): '1.0.0'}), OUTPUT_KW, + KwargInfo( + 'output_inline_wrapper', + str, + default='', + since='1.3.0', + ), DEPENDENCIES_KW.evolve(since='1.0.0'), ) def bindgen(self, state: ModuleState, args: T.List, kwargs: FuncBindgen) -> ModuleReturnValue: @@ -243,12 +250,22 @@ def bindgen(self, state: ModuleState, args: T.List, kwargs: FuncBindgen) -> Modu else: name = header.get_outputs()[0] + inline_wrapper_args = [] + outputs = [kwargs['output']] + if kwargs['output_inline_wrapper']: + outputs.append(kwargs['output_inline_wrapper']) + inline_wrapper_args = [ + '--experimental', '--wrap-static-fns', + '--wrap-static-fns-path', os.path.join(state.environment.build_dir, '@OUTPUT1@') + ] + cmd = self._bindgen_bin.get_command() + \ [ '@INPUT@', '--output', - os.path.join(state.environment.build_dir, '@OUTPUT@') + os.path.join(state.environment.build_dir, '@OUTPUT0@') ] + \ - kwargs['args'] + ['--'] + kwargs['c_args'] + clang_args + \ + kwargs['args'] + inline_wrapper_args + ['--'] + \ + kwargs['c_args'] + clang_args + \ ['-MD', '-MQ', '@INPUT@', '-MF', '@DEPFILE@'] target = CustomTarget( @@ -258,7 +275,7 @@ def bindgen(self, state: ModuleState, args: T.List, kwargs: FuncBindgen) -> Modu state.environment, cmd, [header], - [kwargs['output']], + outputs, depfile='@PLAINNAME@.d', extra_depends=depends, depend_files=depend_files, @@ -266,7 +283,7 @@ def bindgen(self, state: ModuleState, args: T.List, kwargs: FuncBindgen) -> Modu description='Generating bindings for Rust {}', ) - return ModuleReturnValue([target], [target]) + return ModuleReturnValue(target, [target]) def initialize(interp: Interpreter) -> RustModule: