Library for creating WASM plugins with Rust.
Scotch allows you to pass complex types to/from functions in WASM plugins.
It achieves that by encoding and decoding complex types when passed between host and guest environment.
Encoding and decoding is handled by [email protected]
so you need your types
to implement bincode::Encode
and bincode::Decode
traits.
You can disable default features to enable headless mode. This should reduce host binary size.
In headless mode you are unable to compile wasm bytecode and need to rely on serialized plugins.
See WasmPluginBuilder::from_serialized
, WasmPluginBuilder::from_serialized_compressed
,
WasmPlugin::serialize
, WasmPlugin::serialize_compress
. *_compress
, *_compressed
functions
uses flate2
crate to compress/decompress plugins, to use them you need to have flate2
feature enabled.
# In your main application
[dependenices]
scotch-host = "0.1"
# In your plugins
[dependencies]
scotch-guest = "0.1"
// Define functions that your plugin exports.
#[scotch_host::guest_functions]
extern "C" {
// To pass complex types you use references to them, not owned types.
// The name must match with the name of the plugin function.
pub fn add_up_list(nums: &Vec<i32>) -> i32;
}
// Create your plugin
let plugin = WasmPlugin::builder()
.with_state(0)
// PLUGIN_BYTES is a slice of your wasm plugin.
.from_binary(PLUGIN_BYTES)?
// This call caches exports of your plugin.
.with_exports(make_exports![add_up_list])
.finish()?;
// Call the function
let sum = plugin.function_unwrap::<add_up_list>()(&vec![1, 2, 3, 4, 5])?;
assert_eq!(sum, 15);
// This is required.
scotch_guest::export_alloc!();
// Functions marked with `guest_function` will be exposed to the host.
// All complex types such as Vec, String, user-defined types must be passed by immutable reference.
#[scotch_guest::guest_function]
fn add_up_list(items: &Vec<i32>) -> i32 {
items.iter().sum::<i32>()
}
More complete example can be found here
- Improve codegeneration with proc macros.
- Mutable references.
- WASI support.