Config

Struct Config 

Source
pub struct Config { /* private fields */ }
Expand description

Configuration for an Engine.

Implementations§

Source§

impl Config

Source

pub fn set_stack_limits(&mut self, limits: StackLimits) -> &mut Self

👎Deprecated since 0.51.0: use Config::set_{min,max}_stack_height, Config::max_recursion_depth instead

Sets the StackLimits for the Config.

Source

pub fn set_cached_stacks(&mut self, amount: usize) -> &mut Self

👎Deprecated since 0.51.0: use Config::set_max_cached_stacks instead

Sets the maximum amount of cached stacks for reuse for the Config.

§Note

Defaults to 2.

Source

pub fn set_max_recursion_depth(&mut self, value: usize) -> &mut Self

Sets the maximum recursion depth of the Engine’s stack during execution.

§Note

An execution traps if it exceeds this limits.

Source

pub fn set_min_stack_height(&mut self, value: usize) -> &mut Self

Sets the minimum (or initial) height of the Engine’s value stack in bytes.

§Note
  • Lower initial heights may improve memory consumption.
  • Higher initial heights may improve cold start times.
§Panics

If value is greater than the current maximum height of the value stack.

Source

pub fn set_max_stack_height(&mut self, value: usize) -> &mut Self

Sets the maximum height of the Engine’s value stack in bytes.

§Note

An execution traps if it exceeds this limits.

§Panics

If value is less than the current minimum height of the value stack.

Source

pub fn set_max_cached_stacks(&mut self, value: usize) -> &mut Self

Sets the maximum number of cached stacks for reuse for the Config.

§Note
  • A higher value may improve execution performance.
  • A lower value may improve memory consumption.
Source

pub fn wasm_mutable_global(&mut self, enable: bool) -> &mut Self

Enable or disable the mutable-global Wasm proposal for the Config.

§Note

Enabled by default.

Source

pub fn wasm_sign_extension(&mut self, enable: bool) -> &mut Self

Enable or disable the sign-extension Wasm proposal for the Config.

§Note

Enabled by default.

Source

pub fn wasm_saturating_float_to_int(&mut self, enable: bool) -> &mut Self

Enable or disable the saturating-float-to-int Wasm proposal for the Config.

§Note

Enabled by default.

Source

pub fn wasm_multi_value(&mut self, enable: bool) -> &mut Self

Enable or disable the multi-value Wasm proposal for the Config.

§Note

Enabled by default.

Source

pub fn wasm_multi_memory(&mut self, enable: bool) -> &mut Self

Enable or disable the multi-memory Wasm proposal for the Config.

§Note

Enabled by default.

Source

pub fn wasm_bulk_memory(&mut self, enable: bool) -> &mut Self

Enable or disable the bulk-memory Wasm proposal for the Config.

§Note

Enabled by default.

Source

pub fn wasm_reference_types(&mut self, enable: bool) -> &mut Self

Enable or disable the reference-types Wasm proposal for the Config.

§Note

Enabled by default.

Source

pub fn wasm_tail_call(&mut self, enable: bool) -> &mut Self

Enable or disable the tail-call Wasm proposal for the Config.

§Note

Enabled by default.

Source

pub fn wasm_extended_const(&mut self, enable: bool) -> &mut Self

Enable or disable the extended-const Wasm proposal for the Config.

§Note

Enabled by default.

Source

pub fn wasm_custom_page_sizes(&mut self, enable: bool) -> &mut Self

Enable or disable the custom-page-sizes Wasm proposal for the Config.

§Note

Disabled by default.

Source

pub fn wasm_memory64(&mut self, enable: bool) -> &mut Self

Enable or disable the memory64 Wasm proposal for the Config.

§Note

Disabled by default.

Source

pub fn wasm_wide_arithmetic(&mut self, enable: bool) -> &mut Self

Enable or disable the wide-arithmetic Wasm proposal for the Config.

Disabled by default.

Source

pub fn wasm_simd(&mut self, enable: bool) -> &mut Self

Enable or disable the simd Wasm proposal for the Config.

Enabled by default.

Source

pub fn wasm_relaxed_simd(&mut self, enable: bool) -> &mut Self

Enable or disable the relaxed-simd Wasm proposal for the Config.

Enabled by default.

Source

pub fn floats(&mut self, enable: bool) -> &mut Self

Enable or disable Wasm floating point (f32 and f64) instructions and types.

Enabled by default.

Source

pub fn consume_fuel(&mut self, enable: bool) -> &mut Self

Configures whether Wasmi will consume fuel during execution to either halt execution as desired.

§Note

This configuration can be used to make Wasmi instrument its internal bytecode so that it consumes fuel as it executes. Once an execution runs out of fuel a TrapCode::OutOfFuel trap is raised. This way users can deterministically halt or yield the execution of WebAssembly code.

Disabled by default.

Source

pub fn ignore_custom_sections(&mut self, enable: bool) -> &mut Self

Configures whether Wasmi will ignore custom sections when parsing Wasm modules.

Default value: false

Source

pub fn compilation_mode(&mut self, mode: CompilationMode) -> &mut Self

Sets the CompilationMode used for the Engine.

By default CompilationMode::LazyTranslation is used.

Source

pub fn enforced_limits(&mut self, limits: EnforcedLimits) -> &mut Self

Sets the EnforcedLimits enforced by the Engine for Wasm module parsing and compilation.

By default no limits are enforced.

Trait Implementations§

Source§

impl Clone for Config

Source§

fn clone(&self) -> Config

Returns a duplicate 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 Debug for Config

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for Config

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl Freeze for Config

§

impl !RefUnwindSafe for Config

§

impl Send for Config

§

impl Sync for Config

§

impl Unpin for Config

§

impl !UnwindSafe for Config

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
Source§

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

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> ToOwned for T
where T: Clone,

Source§

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>,

Source§

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>,

Source§

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.