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
use std::error::{Error as StdError};
use std::fmt;
use csv::{DeserializeErrorKind, ErrorKind, Error as CsvError};
#[derive(Debug)]
pub enum Error {
Csv(String, CsvError),
FieldError(String, u64, DeserializeErrorKind, Option<String>),
LineError(String, ErrorKind)
}
impl fmt::Display for Error {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
match *self {
Error::Csv(ref filename, ref err) => write!(f, "error parsing {} - {}", filename, format!("{}", err)),
Error::FieldError(ref filename, ref lineno, ref errk, ref field) => match *field {
Some(ref fieldname) => {
write!(f, "error parsing {} in {}:{} - {}", fieldname, filename, lineno, format!("{}", errk))
}
None => write!(f, "error parsing {}:{} - {}", filename, lineno, format!("{}", errk))
},
Error::LineError(ref filename, ref err) => match *err {
ErrorKind::UnequalLengths{ref pos, ref expected_len, ref len} => write!(f, "error parsing {}:{} - expected {} fields but got {} fields", filename, pos.as_ref().unwrap().line(), expected_len, len),
ErrorKind::Utf8{ref pos, ref err} => write!(f, "error parsing {}:{} - {:?}", filename, pos.as_ref().unwrap().line(), err),
_ => write!(f, "error parsing {} - {:?}", filename, err)
}
}
}
}
impl StdError for Error {
fn description(&self) -> &str {
use self::Error::*;
match *self {
Csv(_, ref err) => err.description(),
FieldError(..) => "error processing field of a line",
LineError(..) => "error processing line"
}
}
fn cause(&self) -> Option<&StdError> {
use self::Error::*;
match *self {
Csv(_, ref err) => Some(err),
FieldError(..) => None,
LineError(..) => None
}
}
}