use core::fmt::{self, Display, Formatter};
#[cfg(any(feature = "byte", feature = "bit"))]
pub use core::num::TryFromIntError;
#[cfg(feature = "std")]
use std::error::Error;
#[cfg(any(feature = "byte", feature = "bit"))]
use rust_decimal::Decimal;
#[cfg(any(feature = "byte", feature = "bit"))]
#[derive(Debug, Copy, Clone, PartialEq, Eq)]
pub struct ExceededBoundsError;
#[cfg(any(feature = "byte", feature = "bit"))]
impl Display for ExceededBoundsError {
#[inline]
fn fmt(&self, f: &mut Formatter<'_>) -> fmt::Result {
f.write_str("value exceeds the valid range")
}
}
#[cfg(any(feature = "byte", feature = "bit"))]
#[cfg(feature = "std")]
impl Error for ExceededBoundsError {}
#[cfg(any(feature = "byte", feature = "bit"))]
#[derive(Debug, Clone)]
pub enum ValueParseError {
ExceededBounds(Decimal),
NotNumber(char),
NoValue,
NumberTooLong,
}
#[cfg(any(feature = "byte", feature = "bit"))]
impl Display for ValueParseError {
#[inline]
fn fmt(&self, f: &mut Formatter<'_>) -> fmt::Result {
match self {
Self::ExceededBounds(value) => {
f.write_fmt(format_args!("the value {value:?} exceeds the valid range"))
},
Self::NotNumber(c) => f.write_fmt(format_args!("the character {c:?} is not a number")),
Self::NoValue => f.write_str("no value can be found"),
Self::NumberTooLong => f.write_str("value number is too long"),
}
}
}
#[cfg(any(feature = "byte", feature = "bit"))]
#[cfg(feature = "std")]
impl Error for ValueParseError {}
#[derive(Debug, Clone)]
pub struct UnitParseError {
pub character: char,
pub expected_characters: &'static [char],
pub also_expect_no_character: bool,
}
impl Display for UnitParseError {
#[inline]
fn fmt(&self, f: &mut Formatter<'_>) -> fmt::Result {
let Self {
character,
expected_characters,
also_expect_no_character,
} = self;
let expected_characters_length = expected_characters.len();
f.write_fmt(format_args!("the character {character:?} is incorrect",))?;
if expected_characters_length == 0 {
f.write_str(" (no character is expected)")
} else {
f.write_fmt(format_args!(
" ({expected_character:?}",
expected_character = expected_characters[0]
))?;
if expected_characters_length > 1 {
for expected_character in
expected_characters[1..].iter().take(expected_characters_length - 2)
{
f.write_fmt(format_args!(", {expected_character:?}"))?;
}
if *also_expect_no_character {
f.write_fmt(format_args!(
", {expected_character:?} or no character",
expected_character = expected_characters[expected_characters_length - 1]
))?;
} else {
f.write_fmt(format_args!(
" or {expected_character:?} is expected)",
expected_character = expected_characters[expected_characters_length - 1]
))?;
}
}
if *also_expect_no_character {
f.write_str(" or no character")?;
}
f.write_str(" is expected)")
}
}
}
#[cfg(any(feature = "byte", feature = "bit"))]
#[cfg(feature = "std")]
impl Error for UnitParseError {}
#[cfg(any(feature = "byte", feature = "bit"))]
#[derive(Debug, Clone)]
pub enum ParseError {
Value(ValueParseError),
Unit(UnitParseError),
}
#[cfg(any(feature = "byte", feature = "bit"))]
impl From<ValueParseError> for ParseError {
#[inline]
fn from(error: ValueParseError) -> Self {
Self::Value(error)
}
}
#[cfg(any(feature = "byte", feature = "bit"))]
impl From<UnitParseError> for ParseError {
#[inline]
fn from(error: UnitParseError) -> Self {
Self::Unit(error)
}
}
#[cfg(any(feature = "byte", feature = "bit"))]
impl Display for ParseError {
#[inline]
fn fmt(&self, f: &mut Formatter<'_>) -> fmt::Result {
match self {
ParseError::Value(error) => Display::fmt(error, f),
ParseError::Unit(error) => Display::fmt(error, f),
}
}
}
#[cfg(any(feature = "byte", feature = "bit"))]
#[cfg(feature = "std")]
impl Error for ParseError {}