* Reactor support. This implements the new WASI ABI described here: https://github.com/WebAssembly/WASI/blob/master/design/application-abi.md It adds APIs to `Instance` and `Linker` with support for running WASI programs, and also simplifies the process of instantiating WASI API modules. This currently only includes Rust API support. * Add comments and fix a typo in a comment. * Fix a rustdoc warning. * Tidy an unneeded `mut`. * Factor out instance initialization with `NewInstance`. This also separates instantiation from initialization in a manner similar to https://github.com/bytecodealliance/lucet/pull/506. * Update fuzzing oracles for the API changes. * Remove `wasi_linker` and clarify that Commands/Reactors aren't connected to WASI. * Move Command/Reactor semantics into the Linker. * C API support. * Fix fuzzer build. * Update usage syntax from "::" to "=". * Remove `NewInstance` and `start()`. * Elaborate on Commands and Reactors and add a spec link. * Add more comments. * Fix wat syntax. * Fix wat. * Use the `Debug` formatter to format an anyhow::Error. * Fix wat.
27 lines
870 B
Rust
27 lines
870 B
Rust
//! Example of instantiating of instantiating a wasm module which uses WASI
|
|
//! imports.
|
|
|
|
// You can execute this example with `cargo run --example wasi`
|
|
|
|
use anyhow::Result;
|
|
use wasmtime::*;
|
|
use wasmtime_wasi::{Wasi, WasiCtx};
|
|
|
|
fn main() -> Result<()> {
|
|
let store = Store::default();
|
|
let mut linker = Linker::new(&store);
|
|
|
|
// Create an instance of `Wasi` which contains a `WasiCtx`. Note that
|
|
// `WasiCtx` provides a number of ways to configure what the target program
|
|
// will have access to.
|
|
let wasi = Wasi::new(&store, WasiCtx::new(std::env::args())?);
|
|
wasi.add_to_linker(&mut linker)?;
|
|
|
|
// Instantiate our module with the imports we've created, and run it.
|
|
let module = Module::from_file(&store, "target/wasm32-wasi/debug/wasi.wasm")?;
|
|
linker.module("", &module)?;
|
|
linker.get_default("")?.get0::<()>()?()?;
|
|
|
|
Ok(())
|
|
}
|