Struct wasmi::NotStartedModuleRef
source · [−]pub struct NotStartedModuleRef<'a> { /* private fields */ }
Expand description
Mostly instantiated ModuleRef
.
At this point memory segments and tables are copied. However, start
function (if any) is not called.
To get fully instantiated module instance, running start
function is required.
You can still access not fully initialized instance by calling not_started_instance
,
but keep in mind, that this is sort of escape hatch: module really might depend on initialization
done in start
function. It’s definitely not recommended to call any exports on ModuleRef
returned by this function.
If you sure, that there is no start
function (e.g. because you created it without one), you can
call assert_no_start
which returns ModuleRef
without calling start
function. However,
it will panic if module contains start
function.
Implementations
Returns not fully initialized instance.
To fully initialize the instance you need to call either run_start
or
assert_no_start
. See struct documentation for details.
Executes start
function (if any) and returns fully instantiated module.
Errors
Returns Err
if start function traps.
pub fn run_start_with_stack<E: Externals>(
self,
state: &mut E,
stack_recycler: &mut StackRecycler
) -> Result<ModuleRef, Trap>
pub fn run_start_with_stack<E: Externals>(
self,
state: &mut E,
stack_recycler: &mut StackRecycler
) -> Result<ModuleRef, Trap>
Executes start
function (if any) and returns fully instantiated module.
Errors
Returns Err
if start function traps.
Returns fully instantiated module without running start
function.
Panics
This function panics if original module contains start
function.
Auto Trait Implementations
impl<'a> !RefUnwindSafe for NotStartedModuleRef<'a>
impl<'a> !Send for NotStartedModuleRef<'a>
impl<'a> !Sync for NotStartedModuleRef<'a>
impl<'a> Unpin for NotStartedModuleRef<'a>
impl<'a> !UnwindSafe for NotStartedModuleRef<'a>
Blanket Implementations
Mutably borrows from an owned value. Read more
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
. Read more
Convert Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
. Read more
Convert &Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s. Read more
Convert &mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s. Read more