Skip to main content

wasmtime_wasi/p3/random/
mod.rs

1mod host;
2
3use crate::p3::bindings::random::{insecure, insecure_seed, random};
4use crate::random::{WasiRandom, WasiRandomView};
5use wasmtime::component::Linker;
6
7/// Add all WASI interfaces from this module into the `linker` provided.
8///
9/// This function will add all interfaces implemented by this module to the
10/// [`Linker`], which corresponds to the `wasi:random/imports` world supported by
11/// this crate.
12///
13/// This is low-level API for advanced use cases,
14/// [`wasmtime_wasi::p3::add_to_linker`](crate::p3::add_to_linker) can be used instead
15/// to add *all* wasip3 interfaces (including the ones from this module) to the `linker`.
16///
17///
18/// # Example
19///
20/// ```
21/// use wasmtime::{Engine, Result, Store};
22/// use wasmtime::component::Linker;
23/// use wasmtime_wasi::random::{WasiRandomView, WasiRandomCtx};
24///
25/// fn main() -> Result<()> {
26///     let engine = Engine::default();
27///
28///     let mut linker = Linker::<MyState>::new(&engine);
29///     wasmtime_wasi::p3::random::add_to_linker(&mut linker)?;
30///     // ... add any further functionality to `linker` if desired ...
31///
32///     let mut store = Store::new(
33///         &engine,
34///         MyState {
35///             random: WasiRandomCtx::default(),
36///         },
37///     );
38///
39///     // ... use `linker` to instantiate within `store` ...
40///
41///     Ok(())
42/// }
43///
44/// struct MyState {
45///     random: WasiRandomCtx,
46/// }
47///
48/// impl WasiRandomView for MyState {
49///     fn random(&mut self) -> &mut WasiRandomCtx { &mut self.random }
50/// }
51/// ```
52pub fn add_to_linker<T>(linker: &mut Linker<T>) -> wasmtime::Result<()>
53where
54    T: WasiRandomView + 'static,
55{
56    random::add_to_linker::<_, WasiRandom>(linker, T::random)?;
57    insecure::add_to_linker::<_, WasiRandom>(linker, T::random)?;
58    insecure_seed::add_to_linker::<_, WasiRandom>(linker, T::random)?;
59    Ok(())
60}