connectorx::destinations

Trait DestinationPartition

Source
pub trait DestinationPartition<'a>: Send {
    type TypeSystem: TypeSystem;
    type Error: From<ConnectorXError> + Send;

    // Required methods
    fn ncols(&self) -> usize;
    fn finalize(&mut self) -> Result<(), Self::Error>;
    fn aquire_row(&mut self, n: usize) -> Result<usize, Self::Error>;

    // Provided method
    fn write<T>(
        &mut self,
        value: T,
    ) -> Result<(), <Self as DestinationPartition<'a>>::Error>
       where T: TypeAssoc<Self::TypeSystem>,
             Self: Consume<T, Error = <Self as DestinationPartition<'a>>::Error> { ... }
}
Expand description

PartitionDestination writes values to its own region. PartitionDestination is parameterized on lifetime 'a, which is the lifetime of the parent Destination. Usually, a PartitionDestination can never live longer than the parent.

Required Associated Types§

Required Methods§

Source

fn ncols(&self) -> usize

Number of rows this PartitionDestination controls.

Source

fn finalize(&mut self) -> Result<(), Self::Error>

Final clean ups

Source

fn aquire_row(&mut self, n: usize) -> Result<usize, Self::Error>

Aquire n rows in final destination

Provided Methods§

Source

fn write<T>( &mut self, value: T, ) -> Result<(), <Self as DestinationPartition<'a>>::Error>
where T: TypeAssoc<Self::TypeSystem>, Self: Consume<T, Error = <Self as DestinationPartition<'a>>::Error>,

Write a value of type T to the location (row, col). If T mismatch with the schema, ConnectorXError::TypeCheckFailed will return.

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§