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, e).fmt(f),
Error::Io(ref e) =>
format!("{}: {}", self, e).fmt(f),
Error::Hyper(ref e) =>
format!("{}: {}", self, e).fmt(f),
Error::Utf8(ref e) =>
format!("{}: {}", self, e).fmt(f),
Error::Decoding(ref e) =>
format!("{}: {}", self, e).fmt(f),
Error::Multipart(ref e) =>
format!("{}: {}", self, e).fmt(f),
_ => format!("{}", self).fmt(f),
}
}
}
impl fmt::Debug for Error {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{}", self)?;
if self.source().is_some() {
write!(f, ": {:?}", self.source().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.",
}
}
}