Struct wasmi::FuncInstance

source ·
pub struct FuncInstance(_);
Expand description

Runtime representation of a function.

Functions are the unit of organization of code in WebAssembly. Each function takes a sequence of values as parameters and either optionally return a value or trap. Functions can call other function including itself (i.e recursive calls are allowed) and imported functions (i.e functions defined in another module or by the host environment).

Functions can be defined either:

  • by a wasm module,
  • by the host environment and passed to a wasm module as an import. See more in Externals.

Implementations§

source§

impl FuncInstance

source

pub fn alloc_host(signature: Signature, host_func_index: usize) -> FuncRef

Allocate a function instance for a host function.

When this function instance will be called by the wasm code, the instance of Externals will be invoked by calling invoke_index with specified host_func_index here. This call will be made with the signature provided here.

source

pub fn signature(&self) -> &Signature

Returns signature of this function instance.

This function instance can only be called with matching signatures.

source

pub fn invoke<E: Externals>( func: &FuncRef, args: &[RuntimeValue], externals: &mut E ) -> Result<Option<RuntimeValue>, Trap>

Invoke this function.

Errors

Returns Err if args types is not match function signature or if Trap at execution time occured.

source

pub fn invoke_with_stack<E: Externals>( func: &FuncRef, args: &[RuntimeValue], externals: &mut E, stack_recycler: &mut StackRecycler ) -> Result<Option<RuntimeValue>, Trap>

Invoke this function using recycled stacks.

Errors

Same as invoke.

source

pub fn invoke_resumable<'args>( func: &FuncRef, args: impl Into<Cow<'args, [RuntimeValue]>> ) -> Result<FuncInvocation<'args>, Trap>

Invoke the function, get a resumable handle. This handle can then be used to start_execution. If a Host trap happens, caller can use resume_execution to feed the expected return value back in, and then continue the execution.

This is an experimental API, and this functionality may not be available in other WebAssembly engines.

Errors

Returns Err if args types is not match function signature.

Trait Implementations§

source§

impl Debug for FuncInstance

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> Downcast for Twhere T: Any,

source§

fn into_any(self: Box<T, Global>) -> Box<dyn Any, Global>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.