* wasmtime-wasi: re-exporting this WasiCtxBuilder was shadowing the right one wasi-common's WasiCtxBuilder is really only useful wasi_cap_std_sync and wasi_tokio to implement their own Builder on top of. This re-export of wasi-common's is 1. not useful and 2. shadow's the re-export of the right one in sync::*. * wasi-common: eliminate WasiCtxBuilder, make the builder methods on WasiCtx instead * delete wasi-common::WasiCtxBuilder altogether just put those methods directly on &mut WasiCtx. As a bonus, the sync and tokio WasiCtxBuilder::build functions are no longer fallible! * bench fixes * more test fixes
wasmtime-rust - Using WebAssembly from Rust
This crate is intended to be an example of how to load WebAssembly files from a
native Rust application. You can always use wasmtime and its family of crates
directly, but the purpose of this crate is to provide an ergonomic macro:
#[wasmtime_rust::wasmtime]
trait WasmMarkdown {
fn render(&mut self, input: &str) -> String;
}
fn main() -> anyhow::Result<()> {
let mut markdown = WasmMarkdown::load_file("markdown.wasm")?;
println!("{}", markdown.render("# Hello, Rust!"));
Ok(())
}
The wasmtime macro defined in the wasmtime-rust crate is placed on a trait
which includes the set of functionality which a wasm module should export. In
this case we're expecting one render function which takes and returns a
string.
The macro expands to a struct with all of the methods on the trait (they must
all be &mut self) and one function called load_file to actually instantiate
the module.
Note that this macro is still in early stages of development, so error messages aren't great yet and all functionality isn't supported yet.
Missing features
Currently if the wasm module imports any symbols outside of the WASI namespace the module will not load. It's intended that support for this will be added soon though!