Struct StoreLimitsBuilder
pub struct StoreLimitsBuilder(/* private fields */);
Expand description
Used to build StoreLimits
.
Implementations§
§impl StoreLimitsBuilder
impl StoreLimitsBuilder
pub fn new() -> StoreLimitsBuilder
pub fn new() -> StoreLimitsBuilder
Creates a new StoreLimitsBuilder
.
See the documentation on each builder method for the default for each value.
pub fn memory_size(self, limit: usize) -> StoreLimitsBuilder
pub fn memory_size(self, limit: usize) -> StoreLimitsBuilder
The maximum number of bytes a linear memory can grow to.
Growing a linear memory beyond this limit will fail. This limit is
applied to each linear memory individually, so if a wasm module has
multiple linear memories then they’re all allowed to reach up to the
limit
specified.
By default, linear memory will not be limited.
pub fn table_elements(self, limit: usize) -> StoreLimitsBuilder
pub fn table_elements(self, limit: usize) -> StoreLimitsBuilder
The maximum number of elements in a table.
Growing a table beyond this limit will fail. This limit is applied to
each table individually, so if a wasm module has multiple tables then
they’re all allowed to reach up to the limit
specified.
By default, table elements will not be limited.
pub fn instances(self, limit: usize) -> StoreLimitsBuilder
pub fn instances(self, limit: usize) -> StoreLimitsBuilder
The maximum number of instances that can be created for a Store
.
Module instantiation will fail if this limit is exceeded.
This value defaults to 10,000.
pub fn tables(self, tables: usize) -> StoreLimitsBuilder
pub fn tables(self, tables: usize) -> StoreLimitsBuilder
The maximum number of tables that can be created for a Store
.
Module instantiation will fail if this limit is exceeded.
This value defaults to 10,000.
pub fn memories(self, memories: usize) -> StoreLimitsBuilder
pub fn memories(self, memories: usize) -> StoreLimitsBuilder
The maximum number of linear memories that can be created for a Store
.
Instantiation will fail with an error if this limit is exceeded.
This value defaults to 10,000.
pub fn trap_on_grow_failure(self, trap: bool) -> StoreLimitsBuilder
pub fn trap_on_grow_failure(self, trap: bool) -> StoreLimitsBuilder
Indicates that a trap should be raised whenever a growth operation would fail.
This operation will force memory.grow
and table.grow
instructions
to raise a trap on failure instead of returning -1. This is not
necessarily spec-compliant, but it can be quite handy when debugging a
module that fails to allocate memory and might behave oddly as a result.
This value defaults to false
.
pub fn build(self) -> StoreLimits
pub fn build(self) -> StoreLimits
Consumes this builder and returns the StoreLimits
.
Auto Trait Implementations§
impl Freeze for StoreLimitsBuilder
impl RefUnwindSafe for StoreLimitsBuilder
impl Send for StoreLimitsBuilder
impl Sync for StoreLimitsBuilder
impl Unpin for StoreLimitsBuilder
impl UnwindSafe for StoreLimitsBuilder
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut 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> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more