use crate::export::ExportError;
use std::{sync::PoisonError, time::Duration};
use thiserror::Error;
pub type LogResult<T> = Result<T, LogError>;
#[derive(Error, Debug)]
#[non_exhaustive]
pub enum LogError {
#[error("Exporter {} encountered the following errors: {0}", .0.exporter_name())]
ExportFailed(Box<dyn ExportError>),
#[error("Exporter timed out after {} seconds", .0.as_secs())]
ExportTimedOut(Duration),
#[error("{0} already shutdown")]
AlreadyShutdown(String),
#[error("mutex lock poisioning for {0}")]
MutexPoisoned(String),
#[error(transparent)]
Other(#[from] Box<dyn std::error::Error + Send + Sync + 'static>),
}
impl<T> From<T> for LogError
where
T: ExportError,
{
fn from(err: T) -> Self {
LogError::ExportFailed(Box::new(err))
}
}
impl From<String> for LogError {
fn from(err_msg: String) -> Self {
LogError::Other(Box::new(Custom(err_msg)))
}
}
impl From<&'static str> for LogError {
fn from(err_msg: &'static str) -> Self {
LogError::Other(Box::new(Custom(err_msg.into())))
}
}
impl<T> From<PoisonError<T>> for LogError {
fn from(err: PoisonError<T>) -> Self {
LogError::Other(err.to_string().into())
}
}
#[derive(Error, Debug)]
#[error("{0}")]
struct Custom(String);