Import functions
The #[marine]
macro can also wrap a Rust extern block. In this case, all functions declared in it are considered imported functions. If there are imported functions in some module, say, module A, then
- There should be another module, module B, that exports the same functions. The name of module B is indicated in the
module_import
macro (see examples below) - Module B should be loaded into
Marine
by the moment the loading of module A starts. Module A cannot be loaded if at least one imported function is absent inMarine
.
Function import requirements
- wrap an extern block with the function(s) to be imported with the
#[marine]
macro - all function(s) arguments must be of the mtype type
- the return type of the function(s) must be mtype
Examples
See the examples below of wrapped extern
block usage:
- Example 1
- Example 2
rust
#[marine]pub struct TestRecord {pub field_0: i32,pub field_1: Vec<Vec<u8>>,}// wrap the extern block with the marine macro to expose the function// as an import to the Marine VM#[marine]#[module_import("some_module")]extern "C" {pub fn foo(arg: Vec<Vec<Vec<Vec<TestRecord>>>>, arg_2: String) -> Vec<Vec<Vec<Vec<TestRecord>>>>;}
rust
#[marine]pub struct TestRecord {pub field_0: i32,pub field_1: Vec<Vec<u8>>,}// wrap the extern block with the marine macro to expose the function// as an import to the Marine VM#[marine]#[module_import("some_module")]extern "C" {pub fn foo(arg: Vec<Vec<Vec<Vec<TestRecord>>>>, arg_2: String) -> Vec<Vec<Vec<Vec<TestRecord>>>>;}
rust
#[marine]#[module_import("some_module")]extern "C" {pub fn foo(arg: Vec<Vec<Vec<Vec<u8>>>>) -> Vec<Vec<Vec<Vec<u8>>>>;}
rust
#[marine]#[module_import("some_module")]extern "C" {pub fn foo(arg: Vec<Vec<Vec<Vec<u8>>>>) -> Vec<Vec<Vec<Vec<u8>>>>;}