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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
use lib::fmt;
use lib::error::Error as StdError;
#[derive(Debug, Copy, Clone, Eq, PartialEq)]
pub enum ErrorKind {
Overflow,
InvalidDigit(usize),
Empty,
#[doc(hidden)]
__Nonexhaustive,
}
#[derive(Debug, Copy, Clone, Eq, PartialEq)]
pub struct Error(ErrorKind);
impl From<ErrorKind> for Error {
#[inline]
fn from(kind: ErrorKind) -> Self {
Error(kind)
}
}
impl Error {
#[inline]
pub fn kind(&self) -> &ErrorKind {
&self.0
}
}
impl fmt::Display for Error {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
match self.kind() {
&ErrorKind::Overflow => write!(f, "lexical error: integer overflow occurred during integer parsing."),
&ErrorKind::InvalidDigit(u) => write!(f, "lexical error: invalid digit found at {}.", u),
&ErrorKind::Empty => write!(f, "lexical error: empty input data."),
_ => unreachable!(),
}
}
}
impl StdError for Error {
fn description(&self) -> &str {
match self.kind() {
&ErrorKind::Overflow => "lexical error: integer overflow occurred during integer parsing.",
&ErrorKind::InvalidDigit(_) => "lexical error: invalid digit found in string.",
&ErrorKind::Empty => "lexical error: empty input data.",
_ => unreachable!(),
}
}
#[allow(unknown_lints, bare_trait_objects)]
fn cause(&self) -> Option<&StdError> {
None
}
}
#[inline]
pub(crate) fn overflow() -> Error {
ErrorKind::Overflow.into()
}
#[inline]
pub(crate) fn invalid_digit(position: usize) -> Error {
ErrorKind::InvalidDigit(position).into()
}
#[inline]
pub(crate) fn empty() -> Error {
ErrorKind::Empty.into()
}