pub struct Map<K, V: Storable<D>, D: DB = DefaultDB, A: Storable<D> + Annotation<V> = SizeAnn> { /* private fields */ }Expand description
A persistently stored map, guaranteeing O(1) clones and log-time modifications.
Implementations§
Source§impl<K: Serializable + Deserializable, V: Storable<D>, D: DB, A: Storable<D> + Annotation<V>> Map<K, V, D, A>
impl<K: Serializable + Deserializable, V: Storable<D>, D: DB, A: Storable<D> + Annotation<V>> Map<K, V, D, A>
Sourcepub fn insert(&self, key: K, value: V) -> Self
pub fn insert(&self, key: K, value: V) -> Self
Insert a key-value pair into the map. Must be O(log(|self|)).
Sourcepub fn into_inner_for_drop(self) -> impl Iterator<Item = V>
pub fn into_inner_for_drop(self) -> impl Iterator<Item = V>
Consume internal pointers, returning only the leaves left dangling by this.
Used for custom Drop implementations.
Sourcepub fn iter(
&self,
) -> impl Iterator<Item = (K, Sp<V, D>)> + use<'_, K, V, D, A> + '_
pub fn iter( &self, ) -> impl Iterator<Item = (K, Sp<V, D>)> + use<'_, K, V, D, A> + '_
Iterate over the key-value pairs in the map in a deterministic, but unspecified order.
Sourcepub fn keys(&self) -> impl Iterator<Item = K> + use<'_, K, V, D, A> + '_
pub fn keys(&self) -> impl Iterator<Item = K> + use<'_, K, V, D, A> + '_
Iterator over the keys in the map in a deterministic, but unspecified order.
Sourcepub fn contains_key<Q>(&self, key: &Q) -> bool
pub fn contains_key<Q>(&self, key: &Q) -> bool
Check if the map contains a key. Must be O(log(|self|)).
Sourcepub fn get<Q>(&self, key: &Q) -> Option<&V>where
K: Borrow<Q>,
Q: Serializable,
pub fn get<Q>(&self, key: &Q) -> Option<&V>where
K: Borrow<Q>,
Q: Serializable,
Retrieve the value stored at a key, if applicable. Must be O(log(|self|)).
Trait Implementations§
Source§impl<K: Deserializable + Debug, V: Storable<D> + Debug, D: DB, A: Storable<D> + Annotation<V>> Debug for Map<K, V, D, A>
impl<K: Deserializable + Debug, V: Storable<D> + Debug, D: DB, A: Storable<D> + Annotation<V>> Debug for Map<K, V, D, A>
Source§impl<K: Serializable + Deserializable, V: Storable<D>, D: DB, A: Storable<D> + Annotation<V>> Default for Map<K, V, D, A>
impl<K: Serializable + Deserializable, V: Storable<D>, D: DB, A: Storable<D> + Annotation<V>> Default for Map<K, V, D, A>
Source§impl<K: Sync + Send + 'static + Deserializable, V: Storable<D>, D: DB, A: Storable<D> + Annotation<V>> Deserializable for Map<K, V, D, A>
impl<K: Sync + Send + 'static + Deserializable, V: Storable<D>, D: DB, A: Storable<D> + Annotation<V>> Deserializable for Map<K, V, D, A>
Source§impl<'de, K: Deserialize<'de> + Serializable + Deserializable, V: Deserialize<'de> + Storable<D1>, D1: DB, A: Storable<D1> + Annotation<V>> Deserialize<'de> for Map<K, V, D1, A>
impl<'de, K: Deserialize<'de> + Serializable + Deserializable, V: Deserialize<'de> + Storable<D1>, D1: DB, A: Storable<D1> + Annotation<V>> Deserialize<'de> for Map<K, V, D1, A>
Source§fn deserialize<D: Deserializer<'de>>(de: D) -> Result<Self, D::Error>
fn deserialize<D: Deserializer<'de>>(de: D) -> Result<Self, D::Error>
Deserialize this value from the given Serde deserializer. Read more
Source§impl<K: Serializable + Deserializable, V: Storable<D>, D: DB, A: Storable<D> + Annotation<V>> Distribution<Map<K, V, D, A>> for Standard
impl<K: Serializable + Deserializable, V: Storable<D>, D: DB, A: Storable<D> + Annotation<V>> Distribution<Map<K, V, D, A>> for Standard
Source§fn sample<R: Rng + ?Sized>(&self, rng: &mut R) -> Map<K, V, D, A>
fn sample<R: Rng + ?Sized>(&self, rng: &mut R) -> Map<K, V, D, A>
Generate a random value of
T, using rng as the source of randomness.Source§fn sample_iter<R>(self, rng: R) -> DistIter<Self, R, T>
fn sample_iter<R>(self, rng: R) -> DistIter<Self, R, T>
Create an iterator that generates random values of
T, using rng as
the source of randomness. Read moreSource§impl<K: Serializable + Deserializable + Storable<D>, V: Storable<D>, D: DB, A: Storable<D> + Annotation<(Sp<K, D>, Sp<V, D>)> + Annotation<V>> From<Map<K, V, D, A>> for HashMap<K, V, D, A>
impl<K: Serializable + Deserializable + Storable<D>, V: Storable<D>, D: DB, A: Storable<D> + Annotation<(Sp<K, D>, Sp<V, D>)> + Annotation<V>> From<Map<K, V, D, A>> for HashMap<K, V, D, A>
Source§impl<K, V, D, A> FromIterator<(K, V)> for Map<K, V, D, A>
impl<K, V, D, A> FromIterator<(K, V)> for Map<K, V, D, A>
Source§impl<K: Clone + Serializable + Deserializable, V: Clone + Storable<D>, D: DB, A: Storable<D> + Annotation<V>> IntoIterator for Map<K, V, D, A>
impl<K: Clone + Serializable + Deserializable, V: Clone + Storable<D>, D: DB, A: Storable<D> + Annotation<V>> IntoIterator for Map<K, V, D, A>
Source§impl<K, V, D: DB, A> Ord for Map<K, V, D, A>
impl<K, V, D: DB, A> Ord for Map<K, V, D, A>
Source§impl<K, V, D: DB, A> PartialOrd for Map<K, V, D, A>
impl<K, V, D: DB, A> PartialOrd for Map<K, V, D, A>
Source§impl<K: Sync + Send + 'static + Deserializable, V: Storable<D>, D: DB, A: Storable<D> + Annotation<V>> Serializable for Map<K, V, D, A>
impl<K: Sync + Send + 'static + Deserializable, V: Storable<D>, D: DB, A: Storable<D> + Annotation<V>> Serializable for Map<K, V, D, A>
Source§impl<K: Serialize + Serializable + Deserializable, V: Storable<D> + Serialize, D: DB, A: Storable<D> + Annotation<V>> Serialize for Map<K, V, D, A>
impl<K: Serialize + Serializable + Deserializable, V: Storable<D> + Serialize, D: DB, A: Storable<D> + Annotation<V>> Serialize for Map<K, V, D, A>
Source§impl<K: Sync + Send + 'static + Deserializable, V: Storable<D>, D: DB, A: Storable<D> + Annotation<V>> Storable<D> for Map<K, V, D, A>
impl<K: Sync + Send + 'static + Deserializable, V: Storable<D>, D: DB, A: Storable<D> + Annotation<V>> Storable<D> for Map<K, V, D, A>
Source§fn children(&self) -> Vec<ArenaKey<D::Hasher>>
fn children(&self) -> Vec<ArenaKey<D::Hasher>>
Rather than in-lining the wrapped MPT it is a child such that we know the public Map has only a single child element (rather than up to 16)
Source§fn to_binary_repr<W: Write>(&self, _writer: &mut W) -> Result<(), Error>where
Self: Sized,
fn to_binary_repr<W: Write>(&self, _writer: &mut W) -> Result<(), Error>where
Self: Sized,
Serializes self, omitting any children.
Source§fn from_binary_repr<R: Read>(
_reader: &mut R,
child_hashes: &mut impl Iterator<Item = ArenaKey<D::Hasher>>,
loader: &impl Loader<D>,
) -> Result<Self, Error>where
Self: Sized,
fn from_binary_repr<R: Read>(
_reader: &mut R,
child_hashes: &mut impl Iterator<Item = ArenaKey<D::Hasher>>,
loader: &impl Loader<D>,
) -> Result<Self, Error>where
Self: Sized,
Instantiates self, given hashes of any children, and loader that loads
children given their hash.
Source§impl<K: Tagged, V: Storable<D> + Tagged, D: DB, A: Storable<D> + Annotation<V> + Tagged> Tagged for Map<K, V, D, A>
impl<K: Tagged, V: Storable<D> + Tagged, D: DB, A: Storable<D> + Annotation<V> + Tagged> Tagged for Map<K, V, D, A>
Source§fn tag() -> Cow<'static, str>
fn tag() -> Cow<'static, str>
Retrieves the tag of
Self. Returns a [Cow] as type arguments require allocation, but no
allocation is preferred.Source§fn tag_unique_factor() -> String
fn tag_unique_factor() -> String
A decomposition of this tag into primitive types (any type whose representation is not
defined through other types), tuples (via
(a,b)), and sum types (via [a,b]). Read moreimpl<K, V, D: DB, A> Eq for Map<K, V, D, A>
Auto Trait Implementations§
impl<K, V, D = InMemoryDB, A = SizeAnn> !Freeze for Map<K, V, D, A>
impl<K, V, D = InMemoryDB, A = SizeAnn> !RefUnwindSafe for Map<K, V, D, A>
impl<K, V, D, A> Send for Map<K, V, D, A>where
K: Send,
impl<K, V, D, A> Sync for Map<K, V, D, A>where
K: Sync,
impl<K, V, D, A> Unpin for Map<K, V, D, A>where
K: Unpin,
<<<D as DB>::Hasher as OutputSizeUser>::OutputSize as ArrayLength<u8>>::ArrayType: Unpin,
impl<K, V, D, A> UnsafeUnpin for Map<K, V, D, A>where
<<<D as DB>::Hasher as OutputSizeUser>::OutputSize as ArrayLength<u8>>::ArrayType: UnsafeUnpin,
impl<K, V, D = InMemoryDB, A = SizeAnn> !UnwindSafe for Map<K, V, D, A>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Comparable<K> for Q
impl<Q, K> Comparable<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
Causes
self to use its Binary implementation when Debug-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
Causes
self to use its Display implementation when
Debug-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
Causes
self to use its LowerExp implementation when
Debug-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
Causes
self to use its LowerHex implementation when
Debug-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
Causes
self to use its Octal implementation when Debug-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
Causes
self to use its Pointer implementation when
Debug-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
Causes
self to use its UpperExp implementation when
Debug-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
Causes
self to use its UpperHex implementation when
Debug-formatted.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Pipes by value. This is generally the method you want to use. Read more
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
Borrows
self and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
Mutably borrows
self and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
Borrows
self, then passes self.as_ref() into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
Mutably borrows
self, then passes self.as_mut() into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
Borrows
self, then passes self.deref() into the pipe function.Source§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Immutable access to the
Borrow<B> of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
Mutable access to the
BorrowMut<B> of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
Immutable access to the
AsRef<R> view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
Mutable access to the
AsMut<R> view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Immutable access to the
Deref::Target of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Mutable access to the
Deref::Target of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
Calls
.tap() only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
Calls
.tap_mut() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
Calls
.tap_borrow() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
Calls
.tap_borrow_mut() only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
Calls
.tap_ref() only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
Calls
.tap_ref_mut() only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
Calls
.tap_deref() only in debug builds, and is erased in release
builds.