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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
use std::borrow::Cow;
use std::error::Error as StdError;
use std::fmt::{self, Display};
use std::io;
use std::string::FromUtf8Error;
use super::{httparse, hyper, mime_multipart};
pub enum Error {
NoRequestContentType,
NotMultipart,
NotFormData,
BoundaryNotSpecified,
PartialHeaders,
MissingDisposition,
InvalidDisposition,
NoName,
Eof,
Httparse(httparse::Error),
Io(io::Error),
Hyper(hyper::Error),
Utf8(FromUtf8Error),
Decoding(Cow<'static, str>),
Multipart(mime_multipart::Error),
NotAFile,
}
impl From<io::Error> for Error {
fn from(err: io::Error) -> Error {
Error::Io(err)
}
}
impl From<httparse::Error> for Error {
fn from(err: httparse::Error) -> Error {
Error::Httparse(err)
}
}
impl From<hyper::Error> for Error {
fn from(err: hyper::Error) -> Error {
Error::Hyper(err)
}
}
impl From<FromUtf8Error> for Error {
fn from(err: FromUtf8Error) -> Error {
Error::Utf8(err)
}
}
impl From<mime_multipart::Error> for Error {
fn from(err: mime_multipart::Error) -> Error {
Error::Multipart(err)
}
}
impl Display for Error {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
match *self {
Error::Httparse(ref e) =>
format!("{}: {:?}", self.description(), e).fmt(f),
Error::Io(ref e) =>
format!("{}: {}", self.description(), e).fmt(f),
Error::Hyper(ref e) =>
format!("{}: {}", self.description(), e).fmt(f),
Error::Utf8(ref e) =>
format!("{}: {}", self.description(), e).fmt(f),
Error::Decoding(ref e) =>
format!("{}: {}", self.description(), e).fmt(f),
Error::Multipart(ref e) =>
format!("{}: {}", self.description(), e).fmt(f),
_ => format!("{}", self.description()).fmt(f),
}
}
}
impl fmt::Debug for Error {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
try!( f.write_str(&*self.description()) );
if self.cause().is_some() {
try!( write!(f, ": {:?}", self.cause().unwrap()) );
}
Ok(())
}
}
impl StdError for Error {
fn description(&self) -> &str{
match *self {
Error::NoRequestContentType => "The Hyper request did not have a Content-Type header.",
Error::NotMultipart =>
"The Hyper request Content-Type top-level Mime was not multipart.",
Error::NotFormData =>
"The Hyper request Content-Type sub-level Mime was not form-data.",
Error::BoundaryNotSpecified =>
"The Content-Type header failed to specify a boundary token.",
Error::PartialHeaders => "A multipart section contained only partial headers.",
Error::MissingDisposition =>
"A multipart section did not have the required Content-Disposition header.",
Error::InvalidDisposition =>
"A multipart section did not have a valid corresponding Content-Disposition.",
Error::NoName =>
"A multipart section Content-Disposition header failed to specify a name.",
Error::Eof =>
"The request body ended prior to reaching the expected terminating boundary.",
Error::Httparse(_) =>
"A parse error occurred while parsing the headers of a multipart section.",
Error::Io(_) => "An I/O error occurred.",
Error::Hyper(_) => "A Hyper error occurred.",
Error::Utf8(_) => "A UTF-8 error occurred.",
Error::Decoding(_) => "A decoding error occurred.",
Error::Multipart(_) => "A MIME multipart error occurred.",
Error::NotAFile => "FilePart is not a file.",
}
}
}