multiversx_sc::storage::mappers

Struct VecMapper

Source
pub struct VecMapper<SA, T, A = CurrentStorage>
where SA: StorageMapperApi, T: TopEncode + TopDecode + 'static,
{ /* private fields */ }
Expand description

Manages a list of items of the same type. Saves each of the items under a separate key in storage. To produce each individual key, it concatenates the main key with a serialized 4-byte index. Indexes start from 1, instead of 0. (We avoid 0-value indexes to prevent confusion between an uninitialized variable and zero.) It also stores the count separately, at what would be index 0. The count is always kept in sync automatically.

Implementations§

Source§

impl<SA, T, A> VecMapper<SA, T, A>
where SA: StorageMapperApi, A: StorageAddress<SA>, T: TopEncode + TopDecode,

Source

pub fn len(&self) -> usize

Number of items managed by the mapper.

Source

pub fn is_empty(&self) -> bool

True if no items present in the mapper.

Source

pub fn get(&self, index: usize) -> T

Get item at index from storage. Index must be valid (1 <= index <= count).

Source

pub fn get_unchecked(&self, index: usize) -> T

Get item at index from storage. There are no restrictions on the index, calling for an invalid index will simply return the zero-value.

Source

pub fn get_or_else<F: FnOnce() -> T>(self, index: usize, or_else: F) -> T

Get item at index from storage. If index is valid (1 <= index <= count), returns value at index, else calls lambda given as argument. The lambda only gets called lazily if the index is not valid.

Source

pub fn item_is_empty(&self, index: usize) -> bool

Checks whether or not there is anything ins storage at index. Index must be valid (1 <= index <= count).

Source

pub fn item_is_empty_unchecked(&self, index: usize) -> bool

Checks whether or not there is anything in storage at index. There are no restrictions on the index, calling for an invalid index will simply return true.

Source

pub fn load_as_vec(&self) -> Vec<T>

Loads all items from storage and places them in a Vec. Can easily consume a lot of gas.

Source

pub fn iter(&self) -> Iter<'_, SA, T, A>

Provides a forward iterator.

Source§

impl<SA, T> VecMapper<SA, T, CurrentStorage>

Source

pub fn push(&mut self, item: &T) -> usize

Add one item at the end of the list. Returns the index of the newly inserted item, which is also equal to the new number of elements.

Source

pub fn extend_from_slice(&mut self, items: &[T]) -> usize

Adds multiple items at the end of the list. Cheaper than multiple push-es because the count only gets updated once at the end. Returns the index of the last inserted item, which is also equal to the new number of elements.

Source

pub fn set(&mut self, index: usize, item: &T)

Set item at index in storage. Index must be valid (1 <= index <= count).

Source

pub fn update<R, F: FnOnce(&mut T) -> R>(&mut self, index: usize, f: F) -> R

Syntactic sugar, to more compactly express a get, update and set in one line. Takes whatever lies in storage, apples the given closure and saves the final value back to storage. Propagates the return value of the given function.

Source

pub fn clear_entry(&self, index: usize)

Clears item at index from storage. Index must be valid (1 <= index <= count).

Source

pub fn clear_entry_unchecked(&self, index: usize)

Clears item at index from storage. There are no restrictions on the index, calling for an invalid index will simply do nothing.

Source

pub fn swap_remove(&mut self, index: usize)

Clears item at index from storage by swap remove last item takes the index of the item to remove and we remove the last index.

Source

pub fn clear(&mut self)

Deletes all contents form storage and sets count to 0. Can easily consume a lot of gas.

Trait Implementations§

Source§

impl<'a, SA, T, A> IntoIterator for &'a VecMapper<SA, T, A>
where SA: StorageMapperApi, A: StorageAddress<SA>, T: TopEncode + TopDecode + 'static,

Source§

type Item = T

The type of the elements being iterated over.
Source§

type IntoIter = Iter<'a, SA, T, A>

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more
Source§

impl<SA, T> StorageClearable for VecMapper<SA, T, CurrentStorage>

Source§

fn clear(&mut self)

Clears all the entries owned by the storage.
Source§

impl<SA, T> StorageMapper<SA> for VecMapper<SA, T, CurrentStorage>

Source§

fn new(base_key: StorageKey<SA>) -> Self

Will be called automatically by the #[storage_mapper] annotation generated code.
Source§

impl<SA, T> StorageMapperFromAddress<SA> for VecMapper<SA, T, ManagedAddress<SA>>

Source§

fn new_from_address( address: ManagedAddress<SA>, base_key: StorageKey<SA>, ) -> Self

Will be called automatically by the #[storage_mapper_from_address] annotation generated code.
Source§

impl<SA, T> TopEncodeMulti for VecMapper<SA, T, CurrentStorage>

Behaves like a MultiResultVec when an endpoint result.

Source§

fn multi_encode_or_handle_err<O, H>( &self, output: &mut O, h: H, ) -> Result<(), H::HandledErr>

Version of top_encode that can handle errors as soon as they occur. For instance in can exit immediately and make sure that if it returns, it is a success. By not deferring error handling, this can lead to somewhat smaller bytecode.
Source§

fn multi_encode<O>(&self, output: &mut O) -> Result<(), EncodeError>

Attempt to serialize the value to ouput.
Source§

impl<SA, T> TypeAbi for VecMapper<SA, T, CurrentStorage>

Behaves like a MultiResultVec when an endpoint result.

Source§

type Unmanaged = VecMapper<SA, T>

Source§

fn type_name() -> TypeName

Source§

fn type_name_rust() -> TypeName

Source§

fn provide_type_descriptions<TDC: TypeDescriptionContainer>( accumulator: &mut TDC, )

A type can provide more than its own name. For instance, a struct can also provide the descriptions of the type of its fields. TypeAbi doesn’t care for the exact accumulator type, which is abstracted by the TypeDescriptionContainer trait.
Source§

fn type_names() -> TypeNames

Source§

impl<SA, T> TypeAbiFrom<VecMapper<SA, T>> for MultiValueEncoded<SA, T>

Source§

impl<SA, T> TypeAbiFrom<VecMapper<SA, T>> for VecMapper<SA, T, CurrentStorage>

Auto Trait Implementations§

§

impl<SA, T, A> Freeze for VecMapper<SA, T, A>

§

impl<SA, T, A> RefUnwindSafe for VecMapper<SA, T, A>

§

impl<SA, T, A> Send for VecMapper<SA, T, A>
where A: Send, SA: Send, T: Send, <SA as HandleTypeInfo>::ManagedBufferHandle: Send,

§

impl<SA, T, A> Sync for VecMapper<SA, T, A>
where A: Sync, SA: Sync, T: Sync, <SA as HandleTypeInfo>::ManagedBufferHandle: Sync,

§

impl<SA, T, A> Unpin for VecMapper<SA, T, A>

§

impl<SA, T, A> UnwindSafe for VecMapper<SA, T, A>

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

impl<O, T> ProxyArg<O> for T
where O: TypeAbiFrom<T>, T: TopEncodeMulti,