use super::{AsyncDatabase, AsyncPendingManager};
#[derive(thiserror::Error)]
pub enum TransactionError<P: AsyncPendingManager> {
#[error("transaction is read-only")]
ReadOnly,
#[error("transaction conflict, please retry")]
Conflict,
#[error("transaction has been discarded, please create a new one")]
Discard,
#[error("transaction is too large")]
LargeTxn,
#[error("transaction manager error: {0}")]
Manager(P::Error),
}
impl<P: AsyncPendingManager> core::fmt::Debug for TransactionError<P> {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
match self {
Self::ReadOnly => write!(f, "ReadOnly"),
Self::Conflict => write!(f, "Conflict"),
Self::Discard => write!(f, "Discard"),
Self::LargeTxn => write!(f, "LargeTxn"),
Self::Manager(e) => write!(f, "Manager({:?})", e),
}
}
}
#[derive(thiserror::Error)]
pub enum Error<D: AsyncDatabase, P: AsyncPendingManager> {
#[error(transparent)]
Transaction(#[from] TransactionError<P>),
#[error(transparent)]
DB(D::Error),
}
impl<D: AsyncDatabase, P: AsyncPendingManager> core::fmt::Debug for Error<D, P> {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
match self {
Self::Transaction(e) => e.fmt(f),
Self::DB(e) => e.fmt(f),
}
}
}
impl<D: AsyncDatabase, P: AsyncPendingManager> Error<D, P> {
pub fn database(err: D::Error) -> Self {
Self::DB(err)
}
pub fn transaction(err: TransactionError<P>) -> Self {
Self::Transaction(err)
}
}