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
impl FuncInstance
sourcepub fn alloc_host(signature: Signature, host_func_index: usize) -> FuncRef
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.
sourcepub fn signature(&self) -> &Signature
pub fn signature(&self) -> &Signature
Returns signature of this function instance.
This function instance can only be called with matching signatures.
sourcepub fn invoke<E: Externals>(
func: &FuncRef,
args: &[RuntimeValue],
externals: &mut E
) -> Result<Option<RuntimeValue>, Trap>
pub fn invoke<E: Externals>( func: &FuncRef, args: &[RuntimeValue], externals: &mut E ) -> Result<Option<RuntimeValue>, Trap>
sourcepub fn invoke_with_stack<E: Externals>(
func: &FuncRef,
args: &[RuntimeValue],
externals: &mut E,
stack_recycler: &mut StackRecycler
) -> Result<Option<RuntimeValue>, Trap>
pub fn invoke_with_stack<E: Externals>( func: &FuncRef, args: &[RuntimeValue], externals: &mut E, stack_recycler: &mut StackRecycler ) -> Result<Option<RuntimeValue>, Trap>
sourcepub fn invoke_resumable<'args>(
func: &FuncRef,
args: impl Into<Cow<'args, [RuntimeValue]>>
) -> Result<FuncInvocation<'args>, Trap>
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§
Auto Trait Implementations§
impl !RefUnwindSafe for FuncInstance
impl !Send for FuncInstance
impl !Sync for FuncInstance
impl Unpin for FuncInstance
impl !UnwindSafe for FuncInstance
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere T: Any,
source§fn into_any(self: Box<T, Global>) -> Box<dyn Any, Global>
fn into_any(self: Box<T, Global>) -> Box<dyn Any, Global>
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>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
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)
fn as_any(&self) -> &(dyn Any + 'static)
&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)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.