#![cfg_attr(not(debug_assertions), deny(clippy::disallowed_methods))]
#![cfg_attr(debug_assertions, warn(clippy::disallowed_methods))]
#![cfg_attr(not(debug_assertions), deny(warnings))]
#![allow(clippy::tabs_in_doc_comments)]
use reifydb_core::{
event::EventBus,
interface::version::{ComponentType, HasVersion, SystemVersion},
};
use reifydb_type::Result;
pub mod cold;
pub mod hot;
pub mod tier;
pub mod ttl;
pub mod warm;
pub mod config;
pub mod multi;
pub mod store;
use config::{HotConfig, MultiStoreConfig};
use reifydb_core::{
common::CommitVersion,
delta::Delta,
encoded::key::{EncodedKey, EncodedKeyRange},
interface::store::{
MultiVersionCommit, MultiVersionContains, MultiVersionGet, MultiVersionGetPrevious, MultiVersionRow,
MultiVersionStore,
},
};
use reifydb_type::util::cowvec::CowVec;
use store::StandardMultiStore;
pub mod memory {}
pub mod sqlite {}
pub struct MultiStoreVersion;
impl HasVersion for MultiStoreVersion {
fn version(&self) -> SystemVersion {
SystemVersion {
name: env!("CARGO_PKG_NAME")
.strip_prefix("reifydb-")
.unwrap_or(env!("CARGO_PKG_NAME"))
.to_string(),
version: env!("CARGO_PKG_VERSION").to_string(),
description: "Multi-version storage for OLTP operations with MVCC support".to_string(),
r#type: ComponentType::Module,
}
}
}
#[repr(u8)]
#[derive(Clone)]
pub enum MultiStore {
Standard(StandardMultiStore) = 0,
}
impl MultiStore {
pub fn standard(config: MultiStoreConfig) -> Self {
Self::Standard(StandardMultiStore::new(config).unwrap())
}
}
impl MultiStore {
pub fn testing_memory() -> Self {
MultiStore::Standard(StandardMultiStore::testing_memory())
}
pub fn testing_memory_with_eventbus(event_bus: EventBus) -> Self {
MultiStore::Standard(StandardMultiStore::testing_memory_with_eventbus(event_bus))
}
pub fn hot(&self) -> Option<&hot::storage::HotStorage> {
match self {
MultiStore::Standard(store) => store.hot(),
}
}
}
impl MultiVersionGet for MultiStore {
#[inline]
fn get(&self, key: &EncodedKey, version: CommitVersion) -> Result<Option<MultiVersionRow>> {
match self {
MultiStore::Standard(store) => MultiVersionGet::get(store, key, version),
}
}
}
impl MultiVersionContains for MultiStore {
#[inline]
fn contains(&self, key: &EncodedKey, version: CommitVersion) -> Result<bool> {
match self {
MultiStore::Standard(store) => MultiVersionContains::contains(store, key, version),
}
}
}
impl MultiVersionCommit for MultiStore {
#[inline]
fn commit(&self, deltas: CowVec<Delta>, version: CommitVersion) -> Result<()> {
match self {
MultiStore::Standard(store) => store.commit(deltas, version),
}
}
}
impl MultiVersionGetPrevious for MultiStore {
#[inline]
fn get_previous_version(
&self,
key: &EncodedKey,
before_version: CommitVersion,
) -> Result<Option<MultiVersionRow>> {
match self {
MultiStore::Standard(store) => store.get_previous_version(key, before_version),
}
}
}
pub type MultiVersionRangeIterator<'a> = Box<dyn Iterator<Item = Result<MultiVersionRow>> + Send + 'a>;
impl MultiStore {
pub fn range(
&self,
range: EncodedKeyRange,
version: CommitVersion,
batch_size: usize,
) -> MultiVersionRangeIterator<'_> {
match self {
MultiStore::Standard(store) => Box::new(store.range(range, version, batch_size)),
}
}
pub fn range_rev(
&self,
range: EncodedKeyRange,
version: CommitVersion,
batch_size: usize,
) -> MultiVersionRangeIterator<'_> {
match self {
MultiStore::Standard(store) => Box::new(store.range_rev(range, version, batch_size)),
}
}
}
impl MultiVersionStore for MultiStore {}