use ebacktrace::define_error;
use std::{
error, io, result,
fmt::{ self, Display, Formatter }
};
#[macro_export] macro_rules! e {
($kind:expr, $($arg:tt)*) => ({ $crate::error::ErrorImpl::new($kind, format!($($arg)*)) })
}
#[macro_export] macro_rules! eio {
($($arg:tt)*) => ({ e!($crate::error::ErrorKind::InOutError, $($arg)*) });
}
#[macro_export] macro_rules! einval {
($($arg:tt)*) => ({ e!($crate::error::ErrorKind::InvalidValue, $($arg)*) });
}
#[derive(Debug, PartialEq, Eq)]
pub enum ErrorKind {
InOutError,
InvalidValue
}
impl Display for ErrorKind {
fn fmt(&self, f: &mut Formatter) -> fmt::Result {
match self {
Self::InOutError => write!(f, "An I/O-error occurred"),
Self::InvalidValue => write!(f, "A value is invalid")
}
}
}
impl error::Error for ErrorKind {
}
define_error!(ErrorImpl);
impl From<io::Error> for ErrorImpl<ErrorKind> {
fn from(underlying: io::Error) -> Self {
ErrorImpl::new(ErrorKind::InOutError, underlying.to_string())
}
}
pub type Error = ErrorImpl<ErrorKind>;
pub type Result<T = ()> = result::Result<T, ErrorImpl<ErrorKind>>;