From 18bece201c15ec78f5f46d51c1192aeb393742f2 Mon Sep 17 00:00:00 2001 From: Christian Stefanescu Date: Fri, 15 May 2020 19:22:26 +0200 Subject: [PATCH] Use thiserror's Derive macro --- Cargo.toml | 1 + src/result.rs | 84 ++++++--------------------------------------------- 2 files changed, 10 insertions(+), 75 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index a351ec9a..0cc4c73f 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 c826d1d4..3faec859 100644 --- a/src/result.rs +++ b/src/result.rs @@ -1,94 +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)] -pub enum ZipError -{ +#[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, - } - } -}