honeycomb_core::attributes

Trait AttributeStorage

Source
pub trait AttributeStorage<A: AttributeBind>: UnknownAttributeStorage {
    // Required methods
    fn read(
        &self,
        trans: &mut Transaction,
        id: A::IdentifierType,
    ) -> StmResult<Option<A>>;
    fn write(
        &self,
        trans: &mut Transaction,
        id: A::IdentifierType,
        val: A,
    ) -> StmResult<Option<A>>;
    fn remove(
        &self,
        trans: &mut Transaction,
        id: A::IdentifierType,
    ) -> StmResult<Option<A>>;
    fn force_write(&self, id: A::IdentifierType, val: A) -> Option<A>;

    // Provided methods
    fn force_read(&self, id: A::IdentifierType) -> Option<A> { ... }
    fn force_remove(&self, id: A::IdentifierType) -> Option<A> { ... }
}
Expand description

§Generic attribute storage trait

This trait defines attribute-specific methods. The documentation describes the expected behavior of each method. “ID” and “index” are used interchangeably.

Aside from the regular (transactional) read / write / remove methods, we provide force variants which wraps regular methods in a transaction that retries until success. The main purpose of these variants is to allow omitting transactions when they’re not needed.

Required Methods§

Source

fn read( &self, trans: &mut Transaction, id: A::IdentifierType, ) -> StmResult<Option<A>>

Read the value of an element at a given index.

§Arguments
  • trans: &mut Transaction – Transaction used for synchronization.
  • index: A::IdentifierType – Cell index.
§Return / Errors

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

§Panics

The method:

  • should panic if the index lands out of bounds
  • may panic if the index cannot be converted to usize
Source

fn write( &self, trans: &mut Transaction, id: A::IdentifierType, val: A, ) -> StmResult<Option<A>>

Write the value of an element at a given index and return the old value.

§Arguments
  • trans: &mut Transaction – Transaction used for synchronization.
  • index: A::IdentifierType – Cell index.
  • val: A – Attribute value.
§Return / Errors

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

§Panics

The method:

  • should panic if the index lands out of bounds
  • may panic if the index cannot be converted to usize
Source

fn remove( &self, trans: &mut Transaction, id: A::IdentifierType, ) -> StmResult<Option<A>>

Remove the value at a given index and return it.

§Arguments
  • trans: &mut Transaction – Transaction used for synchronization.
  • index: A::IdentifierType – Cell index.
§Return / Errors

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

§Panics

The method:

  • should panic if the index lands out of bounds
  • may panic if the index cannot be converted to usize
Source

fn force_write(&self, id: A::IdentifierType, val: A) -> Option<A>

Write the value of an element at a given index and return the old value.

This variant is equivalent to write, but internally uses a transaction that will be retried until validated.

Provided Methods§

Source

fn force_read(&self, id: A::IdentifierType) -> Option<A>

Read the value of an element at a given index.

This variant is equivalent to read, but internally uses a transaction that will be retried until validated.

Source

fn force_remove(&self, id: A::IdentifierType) -> Option<A>

Remove the value at a given index and return it.

This variant is equivalent to remove, but internally uses a transaction that will be retried until validated.

Implementors§