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
use cssparser::{BasicParseErrorKind, ParseError, ParseErrorKind};
use std::{
borrow::Cow,
error::Error,
fmt,
fmt::{Display, Formatter},
io,
};
#[derive(Debug)]
pub enum InlineError {
IO(io::Error),
Network(attohttpc::Error),
ParseError(Cow<'static, str>),
}
impl From<io::Error> for InlineError {
fn from(error: io::Error) -> Self {
InlineError::IO(error)
}
}
impl From<attohttpc::Error> for InlineError {
fn from(error: attohttpc::Error) -> Self {
InlineError::Network(error)
}
}
impl Error for InlineError {}
impl Display for InlineError {
fn fmt(&self, f: &mut Formatter) -> fmt::Result {
match self {
InlineError::IO(error) => f.write_str(error.to_string().as_str()),
InlineError::Network(error) => f.write_str(error.to_string().as_str()),
InlineError::ParseError(error) => f.write_str(error),
}
}
}
impl From<(ParseError<'_, ()>, &str)> for InlineError {
fn from(error: (ParseError<'_, ()>, &str)) -> Self {
let message = match error.0.kind {
ParseErrorKind::Basic(kind) => match kind {
BasicParseErrorKind::UnexpectedToken(token) => {
format!("Unexpected token: {:?}", token)
}
BasicParseErrorKind::EndOfInput => "End of input".to_string(),
BasicParseErrorKind::AtRuleInvalid(value) => format!("Invalid @ rule: {}", value),
BasicParseErrorKind::AtRuleBodyInvalid => "Invalid @ rule body".to_string(),
BasicParseErrorKind::QualifiedRuleInvalid => "Invalid qualified rule".to_string(),
},
ParseErrorKind::Custom(_) => "Unknown error".to_string(),
};
InlineError::ParseError(Cow::from(message))
}
}