Struct Db

Source
pub struct Db<C: Computation> { /* private fields */ }

Implementations§

Source§

impl<C: Computation> Db<C>
where C::Storage: Default,

Source

pub fn new() -> Self

Source§

impl<C: Computation> Db<C>

Source

pub fn is_stale<Concrete: Computation>(&self, input: &Concrete) -> bool

True if a given input is stale and needs to be re-computed. Inputs which have never been computed are also considered stale.

This does not actually re-compute the input.

Source

pub fn is_stale_cell(&self, cell: Cell) -> bool

True if a given cell is stale and needs to be re-computed. This does not actually re-compute the input.

Source

pub fn get_cell<ConcreteC: Computation>( &self, input: &ConcreteC, ) -> Option<Cell>

Return the corresponding Cell for a given input, if it exists.

This will not update any values.

Source

pub fn get_or_insert_cell<ConcreteC>(&mut self, input: ConcreteC) -> Cell
where ConcreteC: Computation,

Source

pub fn update_input<ConcreteC>( &mut self, input: ConcreteC, new_value: ConcreteC::Output, )
where ConcreteC: Debug + Computation, C::Output: Eq,

Updates an input with a new value

May panic in Debug mode if the input is not an input - ie. it has at least 1 dependency. Note that this step is skipped when compiling in Release mode.

Source

pub fn storage(&self) -> &C::Storage

Source

pub fn storage_mut(&mut self) -> &mut C::Storage

Source§

impl<C: Computation + Clone> Db<C>
where C::Output: Eq,

Source

pub fn get<Concrete: Computation>( &mut self, compute: Concrete, ) -> &Concrete::Output

Retrieves the up to date value for the given computation, re-running any dependencies as necessary.

This function can panic if the dynamic type of the value returned by compute.run(..) is not T.

Source

pub fn get_with_cell<Concrete: Computation>( &mut self, cell_id: Cell, ) -> &Concrete::Output

Retrieves the up to date value for the given cell, re-running any dependencies as necessary.

This function can panic if the dynamic type of the value returned by compute.run(..) is not T.

Auto Trait Implementations§

§

impl<C> Freeze for Db<C>
where <C as Computation>::Storage: Freeze,

§

impl<C> RefUnwindSafe for Db<C>

§

impl<C> Send for Db<C>
where <C as Computation>::Storage: Send,

§

impl<C> Sync for Db<C>
where <C as Computation>::Storage: Sync,

§

impl<C> Unpin for Db<C>
where <C as Computation>::Storage: Unpin,

§

impl<C> UnwindSafe for Db<C>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

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

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.