pub enum SparseBase<Txn, FE> {
    Bool(SparseBase<Txn, FE, u8>),
    C32((SparseBase<Txn, FE, f32>, SparseBase<Txn, FE, f32>)),
    C64((SparseBase<Txn, FE, f64>, SparseBase<Txn, FE, f64>)),
    F32(SparseBase<Txn, FE, f32>),
    F64(SparseBase<Txn, FE, f64>),
    I16(SparseBase<Txn, FE, i16>),
    I32(SparseBase<Txn, FE, i32>),
    I64(SparseBase<Txn, FE, i64>),
    U8(SparseBase<Txn, FE, u8>),
    U16(SparseBase<Txn, FE, u16>),
    U32(SparseBase<Txn, FE, u32>),
    U64(SparseBase<Txn, FE, u64>),
}

Variants§

§

Bool(SparseBase<Txn, FE, u8>)

§

C32((SparseBase<Txn, FE, f32>, SparseBase<Txn, FE, f32>))

§

C64((SparseBase<Txn, FE, f64>, SparseBase<Txn, FE, f64>))

§

F32(SparseBase<Txn, FE, f32>)

§

F64(SparseBase<Txn, FE, f64>)

§

I16(SparseBase<Txn, FE, i16>)

§

I32(SparseBase<Txn, FE, i32>)

§

I64(SparseBase<Txn, FE, i64>)

§

U8(SparseBase<Txn, FE, u8>)

§

U16(SparseBase<Txn, FE, u16>)

§

U32(SparseBase<Txn, FE, u32>)

§

U64(SparseBase<Txn, FE, u64>)

Trait Implementations§

source§

impl<Txn, FE> Clone for SparseBase<Txn, FE>

source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<Txn, FE> CopyFrom<FE, SparseView<Txn, FE>> for SparseBase<Txn, FE>
where Txn: Transaction<FE>, FE: DenseCacheFile + AsType<Node> + Clone,

source§

