pub struct Singleton<'a, T>{ /* private fields */ }
👎Deprecated: The crate cosmwasm-storage is unmaintained and will be removed in CosmWasm 2.0. Please consider migrating to cw-storage-plus or simple cosmwasm-std storage calls.
Expand description

Singleton effectively combines PrefixedStorage with TypedStorage to work on a single storage key. It performs the to_length_prefixed transformation on the given name to ensure no collisions, and then provides the standard TypedStorage accessors, without requiring a key (which is defined in the constructor)

Implementations§

source§

impl<'a, T> Singleton<'a, T>

source

pub fn new(storage: &'a mut dyn Storage, key: &[u8]) -> Self

source

pub fn save(&mut self, data: &T) -> StdResult<()>

save will serialize the model and store, returns an error on serialization issues

source

pub fn remove(&mut self)

source

pub fn load(&self) -> StdResult<T>

load will return an error if no data is set at the given key, or on parse error

source

pub fn may_load(&self) -> StdResult<Option<T>>

may_load will parse the data stored at the key if present, returns Ok(None) if no data there. returns an error on issues parsing

source

pub fn update<A, E>(&mut self, action: A) -> Result<T, E>
where A: FnOnce(T) -> Result<T, E>, E: From<StdError>,

update will load the data, perform the specified action, and store the result in the database. This is shorthand for some common sequences, which may be useful

This is the least stable of the APIs, and definitely needs some usage

Auto Trait Implementations§

§

impl<'a, T> !RefUnwindSafe for Singleton<'a, T>

§

impl<'a, T> !Send for Singleton<'a, T>

§

impl<'a, T> !Sync for Singleton<'a, T>

§

impl<'a, T> Unpin for Singleton<'a, T>
where T: Unpin,

§

impl<'a, T> !UnwindSafe for Singleton<'a, T>

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
§

impl<U> As for U

§

fn as_<T>(self) -> T
where T: CastFrom<U>,

Casts self to type T. The semantics of numeric casting with the as operator are followed, so <T as As>::as_::<U> can be used in the same way as T as U for numeric conversions. 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> Same for T

§

type Output = T

Should always be Self
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.