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§
source§impl<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
👎Deprecated: use Self::builder
method instead of it
pub fn new( method: WasmExecutionMethod, default_heap_pages: Option<u64>, max_runtime_instances: usize, cache_path: Option<PathBuf>, runtime_cache_size: u8 ) -> Self
Self::builder
method instead of itCreate 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() -> WasmExecutorBuilder<H>
pub fn builder() -> WasmExecutorBuilder<H>
Instantiate a builder for creating an instance of Self
.
sourcepub fn allow_missing_host_functions(
&mut self,
allow_missing_host_functions: bool
)
👎Deprecated: use Self::builder
method instead of it
pub fn allow_missing_host_functions( &mut self, allow_missing_host_functions: bool )
Self::builder
method instead of itIgnore 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<&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<&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§
source§impl<H> Clone for WasmExecutor<H>
impl<H> Clone for WasmExecutor<H>
source§impl<H> CodeExecutor for WasmExecutor<H>where
H: HostFunctions,
impl<H> CodeExecutor for WasmExecutor<H>where H: HostFunctions,
source§impl<H> ReadRuntimeVersion for WasmExecutor<H>where
H: HostFunctions,
impl<H> ReadRuntimeVersion for WasmExecutor<H>where H: HostFunctions,
source§fn 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>
source§impl<H> RuntimeVersionOf for WasmExecutor<H>where
H: HostFunctions,
impl<H> RuntimeVersionOf for WasmExecutor<H>where H: HostFunctions,
source§fn 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§
source§impl<T> CheckedConversion for T
impl<T> CheckedConversion for T
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<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
source§impl<T> SaturatedConversion for T
impl<T> SaturatedConversion for T
source§fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
fn saturated_from<T>(t: T) -> Selfwhere Self: UniqueSaturatedFrom<T>,
source§fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
fn saturated_into<T>(self) -> Twhere Self: UniqueSaturatedInto<T>,
T
. Read moresource§impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
impl<S, T> UncheckedInto<T> for Swhere T: UncheckedFrom<S>,
source§fn unchecked_into(self) -> T
fn unchecked_into(self) -> T
unchecked_from
.source§impl<T, S> UniqueSaturatedInto<T> for Swhere
T: Bounded,
S: TryInto<T>,
impl<T, S> UniqueSaturatedInto<T> for Swhere T: Bounded, S: TryInto<T>,
source§fn unique_saturated_into(self) -> T
fn unique_saturated_into(self) -> T
T
.