Struct sc_executor::WasmExecutor
source · pub struct WasmExecutor<H> { /* private fields */ }
Expand description
An abstraction over Wasm code executor. Supports selecting execution backend and manages runtime cache.
Implementations
sourceimpl<H> WasmExecutor<H>where
H: HostFunctions,
impl<H> WasmExecutor<H>where
H: HostFunctions,
sourcepub fn new(
method: WasmExecutionMethod,
default_heap_pages: Option<u64>,
max_runtime_instances: usize,
cache_path: Option<PathBuf>,
runtime_cache_size: u8
) -> Self
pub fn new(
method: WasmExecutionMethod,
default_heap_pages: Option<u64>,
max_runtime_instances: usize,
cache_path: Option<PathBuf>,
runtime_cache_size: u8
) -> Self
Create new instance.
Parameters
method
- Method used to execute Wasm code.
default_heap_pages
- Number of 64KB pages to allocate for Wasm execution. Internally this
will be mapped as HeapAllocStrategy::Static
where default_heap_pages
represent the
static number of heap pages to allocate. Defaults to DEFAULT_HEAP_ALLOC_STRATEGY
if None
is provided.
max_runtime_instances
- The number of runtime instances to keep in memory ready for reuse.
cache_path
- A path to a directory where the executor can place its files for purposes of
caching. This may be important in cases when there are many different modules with the
compiled execution method is used.
runtime_cache_size
- The capacity of runtime cache.
sourcepub fn builder(method: WasmExecutionMethod) -> WasmExecutorBuilder<H>
pub fn builder(method: WasmExecutionMethod) -> WasmExecutorBuilder<H>
Instantiate a builder for creating an instance of Self
.
sourcepub fn allow_missing_host_functions(
&mut self,
allow_missing_host_functions: bool
)
pub fn allow_missing_host_functions(
&mut self,
allow_missing_host_functions: bool
)
Ignore missing function imports if set true.
sourcepub fn with_instance<R, F>(
&self,
runtime_code: &RuntimeCode<'_>,
ext: &mut dyn Externalities,
heap_alloc_strategy: HeapAllocStrategy,
f: F
) -> Result<R>where
F: FnOnce(AssertUnwindSafe<&Arc<dyn WasmModule>>, AssertUnwindSafe<&mut dyn WasmInstance>, Option<&RuntimeVersion>, AssertUnwindSafe<&mut dyn Externalities>) -> Result<Result<R>>,
pub fn with_instance<R, F>(
&self,
runtime_code: &RuntimeCode<'_>,
ext: &mut dyn Externalities,
heap_alloc_strategy: HeapAllocStrategy,
f: F
) -> Result<R>where
F: FnOnce(AssertUnwindSafe<&Arc<dyn WasmModule>>, AssertUnwindSafe<&mut dyn WasmInstance>, Option<&RuntimeVersion>, AssertUnwindSafe<&mut dyn Externalities>) -> Result<Result<R>>,
Execute the given closure f
with the latest runtime (based on runtime_code
).
The closure f
is expected to return Err(_)
when there happened a panic!
in native code
while executing the runtime in Wasm. If a panic!
occurred, the runtime is invalidated to
prevent any poisoned state. Native runtime execution does not need to report back
any panic!
.
Safety
runtime
and ext
are given as AssertUnwindSafe
to the closure. As described above, the
runtime is invalidated on any panic!
to prevent a poisoned state. ext
is already
implicitly handled as unwind safe, as we store it in a global variable while executing the
native runtime.
Trait Implementations
sourceimpl<H> Clone for WasmExecutor<H>
impl<H> Clone for WasmExecutor<H>
sourceimpl<H> CodeExecutor for WasmExecutor<H>where
H: HostFunctions,
impl<H> CodeExecutor for WasmExecutor<H>where
H: HostFunctions,
sourcefn call(
&self,
ext: &mut dyn Externalities,
runtime_code: &RuntimeCode<'_>,
method: &str,
data: &[u8],
_use_native: bool,
context: CallContext
) -> (Result<Vec<u8>>, bool)
fn call(
&self,
ext: &mut dyn Externalities,
runtime_code: &RuntimeCode<'_>,
method: &str,
data: &[u8],
_use_native: bool,
context: CallContext
) -> (Result<Vec<u8>>, bool)
sourceimpl<H> ReadRuntimeVersion for WasmExecutor<H>where
H: HostFunctions,
impl<H> ReadRuntimeVersion for WasmExecutor<H>where
H: HostFunctions,
sourcefn read_runtime_version(
&self,
wasm_code: &[u8],
ext: &mut dyn Externalities
) -> Result<Vec<u8>, String>
fn read_runtime_version(
&self,
wasm_code: &[u8],
ext: &mut dyn Externalities
) -> Result<Vec<u8>, String>
sourceimpl<H> RuntimeVersionOf for WasmExecutor<H>where
H: HostFunctions,
impl<H> RuntimeVersionOf for WasmExecutor<H>where
H: HostFunctions,
sourcefn runtime_version(
&self,
ext: &mut dyn Externalities,
runtime_code: &RuntimeCode<'_>
) -> Result<RuntimeVersion>
fn runtime_version(
&self,
ext: &mut dyn Externalities,
runtime_code: &RuntimeCode<'_>
) -> Result<RuntimeVersion>
RuntimeVersion
of the given runtime_code
.Auto Trait Implementations
impl<H> !RefUnwindSafe for WasmExecutor<H>
impl<H> Send for WasmExecutor<H>where
H: Send,
impl<H> Sync for WasmExecutor<H>where
H: Sync,
impl<H> Unpin for WasmExecutor<H>where
H: Unpin,
impl<H> !UnwindSafe for WasmExecutor<H>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
sourceimpl<T> CheckedConversion for T
impl<T> CheckedConversion for T
sourcefn checked_from<T>(t: T) -> Option<Self>where
Self: TryFrom<T>,
fn checked_from<T>(t: T) -> Option<Self>where
Self: TryFrom<T>,
sourcefn checked_into<T>(self) -> Option<T>where
Self: TryInto<T>,
fn checked_into<T>(self) -> Option<T>where
Self: TryInto<T>,
impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>
fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, 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
. Read morefn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
. Read morefn 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. Read morefn 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. Read moresourceimpl<T> Instrument for T
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
sourcefn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
sourceimpl<T, Outer> IsWrappedBy<Outer> for Twhere
Outer: AsRef<T> + AsMut<T> + From<T>,
T: From<Outer>,
impl<T, Outer> IsWrappedBy<Outer> for Twhere
Outer: AsRef<T> + AsMut<T> + From<T>,
T: From<Outer>,
impl<T> Pointable for T
impl<T> Pointable for T
sourceimpl<T> SaturatedConversion for T
impl<T> SaturatedConversion for T
sourcefn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
sourcefn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
T
. Read moresourceimpl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
sourcefn unchecked_into(self) -> T
fn unchecked_into(self) -> T
unchecked_from
.sourceimpl<T, S> UniqueSaturatedInto<T> for Swhere
T: Bounded,
S: TryInto<T>,
impl<T, S> UniqueSaturatedInto<T> for Swhere
T: Bounded,
S: TryInto<T>,
sourcefn unique_saturated_into(self) -> T
fn unique_saturated_into(self) -> T
T
.