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,

source

pub 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

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.

source

pub fn builder() -> WasmExecutorBuilder<H>

Instantiate a builder for creating an instance of Self.

source

pub fn allow_missing_host_functions( &mut self, allow_missing_host_functions: bool )

👎Deprecated: use Self::builder method instead of it

Ignore missing function imports if set true.

source

pub fn with_instance<R, F>( &self, runtime_code: &RuntimeCode<'_>, ext: &mut dyn Externalities, heap_alloc_strategy: HeapAllocStrategy, f: F ) -> 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>

source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<H> CodeExecutor for WasmExecutor<H>
where H: HostFunctions,

§

type Error = Error

Externalities error type.
source§

fn call( &self, ext: &mut dyn Externalities, runtime_code: &RuntimeCode<'_>, method: &str, data: &[u8], _use_native: bool, context: CallContext ) -> (Result<Vec<u8>>, bool)

Call a given method in the runtime. Read more
source§

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>

Reads the runtime version information from the given wasm code. Read more
source§

impl<H> RuntimeVersionOf for WasmExecutor<H>
where H: HostFunctions,

source§

fn runtime_version( &self, ext: &mut dyn Externalities, runtime_code: &RuntimeCode<'_> ) -> Result<RuntimeVersion>

Extract 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> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
§

impl<T> CheckedConversion for T

§

fn checked_from<T>(t: T) -> Option<Self>
where Self: TryFrom<T>,

Convert from a value of T into an equivalent instance of Option<Self>. Read more
§

fn checked_into<T>(self) -> Option<T>
where Self: TryInto<T>,

Consume self to return Some equivalent value of Option<T>. Read more
source§

impl<T> DynClone for T
where T: Clone,

source§

fn __clone_box(&self, _: Private) -> *mut ()

source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where 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, Outer> IsWrappedBy<Outer> for T
where Outer: AsRef<T> + AsMut<T> + From<T>, T: From<Outer>,

source§

fn from_ref(outer: &Outer) -> &T

Get a reference to the inner from the outer.

source§

fn from_mut(outer: &mut Outer) -> &mut T

Get a mutable reference to the inner from the outer.

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same for T

§

type Output = T

Should always be Self
§

impl<T> SaturatedConversion for T

§

fn saturated_from<T>(t: T) -> Self
where Self: UniqueSaturatedFrom<T>,

Convert from a value of T into an equivalent instance of Self. Read more
§

fn saturated_into<T>(self) -> T
where Self: UniqueSaturatedInto<T>,

Consume self to return an equivalent value of T. Read more
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where 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 T
where 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.
source§

impl<S, T> UncheckedInto<T> for S
where T: UncheckedFrom<S>,

source§

fn unchecked_into(self) -> T

The counterpart to unchecked_from.
§

impl<T, S> UniqueSaturatedInto<T> for S
where T: Bounded, S: TryInto<T>,

§

fn unique_saturated_into(self) -> T

Consume self to return an equivalent value of T.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
§

impl<T> JsonSchemaMaybe for T