use core::fmt::{self, Display};
#[cfg(feature = "std")]
use std::{boxed::Box, error::Error as StdError};
#[derive(Debug, Default)]
pub struct Error {
#[cfg(feature = "std")]
cause: Option<Box<dyn StdError>>,
}
impl Error {
pub fn new() -> Self {
Self::default()
}
#[cfg(feature = "std")]
pub fn from_cause<E>(cause: E) -> Self
where
E: Into<Box<dyn StdError>>,
{
Self {
cause: Some(cause.into()),
}
}
#[cfg(feature = "std")]
pub fn cause(&self) -> Option<&dyn StdError> {
self.cause.as_ref().map(|c| c.as_ref())
}
#[cfg(feature = "std")]
pub fn into_cause(self) -> Box<dyn StdError> {
self.cause
.expect("into_cause called on an error with no cause")
}
#[cfg(feature = "std")]
pub fn downcast<T>(self) -> Result<Box<T>, Box<dyn StdError>>
where
T: StdError + 'static,
{
self.cause
.map(|cause| cause.downcast())
.unwrap_or_else(|| Err(Error::new().into()))
}
#[cfg(feature = "std")]
pub fn downcast_ref<T>(&self) -> Option<&T>
where
T: StdError + 'static,
{
self.cause.as_ref().and_then(|cause| cause.downcast_ref())
}
}
#[cfg(not(feature = "std"))]
impl Display for Error {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "signature error")
}
}
#[cfg(feature = "std")]
impl Display for Error {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
if let Some(ref cause) = self.cause {
write!(f, "{}", cause)
} else {
write!(f, "signature error")
}
}
}
#[cfg(feature = "std")]
impl StdError for Error {
fn cause(&self) -> Option<&dyn StdError> {
self.cause.as_ref().map(|cause| cause.as_ref())
}
}