A RetroSearch Logo

Home - News ( United States | United Kingdom | Italy | Germany ) - Football scores

Search Query:

Showing content from https://docs.wasmtime.dev/api/wasmtime/struct.Caller.html below:

Caller in wasmtime - Rust

pub struct Caller<'a, T: 'static> {  }

Available on crate feature runtime only.

Expand description

A structure representing the caller’s context when creating a function via Func::wrap.

This structure can be taken as the first parameter of a closure passed to Func::wrap or other constructors, and serves two purposes:

Host functions which want access to Store-level state are recommended to use this type.

Source§ Source

Looks up an export from the caller’s module by the name given.

This is a low-level function that’s typically used to implement passing of pointers or indices between core Wasm instances, where the callee needs to consult the caller’s exports to perform memory management and resolve the references.

For comparison, in components, the component model handles translating arguments from one component instance to another and managing memory, so that callees don’t need to be aware of their callers, which promotes virtualizability of APIs.

§Return

If an export with the name provided was found, then it is returned as an Extern. There are a number of situations, however, where the export may not be available:

It’s recommended to take care when calling this API and gracefully handling a None return value.

Source

Looks up an exported Extern value by a ModuleExport value.

This is similar to Self::get_export but uses a ModuleExport value to avoid string lookups where possible. ModuleExports can be obtained by calling [Module::get_export_index] on the [Module] that an instance was instantiated with.

This method will search the module for an export with a matching entity index and return the value, if found.

Returns None if there was no export with a matching entity index.

§Panics

Panics if store does not own this instance.

§Usage
use std::str;


let module = Module::new(
    store.engine(),
    r#"
        (module
            (import "" "" (func $log_str (param i32 i32)))
            (func (export "foo")
                i32.const 4   ;; ptr
                i32.const 13  ;; len
                call $log_str)
            (memory (export "memory") 1)
            (data (i32.const 4) "Hello, world!"))
    "#,
)?;

let Some(module_export) = module.get_export_index("memory") else {
   anyhow::bail!("failed to find `memory` export in module");
};

let log_str = Func::wrap(&mut store, move |mut caller: Caller<'_, ()>, ptr: i32, len: i32| {
    let mem = match caller.get_module_export(&module_export) {
        Some(Extern::Memory(mem)) => mem,
        _ => anyhow::bail!("failed to find host memory"),
    };
    let data = mem.data(&caller)
        .get(ptr as u32 as usize..)
        .and_then(|arr| arr.get(..len as u32 as usize));
    let string = match data {
        Some(data) => match str::from_utf8(data) {
            Ok(s) => s,
            Err(_) => anyhow::bail!("invalid utf-8"),
        },
        None => anyhow::bail!("pointer/length out of bounds"),
    };
    assert_eq!(string, "Hello, world!");
    println!("{}", string);
    Ok(())
});
let instance = Instance::new(&mut store, &module, &[log_str.into()])?;
let foo = instance.get_typed_func::<(), ()>(&mut store, "foo")?;
foo.call(&mut store, ())?;
Source

Access the underlying data owned by this Store.

Same as Store::data

Source Source

Returns the underlying Engine this store is connected to.

Source

Available on crate feature gc only.

Perform garbage collection.

Same as Store::gc.

Source

Available on crate features async and gc only.

Source

Returns the remaining fuel in the store.

For more information see Store::get_fuel

Source

Set the amount of fuel in this store to be consumed when executing wasm code.

For more information see Store::set_fuel

Source

RetroSearch is an open source project built by @garambo | Open a GitHub Issue

Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo

HTML: 3.2 | Encoding: UTF-8 | Version: 0.7.4