[][src]Struct memory_db::MemoryDB

pub struct MemoryDB<H: KeyHasher, T> { /* fields omitted */ }

Reference-counted memory-based HashDB implementation.

Use new() to create a new database. Insert items with insert(), remove items with remove(), check for existence with contains() and lookup a hash to derive the data with get(). Clear with clear() and purge the portions of the data that have no references with purge().

Example

extern crate hash_db;
extern crate keccak_hasher;
extern crate memory_db;

use hash_db::*;
use keccak_hasher::KeccakHasher;
use memory_db::*;
fn main() {
  let mut m = MemoryDB::<KeccakHasher, Vec<u8>>::default();
  let d = "Hello world!".as_bytes();

  let k = m.insert(d);
  assert!(m.contains(&k));
  assert_eq!(m.get(&k).unwrap(), d);

  m.insert(d);
  assert!(m.contains(&k));

  m.remove(&k);
  assert!(m.contains(&k));

  m.remove(&k);
  assert!(!m.contains(&k));

  m.remove(&k);
  assert!(!m.contains(&k));

  m.insert(d);
  assert!(!m.contains(&k));
  m.insert(d);
  assert!(m.contains(&k));
  assert_eq!(m.get(&k).unwrap(), d);

  m.remove(&k);
  assert!(!m.contains(&k));
}

Methods

impl<H, T> MemoryDB<H, T> where
    H: KeyHasher,
    T: Default
[src]

pub fn remove_and_purge(&mut self, key: &<H as KeyHasher>::Out) -> Option<T>
[src]

Remove an element and delete it from storage if reference count reaches zero. If the value was purged, return the old value.

impl<'a, H: KeyHasher, T> MemoryDB<H, T> where
    T: From<&'a [u8]>, 
[src]

pub fn from_null_node(null_key: &'a [u8], null_node_data: T) -> Self
[src]

Create a new MemoryDB from a given null key/data

pub fn new(data: &'a [u8]) -> Self
[src]

Create a new MemoryDB from a given null key/data

pub fn clear(&mut self)
[src]

Clear all data from the database.

Examples

extern crate hash_db;
extern crate keccak_hasher;
extern crate memory_db;

use hash_db::*;
use keccak_hasher::KeccakHasher;
use memory_db::*;

fn main() {
  let mut m = MemoryDB::<KeccakHasher, Vec<u8>>::default();
  let hello_bytes = "Hello world!".as_bytes();
  let hash = m.insert(hello_bytes);
  assert!(m.contains(&hash));
  m.clear();
  assert!(!m.contains(&hash));
}

pub fn purge(&mut self)
[src]

Purge all zero-referenced data from the database.

pub fn drain(
    &mut self
) -> HashMap<<H as KeyHasher>::Out, (T, i32), BuildHasherDefault<<H as KeyHasher>::StdHasher>>
[src]

Return the internal map of hashes to data, clearing the current state.

pub fn raw(&self, key: &<H as KeyHasher>::Out) -> Option<(&T, i32)>
[src]

Grab the raw information associated with a key. Returns None if the key doesn't exist.

Even when Some is returned, the data is only guaranteed to be useful when the refs > 0.

pub fn consolidate(&mut self, other: Self)
[src]

Consolidate all the entries of other into self.

impl<H, T> MemoryDB<H, T> where
    H: KeyHasher,
    T: HeapSizeOf
[src]

pub fn mem_used(&self) -> usize
[src]

Returns the size of allocated heap memory

Trait Implementations

impl<'a, H, T> Default for MemoryDB<H, T> where
    H: KeyHasher,
    T: From<&'a [u8]>, 
[src]

impl<H: PartialEq + KeyHasher, T: PartialEq> PartialEq<MemoryDB<H, T>> for MemoryDB<H, T> where
    H::Out: PartialEq
[src]

impl<H: Clone + KeyHasher, T: Clone> Clone for MemoryDB<H, T> where
    H::Out: Clone
[src]

fn clone_from(&mut self, source: &Self)
1.0.0
[src]

Performs copy-assignment from source. Read more

impl<H, T> HashDB<H, T> for MemoryDB<H, T> where
    H: KeyHasher,
    T: Default + PartialEq<T> + for<'a> From<&'a [u8]> + Clone + Send + Sync
[src]

impl<H, T> AsHashDB<H, T> for MemoryDB<H, T> where
    H: KeyHasher,
    T: Default + PartialEq<T> + for<'a> From<&'a [u8]> + Clone + Send + Sync
[src]

Auto Trait Implementations

impl<H, T> Send for MemoryDB<H, T> where
    T: Send,
    <H as Hasher>::Out: Send,
    <H as Hasher>::StdHasher: Send

impl<H, T> Sync for MemoryDB<H, T> where
    T: Sync,
    <H as Hasher>::Out: Sync,
    <H as Hasher>::StdHasher: Sync

Blanket Implementations

impl<T> From for T
[src]

impl<T, U> Into for T where
    U: From<T>, 
[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

impl<T, U> TryFrom for T where
    T: From<U>, 
[src]

type Error = !

🔬 This is a nightly-only experimental API. (try_from)

The type returned in the event of a conversion error.

impl<T> Borrow for T where
    T: ?Sized
[src]

impl<T> BorrowMut for T where
    T: ?Sized
[src]

impl<T, U> TryInto for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

🔬 This is a nightly-only experimental API. (try_from)

The type returned in the event of a conversion error.

impl<T> Any for T where
    T: 'static + ?Sized
[src]