Struct snarkvm_ledger_store::helpers::memory::internal::NestedMemoryMap
source · pub struct NestedMemoryMap<M: Copy + Clone + PartialEq + Eq + Hash + Serialize + for<'de> Deserialize<'de> + Send + Sync, K: Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync, V: Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync> { /* private fields */ }
Trait Implementations§
source§impl<M: Clone + Copy + Clone + PartialEq + Eq + Hash + Serialize + for<'de> Deserialize<'de> + Send + Sync, K: Clone + Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync, V: Clone + Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync> Clone for NestedMemoryMap<M, K, V>
impl<M: Clone + Copy + Clone + PartialEq + Eq + Hash + Serialize + for<'de> Deserialize<'de> + Send + Sync, K: Clone + Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync, V: Clone + Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync> Clone for NestedMemoryMap<M, K, V>
source§fn clone(&self) -> NestedMemoryMap<M, K, V>
fn clone(&self) -> NestedMemoryMap<M, K, V>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl<M: Copy + Clone + PartialEq + Eq + Hash + Serialize + for<'de> Deserialize<'de> + Send + Sync, K: Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync, V: Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync> Default for NestedMemoryMap<M, K, V>
impl<M: Copy + Clone + PartialEq + Eq + Hash + Serialize + for<'de> Deserialize<'de> + Send + Sync, K: Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync, V: Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync> Default for NestedMemoryMap<M, K, V>
source§impl<M: Copy + Clone + PartialEq + Eq + Hash + Serialize + for<'de> Deserialize<'de> + Send + Sync, K: Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync, V: Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync> FromIterator<(M, K, V)> for NestedMemoryMap<M, K, V>
impl<M: Copy + Clone + PartialEq + Eq + Hash + Serialize + for<'de> Deserialize<'de> + Send + Sync, K: Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync, V: Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync> FromIterator<(M, K, V)> for NestedMemoryMap<M, K, V>
source§fn from_iter<I: IntoIterator<Item = (M, K, V)>>(iter: I) -> Self
fn from_iter<I: IntoIterator<Item = (M, K, V)>>(iter: I) -> Self
Initializes a new NestedMemoryMap
from the given iterator.
source§impl<'a, M: 'a + Copy + Clone + PartialEq + Eq + Hash + Serialize + for<'de> Deserialize<'de> + Send + Sync, K: 'a + Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync, V: 'a + Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync> NestedMap<'a, M, K, V> for NestedMemoryMap<M, K, V>
impl<'a, M: 'a + Copy + Clone + PartialEq + Eq + Hash + Serialize + for<'de> Deserialize<'de> + Send + Sync, K: 'a + Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync, V: 'a + Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync> NestedMap<'a, M, K, V> for NestedMemoryMap<M, K, V>
source§fn insert(&self, map: M, key: K, value: V) -> Result<()>
fn insert(&self, map: M, key: K, value: V) -> Result<()>
Inserts the given map-key-value pair.
source§fn remove_key(&self, map: &M, key: &K) -> Result<()>
fn remove_key(&self, map: &M, key: &K) -> Result<()>
Removes the key-value pair for the given map and key.
source§fn start_atomic(&self)
fn start_atomic(&self)
Begins an atomic operation. Any further calls to insert
and remove
will be queued
without an actual write taking place until finish_atomic
is called.
source§fn is_atomic_in_progress(&self) -> bool
fn is_atomic_in_progress(&self) -> bool
Checks whether an atomic operation is currently in progress. This can be done to ensure that lower-level operations don’t start and finish their individual atomic write batch if they are already part of a larger one.
source§fn atomic_checkpoint(&self)
fn atomic_checkpoint(&self)
Saves the current list of pending operations, so that if atomic_rewind
is called,
we roll back all future operations, and return to the start of this checkpoint.
source§fn clear_latest_checkpoint(&self)
fn clear_latest_checkpoint(&self)
Removes the latest atomic checkpoint.
source§fn atomic_rewind(&self)
fn atomic_rewind(&self)
Removes all pending operations to the last atomic_checkpoint
(or to start_atomic
if no checkpoints have been created).
source§fn abort_atomic(&self)
fn abort_atomic(&self)
Aborts the current atomic operation.
source§fn finish_atomic(&self) -> Result<()>
fn finish_atomic(&self) -> Result<()>
Finishes an atomic operation, performing all the queued writes.
source§impl<'a, M: 'a + Copy + Clone + PartialEq + Eq + Hash + Serialize + for<'de> Deserialize<'de> + Send + Sync, K: 'a + Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync, V: 'a + Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync> NestedMapRead<'a, M, K, V> for NestedMemoryMap<M, K, V>
impl<'a, M: 'a + Copy + Clone + PartialEq + Eq + Hash + Serialize + for<'de> Deserialize<'de> + Send + Sync, K: 'a + Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync, V: 'a + Clone + PartialEq + Eq + Serialize + for<'de> Deserialize<'de> + Send + Sync> NestedMapRead<'a, M, K, V> for NestedMemoryMap<M, K, V>
source§fn contains_key_confirmed(&self, map: &M, key: &K) -> Result<bool>
fn contains_key_confirmed(&self, map: &M, key: &K) -> Result<bool>
Returns true
if the given key exists in the map.
source§fn contains_key_speculative(&self, map: &M, key: &K) -> Result<bool>
fn contains_key_speculative(&self, map: &M, key: &K) -> Result<bool>
Returns true
if the given key exists in the map.
This method first checks the atomic batch, and if it does not exist, then checks the map.
source§fn get_map_confirmed(&'a self, map: &M) -> Result<Vec<(K, V)>>
fn get_map_confirmed(&'a self, map: &M) -> Result<Vec<(K, V)>>
Returns the confirmed key-value pairs for the given map, if it exists.
source§fn get_map_speculative(&'a self, map: &M) -> Result<Vec<(K, V)>>
fn get_map_speculative(&'a self, map: &M) -> Result<Vec<(K, V)>>
Returns the speculative key-value pairs for the given map, if it exists.
source§fn get_value_confirmed(&'a self, map: &M, key: &K) -> Result<Option<Cow<'a, V>>>
fn get_value_confirmed(&'a self, map: &M, key: &K) -> Result<Option<Cow<'a, V>>>
Returns the value for the given key from the map, if it exists.
source§fn get_value_pending(&self, map: &M, key: &K) -> Option<Option<V>>
fn get_value_pending(&self, map: &M, key: &K) -> Option<Option<V>>
Returns the current value for the given key if it is scheduled to be inserted as part of an atomic batch.
If the key does not exist, returns None
.
If the key is removed in the batch, returns Some(None)
.
If the key is inserted in the batch, returns Some(Some(value))
.
source§fn iter_pending(&'a self) -> Self::PendingIterator
fn iter_pending(&'a self) -> Self::PendingIterator
Returns an iterator visiting each map-key-value pair in the atomic batch.
source§fn iter_confirmed(&'a self) -> Self::Iterator
fn iter_confirmed(&'a self) -> Self::Iterator
Returns an iterator visiting each confirmed map-key-value pair.
source§fn keys_confirmed(&'a self) -> Self::Keys
fn keys_confirmed(&'a self) -> Self::Keys
Returns an iterator over each confirmed key.
source§fn values_confirmed(&'a self) -> Self::Values
fn values_confirmed(&'a self) -> Self::Values
Returns an iterator over each confirmed value.