pub trait HashDB<H: Hasher, T>: Send + Sync + AsHashDB<H, T> {
fn get(&self, key: &H::Out) -> Option<T>;
fn contains(&self, key: &H::Out) -> bool;
fn insert(&mut self, value: &[u8]) -> H::Out;
fn emplace(&mut self, key: H::Out, value: T);
fn remove(&mut self, key: &H::Out);
}Expand description
Trait modelling datastore keyed by a hash defined by the Hasher.
Required methods
Look up a given hash into the bytes that hash to it, returning None if the hash is not known.
Insert a datum item into the DB and return the datum’s hash for a later lookup. Insertions
are counted and the equivalent number of remove()s must be performed before the data
is considered dead.
Like insert(), except you provide the key and the data is all moved.
Trait Implementations
sourceimpl<'a, H: Hasher, T> AsHashDB<H, T> for &'a mut dyn HashDB<H, T>
impl<'a, H: Hasher, T> AsHashDB<H, T> for &'a mut dyn HashDB<H, T>
sourcefn as_hash_db(&self) -> &dyn HashDB<H, T>
fn as_hash_db(&self) -> &dyn HashDB<H, T>
Perform upcast to HashDB for anything that derives from HashDB.
sourcefn as_hash_db_mut<'b>(&'b mut self) -> &'b mut (dyn HashDB<H, T> + 'b)
fn as_hash_db_mut<'b>(&'b mut self) -> &'b mut (dyn HashDB<H, T> + 'b)
Perform mutable upcast to HashDB for anything that derives from HashDB.