fn copy_from<'life0, 'async_trait>( txn: &'life0 Txn, store: Dir<FE>, instance: SparseView<Txn, FE> ) -> Pin<Box<dyn Future<Output = TCResult<Self>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Copy a new instance of Self from an existing instance.
source§

impl<Txn: ThreadSafe, FE: ThreadSafe> Debug for SparseBase<Txn, FE>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<Txn, FE> From<SparseBase<Txn, FE>> for SparseView<Txn, FE>

source§

fn from(base: SparseBase<Txn, FE>) -> Self

Converts to this type from the input type.
source§

impl<Txn, FE> FromStream for SparseBase<Txn, FE>
where Txn: Transaction<FE>, FE: AsType<Node> + ThreadSafe + Clone,

§

type Context = Txn

The decoding context of this type, useful in situations where the stream to be decoded may be too large to hold in main memory. Read more
source§

fn from_stream<'life0, 'async_trait, D>( txn: Txn, decoder: &'life0 mut D ) -> Pin<Box<dyn Future<Output = Result<Self, D::Error>> + Send + 'async_trait>>
where D: 'async_trait + Decoder, Self: 'async_trait, 'life0: 'async_trait,

Parse this value using the given Decoder.
source§

impl<Txn: ThreadSafe, FE: ThreadSafe> Instance for SparseBase<Txn, FE>

§

type Class = TensorType

The Class type of this instance
source§

fn class(&self) -> Self::Class

Returns the [Class] of this instance.
source§

impl<Txn, FE> Persist<FE> for SparseBase<Txn, FE>
where Txn: Transaction<FE>, FE: AsType<Node> + ThreadSafe + Clone,

§

type Txn = Txn

§

type Schema = Schema

source§

fn create<'async_trait>( txn_id: TxnId, schema: Self::Schema, store: Dir<FE> ) -> Pin<Box<dyn Future<Output = TCResult<Self>> + Send + 'async_trait>>
where Self: 'async_trait,

Create a new instance of Self from an empty Store.
source§

fn load<'async_trait>( txn_id: TxnId, schema: Self::Schema, store: Dir<FE> ) -> Pin<Box<dyn Future<Output = TCResult<Self>> + Send + 'async_trait>>
where Self: 'async_trait,

Load a saved instance of Self from persistent storage. Should only be invoked at startup time.
source§

fn dir(&self) -> Inner<FE>

Access the filesystem directory backing this persistent data structure.
source§

fn load_or_create<'async_trait>( txn_id: TxnId, schema: Self::Schema, store: Dir<FE> ) -> Pin<Box<dyn Future<Output = Result<Self, TCError>> + Send + 'async_trait>>
where Self: Send + 'async_trait,

Load a saved instance of Self from persistent storage if present, or create a new one.
source§

impl<Txn, FE> Restore<FE> for SparseBase<Txn, FE>
where Txn: Transaction<FE>, FE: DenseCacheFile + AsType<Node> + Clone,

source§

fn restore<'life0, 'life1, 'async_trait>( &'life0 self, txn_id: TxnId, backup: &'life1 Self ) -> Pin<Box<dyn Future<Output = TCResult<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Restore this persistent state from a backup.
source§

impl<State> Route<State> for SparseBase<State::Txn, State::FE>
where State: StateInstance + From<Tensor<State::Txn, State::FE>> + From<Tuple<Value>>, State::Class: From<NumberType>, State::FE: DenseCacheFile + AsType<Node>, Number: TryCastFrom<State>, Tensor<State::Txn, State::FE>: TryCastFrom<State>, Value: TryCastFrom<State>, bool: TryCastFrom<State>,

source§

fn route<'a>( &'a self, path: &'a [PathSegment] ) -> Option<Box<dyn Handler<'a, State> + 'a>>

source§

impl<Txn, FE> TensorInstance for SparseBase<Txn, FE>
where Txn: ThreadSafe, FE: ThreadSafe,

source§

fn dtype(&self) -> NumberType

source§

fn shape(&self) -> &Shape

source§

fn ndim(&self) -> usize

source§

fn size(&self) -> u64

source§

fn schema(&self) -> Schema

source§

impl<Txn, FE> TensorRead for SparseBase<Txn, FE>
where Txn: Transaction<FE>, FE: DenseCacheFile + AsType<Node>,

source§

fn read_value<'async_trait>( self, txn_id: TxnId, coord: Coord ) -> Pin<Box<dyn Future<Output = TCResult<Number>> + Send + 'async_trait>>
where Self: 'async_trait,

Read a single value from this Tensor.
source§

impl<Txn, FE> TensorWrite for SparseBase<Txn, FE>
where Txn: Transaction<FE>, FE: DenseCacheFile + AsType<Node>,

source§

fn write_value<'life0, 'async_trait>( &'life0 self, txn_id: TxnId, range: Range, value: Number ) -> Pin<Box<dyn Future<Output = TCResult<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Write a single value to the slice of this Tensor with the given Range.
source§

fn write_value_at<'life0, 'async_trait>( &'life0 self, txn_id: TxnId, coord: Coord, value: Number ) -> Pin<Box<dyn Future<Output = TCResult<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Overwrite a single element of this Tensor.
source§

impl<Txn, FE> TensorWriteDual<SparseView<Txn, FE>> for SparseBase<Txn, FE>
where Txn: Transaction<FE>, FE: DenseCacheFile + AsType<Node> + ThreadSafe,

source§

fn write<'async_trait>( self, txn_id: TxnId, range: Range, value: SparseView<Txn, FE> ) -> Pin<Box<dyn Future<Output = TCResult<()>> + Send + 'async_trait>>
where Self: 'async_trait,

Overwrite the slice of this Tensor given by Range with the given value.
source§

impl<Txn, FE> Transact for SparseBase<Txn, FE>
where Txn: Transaction<FE>, FE: AsType<Node> + ThreadSafe + for<'a> FileSave<'a> + Clone,

§

type Commit = ()

A guard which blocks concurrent commits
source§

fn commit<'life0, 'async_trait>( &'life0 self, txn_id: TxnId ) -> Pin<Box<dyn Future<Output = Self::Commit> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Commit this transaction.
source§

fn rollback<'life0, 'life1, 'async_trait>( &'life0 self, txn_id: &'life1 TxnId ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Roll back this transaction.
source§

fn finalize<'life0, 'life1, 'async_trait>( &'life0 self, txn_id: &'life1 TxnId ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Delete any version data specific to this transaction.

Auto Trait Implementations§

§

impl<Txn, FE> !RefUnwindSafe for SparseBase<Txn, FE>

§

impl<Txn, FE> Send for SparseBase<Txn, FE>
where FE: Sync + Send, Txn: Sync + Send,

§

impl<Txn, FE> Sync for SparseBase<Txn, FE>
where FE: Sync + Send, Txn: Sync + Send,

§

impl<Txn, FE> Unpin for SparseBase<Txn, FE>

§

impl<Txn, FE> !UnwindSafe for SparseBase<Txn, FE>

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<F, T> CastFrom<F> for T
where T: From<F>,

source§

fn cast_from(f: F) -> T

Cast an instance of T into an instance of Self.
source§

impl<T, F> CastInto<F> for T
where F: CastFrom<T>,

source§

fn cast_into(self) -> F

Cast an instance of Self into an instance of T.
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<F> Match for F

source§

fn matches<T>(&self) -> bool
where T: TryCastFrom<Self>,

Returns true if self can be cast into the target type T.
§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<State, T> Public<State> for T
where State: StateInstance, T: Route<State> + Debug,

source§

fn get<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, txn: &'life1 <State as StateInstance>::Txn, path: &'life2 [Id], key: Value ) -> Pin<Box<dyn Future<Output = Result<State, TCError>> + Send + 'async_trait>>
where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, T: 'async_trait,

source§

fn put<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, txn: &'life1 <State as StateInstance>::Txn, path: &'life2 [Id], key: Value, value: State ) -> Pin<Box<dyn Future<Output = Result<(), TCError>> + Send + 'async_trait>>
where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, T: 'async_trait,

source§

fn post<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, txn: &'life1 <State as StateInstance>::Txn, path: &'life2 [Id], params: Map<State> ) -> Pin<Box<dyn Future<Output = Result<State, TCError>> + Send + 'async_trait>>
where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, T: 'async_trait,

source§

fn delete<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, txn: &'life1 <State as StateInstance>::Txn, path: &'life2 [Id], key: Value ) -> Pin<Box<dyn Future<Output = Result<(), TCError>> + Send + 'async_trait>>
where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, T: 'async_trait,

source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<State, T> ToState<State> for T
where State: StateInstance, T: Clone + Into<State>,

source§

fn to_state(&self) -> State

source§

impl<F, T> TryCastFrom<F> for T
where T: CastFrom<F>,

source§

fn can_cast_from(_: &F) -> bool

Test if value can be cast into Self.
source§

fn opt_cast_from(f: F) -> Option<T>

Returns Some(Self) if the source value can be cast into Self, otherwise None.
source§

fn try_cast_from<Err, OnErr>(value: T, on_err: OnErr) -> Result<Self, Err>
where OnErr: FnOnce(&T) -> Err,

Returns Ok(Self) if the source value can be cast into Self, otherwise calls on_err.
source§

impl<F, T> TryCastInto<T> for F
where T: TryCastFrom<F>,

source§

fn can_cast_into(&self) -> bool

Test if self can be cast into T.
source§

fn opt_cast_into(self) -> Option<T>

Returns Some(T) if self can be cast into T, otherwise None.
source§

fn try_cast_into<Err, OnErr>(self, on_err: OnErr) -> Result<T, Err>
where OnErr: FnOnce(&Self) -> Err,

Returns Ok(T) if self can be cast into T, otherwise calls on_err.
source§

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

§

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>,

§

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.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

source§

impl<T> ThreadSafe for T
where T: Send + Sync + 'static,