diff --git a/Cargo.toml b/Cargo.toml index a75a4a5d..2fbb331d 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -18,6 +18,7 @@ time = { version = "0.1", optional = true } podio = "0.1" bzip2 = { version = "0.3", optional = true } crc32fast = "1.0" +thiserror = "1.0" [dev-dependencies] bencher = "0.1" diff --git a/src/result.rs b/src/result.rs index 03a41f8c..62ecbb82 100644 --- a/src/result.rs +++ b/src/result.rs @@ -1,77 +1,28 @@ //! Error types that can be emitted from this library -use std::convert; -use std::error; -use std::fmt; use std::io; +use thiserror::Error; + /// Generic result type with ZipError as its error variant pub type ZipResult = Result; /// Error type for Zip -#[derive(Debug)] +#[derive(Debug, Error)] pub enum ZipError { /// An Error caused by I/O - Io(io::Error), + #[error(transparent)] + Io(#[from] io::Error), /// This file is probably not a zip archive + #[error("invalid Zip archive")] InvalidArchive(&'static str), /// This archive is not supported + #[error("unsupported Zip archive")] UnsupportedArchive(&'static str), /// The requested file could not be found in the archive + #[error("specified file not found in archive")] FileNotFound, -} - -impl ZipError { - fn detail(&self) -> ::std::borrow::Cow<'_, str> { - use std::error::Error; - - match *self { - ZipError::Io(ref io_err) => { - ("Io Error: ".to_string() + (io_err as &dyn error::Error).description()).into() - } - ZipError::InvalidArchive(msg) | ZipError::UnsupportedArchive(msg) => { - (self.description().to_string() + ": " + msg).into() - } - ZipError::FileNotFound => self.description().into(), - } - } -} - -impl convert::From for ZipError { - fn from(err: io::Error) -> ZipError { - ZipError::Io(err) - } -} - -impl convert::From for io::Error { - fn from(err: ZipError) -> io::Error { - io::Error::new(io::ErrorKind::Other, 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 as &dyn error::Error).description(), - ZipError::InvalidArchive(..) => "Invalid Zip archive", - ZipError::UnsupportedArchive(..) => "Unsupported Zip archive", - ZipError::FileNotFound => "Specified file not found in archive", - } - } - - fn cause(&self) -> Option<&dyn error::Error> { - match *self { - ZipError::Io(ref io_err) => Some(io_err as &dyn error::Error), - _ => None, - } - } -} +} \ No newline at end of file