cuprate_database

Trait DatabaseRw

Source
pub trait DatabaseRw<T: Table>: DatabaseRo<T> {
    // Required methods
    fn put(&mut self, key: &T::Key, value: &T::Value) -> DbResult<()>;
    fn delete(&mut self, key: &T::Key) -> DbResult<()>;
    fn take(&mut self, key: &T::Key) -> DbResult<T::Value>;
    fn pop_first(&mut self) -> DbResult<(T::Key, T::Value)>;
    fn pop_last(&mut self) -> DbResult<(T::Key, T::Value)>;

    // Provided method
    fn update<F>(&mut self, key: &T::Key, f: F) -> DbResult<()>
       where F: FnMut(T::Value) -> Option<T::Value> { ... }
}
Expand description

Database (key-value store) read/write abstraction.

All DatabaseRo functions are also callable by DatabaseRw.

Required Methods§

Source

fn put(&mut self, key: &T::Key, value: &T::Value) -> DbResult<()>

Insert a key-value pair into the database.

This will overwrite any existing key-value pairs.

§Errors

This will return crate::RuntimeError::KeyNotFound if:

  • Input does not exist OR
  • Database is empty

This will never RuntimeError::KeyExists.

Source

fn delete(&mut self, key: &T::Key) -> DbResult<()>

Delete a key-value pair in the database.

This will return Ok(()) if the key does not exist.

§Errors

This will return crate::RuntimeError::KeyNotFound if:

  • Input does not exist OR
  • Database is empty

This will never RuntimeError::KeyExists.

Source

fn take(&mut self, key: &T::Key) -> DbResult<T::Value>

Delete and return a key-value pair in the database.

This is the same as DatabaseRw::delete, however, it will serialize the T::Value and return it.

§Errors

This will return crate::RuntimeError::KeyNotFound if:

  • Input does not exist OR
  • Database is empty
Source

fn pop_first(&mut self) -> DbResult<(T::Key, T::Value)>

Removes and returns the first (key, value) pair in the database.

§Errors

This will return crate::RuntimeError::KeyNotFound if:

  • Input does not exist OR
  • Database is empty
Source

fn pop_last(&mut self) -> DbResult<(T::Key, T::Value)>

Removes and returns the last (key, value) pair in the database.

§Errors

This will return crate::RuntimeError::KeyNotFound if:

  • Input does not exist OR
  • Database is empty

Provided Methods§

Source

fn update<F>(&mut self, key: &T::Key, f: F) -> DbResult<()>
where F: FnMut(T::Value) -> Option<T::Value>,

Fetch the value, and apply a function to it - or delete the entry.

This will call DatabaseRo::get and call your provided function f on it.

The Option f returns will dictate whether update():

  • Updates the current value OR

  • Deletes the (key, value) pair

  • If f returns Some(value), that will be DatabaseRw::put as the new value

  • If f returns None, the entry will be DatabaseRw::deleted

§Errors

This will return crate::RuntimeError::KeyNotFound if:

  • Input does not exist OR
  • Database is empty

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§