zip-rs-wasm/src/result.rs
2015-02-24 20:42:43 +01:00

86 lines
2 KiB
Rust

//! Error types that can be emitted from this library
use std::io;
use std::error;
use std::fmt;
/// Generic result type with ZipError as its error variant
pub type ZipResult<T> = Result<T, ZipError>;
/// Error type for Zip
#[derive(Debug)]
pub enum ZipError
{
/// An Error caused by I/O
Io(io::Error),
/// This file is probably not a zipfile. The argument is enclosed.
InvalidZipFile(&'static str),
/// This file is unsupported. The reason is enclosed.
UnsupportedZipFile(&'static str),
/// The ZipReader is not available.
ReaderUnavailable,
}
impl ZipError
{
fn detail(&self) -> ::std::string::CowString
{
use ::std::error::Error;
use ::std::borrow::IntoCow;
match *self
{
ZipError::Io(ref io_err) => {
("Io Error: ".to_string() + io_err.description()).into_cow()
},
ZipError::InvalidZipFile(msg) | ZipError::UnsupportedZipFile(msg) => {
(self.description().to_string() + ": " + msg).into_cow()
},
ZipError::ReaderUnavailable => {
self.description().into_cow()
},
}
}
}
impl error::FromError<io::Error> for ZipError
{
fn from_error(err: io::Error) -> ZipError
{
ZipError::Io(err)
}
}
impl fmt::Display for ZipError
{
fn fmt(&self, fmt: &mut fmt::Formatter) -> Result<(), fmt::Error>
{
fmt.write_str(&*self.detail())
}
}
impl error::Error for ZipError
{
fn description(&self) -> &str
{
match *self
{
ZipError::Io(ref io_err) => io_err.description(),
ZipError::InvalidZipFile(..) => "Invalid Zip File",
ZipError::UnsupportedZipFile(..) => "Unsupported Zip File",
ZipError::ReaderUnavailable => "No reader available",
}
}
fn cause(&self) -> Option<&error::Error>
{
match *self
{
ZipError::Io(ref io_err) => Some(io_err as &error::Error),
_ => None,
}
}
}