pub struct SnapshotMap<'a, K, T> { /* private fields */ }
Expand description

Map that maintains a snapshots of one or more checkpoints. We can query historical data as well as current state. What data is snapshotted depends on the Strategy.

Implementations§

source§

impl<'a, K, T> SnapshotMap<'a, K, T>

source

pub const fn new( pk: &'a str, checkpoints: &'a str, changelog: &'a str, strategy: Strategy ) -> Self

Example:

use cw_storage_plus::{SnapshotMap, Strategy};

SnapshotMap::<&[u8], &str>::new(
    "never",
    "never__check",
    "never__change",
    Strategy::EveryBlock
);
source

pub fn changelog(&self) -> &Map<'a, (K, u64), ChangeSet<T>>

source§

impl<'a, K, T> SnapshotMap<'a, K, T>where T: Serialize + DeserializeOwned + Clone, K: PrimaryKey<'a> + Prefixer<'a>,

source

pub fn add_checkpoint( &self, store: &mut dyn Storage, height: u64 ) -> StdResult<()>

source

pub fn remove_checkpoint( &self, store: &mut dyn Storage, height: u64 ) -> StdResult<()>

source§

impl<'a, K, T> SnapshotMap<'a, K, T>where T: Serialize + DeserializeOwned + Clone, K: PrimaryKey<'a> + Prefixer<'a> + KeyDeserialize,

source

pub fn key(&self, k: K) -> Path<T>

source

pub fn save( &self, store: &mut dyn Storage, k: K, data: &T, height: u64 ) -> StdResult<()>

source

pub fn remove( &self, store: &mut dyn Storage, k: K, height: u64 ) -> StdResult<()>

source

pub fn load(&self, store: &dyn Storage, k: K) -> 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, store: &dyn Storage, k: K) -> 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 may_load_at_height( &self, store: &dyn Storage, k: K, height: u64 ) -> StdResult<Option<T>>

source

pub fn assert_checkpointed( &self, store: &dyn Storage, height: u64 ) -> StdResult<()>

source

pub fn update<A, E>( &self, store: &mut dyn Storage, k: K, height: u64, action: A ) -> Result<T, E>where A: FnOnce(Option<T>) -> Result<T, E>, E: From<StdError>,

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

If the data exists, action(Some(value)) is called. Otherwise action(None) is called.

This is a bit more customized than needed to only read “old” value 1 time, not 2 per naive approach

source§

impl<'a, K, T> SnapshotMap<'a, K, T>where T: Serialize + DeserializeOwned + Clone, K: PrimaryKey<'a> + Prefixer<'a> + KeyDeserialize,

source

pub fn range_raw<'c>( &self, store: &'c dyn Storage, min: Option<Bound<'a, K>>, max: Option<Bound<'a, K>>, order: Order ) -> Box<dyn Iterator<Item = StdResult<Record<T>>> + 'c>where T: 'c,

source

pub fn keys_raw<'c>( &self, store: &'c dyn Storage, min: Option<Bound<'a, K>>, max: Option<Bound<'a, K>>, order: Order ) -> Box<dyn Iterator<Item = Vec<u8>> + 'c>where T: 'c,

source§

impl<'a, K, T> SnapshotMap<'a, K, T>where T: Serialize + DeserializeOwned, K: PrimaryKey<'a> + KeyDeserialize,

source

pub fn prefix_range<'c>( &self, store: &'c dyn Storage, min: Option<PrefixBound<'a, K::Prefix>>, max: Option<PrefixBound<'a, K::Prefix>>, order: Order ) -> Box<dyn Iterator<Item = StdResult<(K::Output, T)>> + 'c>where T: 'c, K: 'c, K::Output: 'static, 'a: 'c,

While range over a prefix fixes the prefix to one element and iterates over the remaining, prefix_range accepts bounds for the lowest and highest elements of the Prefix itself, and iterates over those (inclusively or exclusively, depending on PrefixBound). There are some issues that distinguish these two, and blindly casting to Vec<u8> doesn’t solve them.

source

pub fn range<'c>( &self, store: &'c dyn Storage, min: Option<Bound<'a, K>>, max: Option<Bound<'a, K>>, order: Order ) -> Box<dyn Iterator<Item = StdResult<(K::Output, T)>> + 'c>where T: 'c, K::Output: 'static,

source

pub fn keys<'c>( &self, store: &'c dyn Storage, min: Option<Bound<'a, K>>, max: Option<Bound<'a, K>>, order: Order ) -> Box<dyn Iterator<Item = StdResult<K::Output>> + 'c>where T: 'c, K::Output: 'static,

source

pub fn prefix(&self, p: K::Prefix) -> Prefix<K::Suffix, T, K::Suffix>

source

pub fn sub_prefix( &self, p: K::SubPrefix ) -> Prefix<K::SuperSuffix, T, K::SuperSuffix>

Auto Trait Implementations§

§

impl<'a, K, T> RefUnwindSafe for SnapshotMap<'a, K, T>where K: RefUnwindSafe, T: RefUnwindSafe,

§

impl<'a, K, T> Send for SnapshotMap<'a, K, T>where K: Send, T: Send,

§

impl<'a, K, T> Sync for SnapshotMap<'a, K, T>where K: Sync, T: Sync,

§

impl<'a, K, T> Unpin for SnapshotMap<'a, K, T>where K: Unpin, T: Unpin,

§

impl<'a, K, T> UnwindSafe for SnapshotMap<'a, K, T>where K: UnwindSafe, T: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for Twhere 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) -> Twhere 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 Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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 Twhere 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 Twhere 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 Twhere 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.