musli_common/context/error.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
//! Trait governing what error types associated with the encoding framework must
//! support.
//!
//! The most important component in here is `Error::custom` which allows custom
//! encoding implementations to raise custom errors based on types that
//! implement [Display][core::fmt::Display].
use core::fmt;
use musli::context::StdError;
#[cfg(feature = "alloc")]
use alloc::string::{String, ToString};
/// Trait governing errors raised during encodeing or decoding.
pub trait Error: Sized + 'static + Send + Sync + fmt::Display + fmt::Debug {
/// Construct a custom error.
fn custom<T>(error: T) -> Self
where
T: 'static + Send + Sync + StdError;
/// Collect an error from something that can be displayed.
///
/// This is made available to format custom error messages in `no_std`
/// environments. The error message is to be collected by formatting `T`.
fn message<T>(message: T) -> Self
where
T: fmt::Display;
}
#[cfg(all(feature = "std", feature = "alloc"))]
impl Error for std::io::Error {
fn custom<T>(message: T) -> Self
where
T: 'static + Send + Sync + fmt::Display + fmt::Debug,
{
std::io::Error::new(std::io::ErrorKind::Other, message.to_string())
}
fn message<T>(message: T) -> Self
where
T: fmt::Display,
{
std::io::Error::new(std::io::ErrorKind::Other, message.to_string())
}
}
#[cfg(feature = "alloc")]
impl Error for String {
#[inline]
fn custom<T>(message: T) -> Self
where
T: fmt::Display,
{
message.to_string()
}
#[inline]
fn message<T>(message: T) -> Self
where
T: fmt::Display,
{
message.to_string()
}
}