referrerpolicy=no-referrer-when-downgrade

Trait frame_support::traits::StoredMap

source ·
pub trait StoredMap<K, T: Default> {
    // Required methods
    fn get(k: &K) -> T;
    fn try_mutate_exists<R, E: From<DispatchError>>(
        k: &K,
        f: impl FnOnce(&mut Option<T>) -> Result<R, E>,
    ) -> Result<R, E>;

    // Provided methods
    fn mutate<R>(k: &K, f: impl FnOnce(&mut T) -> R) -> Result<R, DispatchError> { ... }
    fn mutate_exists<R>(
        k: &K,
        f: impl FnOnce(&mut Option<T>) -> R,
    ) -> Result<R, DispatchError> { ... }
    fn insert(k: &K, t: T) -> Result<(), DispatchError> { ... }
    fn remove(k: &K) -> Result<(), DispatchError> { ... }
}
Expand description

An abstraction of a value stored within storage, but possibly as part of a larger composite item.

Required Methods§

source

fn get(k: &K) -> T

Get the item, or its default if it doesn’t yet exist; we make no distinction between the two.

source

fn try_mutate_exists<R, E: From<DispatchError>>( k: &K, f: impl FnOnce(&mut Option<T>) -> Result<R, E>, ) -> Result<R, E>

Maybe mutate the item only if an Ok value is returned from f. Do nothing if an Err is returned. It is removed or reset to default value if it has been mutated to None. f will always be called with an option representing if the storage item exists (Some<V>) or if the storage item does not exist (None), independent of the QueryType.

Provided Methods§

source

fn mutate<R>(k: &K, f: impl FnOnce(&mut T) -> R) -> Result<R, DispatchError>

Mutate the item.

source

fn mutate_exists<R>( k: &K, f: impl FnOnce(&mut Option<T>) -> R, ) -> Result<R, DispatchError>

Mutate the item, removing or resetting to default value if it has been mutated to None.

This is infallible as long as the value does not get destroyed.

source

fn insert(k: &K, t: T) -> Result<(), DispatchError>

Set the item to something new.

source

fn remove(k: &K) -> Result<(), DispatchError>

Remove the item or otherwise replace it with its default value; we don’t care which.

Object Safety§

This trait is not object safe.

Implementors§

source§

impl<S: StorageMap<K, T, Query = T>, K: FullCodec, T: FullCodec + Default> StoredMap<K, T> for StorageMapShim<S, K, T>