use std::collections::HashMap;
use std::error;
use std::convert;
use std::error::Error;
use std::fmt;
use wrappers::{Request, Response};
use http_errors::HTTPError;
pub use self::PencilError::{
PenHTTPError,
PenUserError
};
#[derive(Clone, Debug)]
pub struct UserError {
pub desc: String,
}
impl UserError {
pub fn new<T>(desc: T) -> UserError where T: AsRef<str> {
UserError {
desc: desc.as_ref().to_owned(),
}
}
}
impl fmt::Display for UserError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
f.write_str(&self.desc)
}
}
impl error::Error for UserError {
fn description(&self) -> &str {
&self.desc
}
}
#[derive(Clone, Debug)]
pub enum PencilError {
PenHTTPError(HTTPError),
PenUserError(UserError),
}
impl convert::From<HTTPError> for PencilError {
fn from(err: HTTPError) -> PencilError {
PenHTTPError(err)
}
}
impl convert::From<UserError> for PencilError {
fn from(err: UserError) -> PencilError {
PenUserError(err)
}
}
impl fmt::Display for PencilError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
match *self {
PenHTTPError(ref err) => f.write_str(err.description()),
PenUserError(ref err) => f.write_str(err.description()),
}
}
}
impl error::Error for PencilError {
fn description(&self) -> &str {
match *self {
PenHTTPError(ref err) => err.description(),
PenUserError(ref err) => err.description(),
}
}
fn cause(&self) -> Option<&error::Error> {
match self {
&PenHTTPError(ref err) => Some(&*err as &error::Error),
&PenUserError(_) => None,
}
}
}
pub type PencilResult = Result<Response, PencilError>;
pub type ViewArgs = HashMap<String, String>;
pub type ViewFunc = fn(&mut Request) -> PencilResult;
pub type HTTPErrorHandler = fn(HTTPError) -> PencilResult;
pub type UserErrorHandler = fn(UserError) -> PencilResult;
pub type BeforeRequestFunc = fn(&mut Request) -> Option<PencilResult>;
pub type AfterRequestFunc = fn(&mut Response);
pub type TeardownRequestFunc = fn(Option<&PencilError>);