#![warn(clippy::pedantic)]
#![allow(
clippy::cast_possible_wrap, clippy::cast_possible_truncation, clippy::cast_sign_loss,
clippy::module_name_repetitions, clippy::similar_names, clippy::must_use_candidate,
clippy::missing_errors_doc,
clippy::doc_markdown,
clippy::missing_safety_doc,
clippy::needless_pass_by_value,
clippy::ptr_as_ptr,
clippy::missing_panics_doc,
clippy::from_over_into,
)]
#[macro_use]
mod ffi_util;
pub mod backup;
pub mod checkpoint;
mod column_family;
pub mod compaction_filter;
pub mod compaction_filter_factory;
mod comparator;
mod db;
mod db_iterator;
mod db_options;
mod db_pinnable_slice;
mod iter_range;
pub mod merge_operator;
pub mod perf;
pub mod properties;
mod slice_transform;
mod snapshot;
mod sst_file_writer;
mod transactions;
mod write_batch;
pub use crate::{
column_family::{
AsColumnFamilyRef, BoundColumnFamily, ColumnFamily, ColumnFamilyDescriptor,
ColumnFamilyRef, DEFAULT_COLUMN_FAMILY_NAME,
},
compaction_filter::Decision as CompactionDecision,
db::{
DBAccess, DBCommon, DBWithThreadMode, LiveFile, MultiThreaded, SingleThreaded, ThreadMode,
DB,
},
db_iterator::{
DBIterator, DBIteratorWithThreadMode, DBRawIterator, DBRawIteratorWithThreadMode,
DBWALIterator, Direction, IteratorMode,
},
db_options::{
BlockBasedIndexType, BlockBasedOptions, BottommostLevelCompaction, Cache, CompactOptions,
CuckooTableOptions, DBCompactionStyle, DBCompressionType, DBPath, DBRecoveryMode,
DataBlockIndexType, Env, FifoCompactOptions, FlushOptions, IngestExternalFileOptions,
LogLevel, MemtableFactory, Options, PlainTableFactoryOptions, ReadOptions,
UniversalCompactOptions, UniversalCompactionStopStyle, WriteOptions,
},
db_pinnable_slice::DBPinnableSlice,
ffi_util::CStrLike,
iter_range::{IterateBounds, PrefixRange},
merge_operator::MergeOperands,
perf::{PerfContext, PerfMetric, PerfStatsLevel},
slice_transform::SliceTransform,
snapshot::{Snapshot, SnapshotWithThreadMode},
sst_file_writer::SstFileWriter,
transactions::{
OptimisticTransactionDB, OptimisticTransactionOptions, Transaction, TransactionDB,
TransactionDBOptions, TransactionOptions,
},
write_batch::{WriteBatch, WriteBatchIterator, WriteBatchWithTransaction},
};
use librocksdb_sys as ffi;
use std::error;
use std::fmt;
#[derive(Debug, Clone, PartialEq, Eq)]
pub enum ErrorKind {
NotFound,
Corruption,
NotSupported,
InvalidArgument,
IOError,
MergeInProgress,
Incomplete,
ShutdownInProgress,
TimedOut,
Aborted,
Busy,
Expired,
TryAgain,
CompactionTooLarge,
ColumnFamilyDropped,
Unknown,
}
#[derive(Debug, Clone, PartialEq)]
pub struct Error {
message: String,
}
impl Error {
fn new(message: String) -> Error {
Error { message }
}
pub fn into_string(self) -> String {
self.into()
}
pub fn kind(&self) -> ErrorKind {
match self.message.split(':').next().unwrap_or("") {
"NotFound" => ErrorKind::NotFound,
"Corruption" => ErrorKind::Corruption,
"Not implemented" => ErrorKind::NotSupported,
"Invalid argument" => ErrorKind::InvalidArgument,
"IO error" => ErrorKind::IOError,
"Merge in progress" => ErrorKind::MergeInProgress,
"Result incomplete" => ErrorKind::Incomplete,
"Shutdown in progress" => ErrorKind::ShutdownInProgress,
"Operation timed out" => ErrorKind::TimedOut,
"Operation aborted" => ErrorKind::Aborted,
"Resource busy" => ErrorKind::Busy,
"Operation expired" => ErrorKind::Expired,
"Operation failed. Try again." => ErrorKind::TryAgain,
"Compaction too large" => ErrorKind::CompactionTooLarge,
"Column family dropped" => ErrorKind::ColumnFamilyDropped,
_ => ErrorKind::Unknown,
}
}
}
impl AsRef<str> for Error {
fn as_ref(&self) -> &str {
&self.message
}
}
impl From<Error> for String {
fn from(e: Error) -> String {
e.message
}
}
impl error::Error for Error {
fn description(&self) -> &str {
&self.message
}
}
impl fmt::Display for Error {
fn fmt(&self, formatter: &mut fmt::Formatter) -> Result<(), fmt::Error> {
self.message.fmt(formatter)
}
}
#[cfg(test)]
mod test {
use crate::{
OptimisticTransactionDB, OptimisticTransactionOptions, Transaction, TransactionDB,
TransactionDBOptions, TransactionOptions,
};
use super::{
column_family::UnboundColumnFamily,
db_options::{CacheWrapper, EnvWrapper},
BlockBasedOptions, BoundColumnFamily, Cache, ColumnFamily, ColumnFamilyDescriptor,
DBIterator, DBRawIterator, Env, IngestExternalFileOptions, Options,
PlainTableFactoryOptions, ReadOptions, Snapshot, SstFileWriter, WriteBatch, WriteOptions,
DB,
};
#[test]
fn is_send() {
fn is_send<T: Send>() {
}
is_send::<DB>();
is_send::<DBIterator<'_>>();
is_send::<DBRawIterator<'_>>();
is_send::<Snapshot>();
is_send::<Options>();
is_send::<ReadOptions>();
is_send::<WriteOptions>();
is_send::<IngestExternalFileOptions>();
is_send::<BlockBasedOptions>();
is_send::<PlainTableFactoryOptions>();
is_send::<ColumnFamilyDescriptor>();
is_send::<ColumnFamily>();
is_send::<BoundColumnFamily<'_>>();
is_send::<UnboundColumnFamily>();
is_send::<SstFileWriter>();
is_send::<WriteBatch>();
is_send::<Cache>();
is_send::<CacheWrapper>();
is_send::<Env>();
is_send::<EnvWrapper>();
is_send::<TransactionDB>();
is_send::<OptimisticTransactionDB>();
is_send::<Transaction<'_, TransactionDB>>();
is_send::<TransactionDBOptions>();
is_send::<OptimisticTransactionOptions>();
is_send::<TransactionOptions>();
}
#[test]
fn is_sync() {
fn is_sync<T: Sync>() {
}
is_sync::<DB>();
is_sync::<Snapshot>();
is_sync::<Options>();
is_sync::<ReadOptions>();
is_sync::<WriteOptions>();
is_sync::<IngestExternalFileOptions>();
is_sync::<BlockBasedOptions>();
is_sync::<PlainTableFactoryOptions>();
is_sync::<UnboundColumnFamily>();
is_sync::<ColumnFamilyDescriptor>();
is_sync::<SstFileWriter>();
is_sync::<Cache>();
is_sync::<CacheWrapper>();
is_sync::<Env>();
is_sync::<EnvWrapper>();
is_sync::<TransactionDB>();
is_sync::<OptimisticTransactionDB>();
is_sync::<TransactionDBOptions>();
is_sync::<OptimisticTransactionOptions>();
is_sync::<TransactionOptions>();
}
}