diff options
-rw-r--r-- | src/error.rs | 118 | ||||
-rw-r--r-- | src/main.rs | 1 |
2 files changed, 0 insertions, 119 deletions
diff --git a/src/error.rs b/src/error.rs deleted file mode 100644 index e891da2..0000000 --- a/src/error.rs +++ /dev/null @@ -1,118 +0,0 @@ -// error.rs - -// ************************************************************************* -// * Copyright (C) 2017-2020 Daniel Mueller (deso@posteo.net) * -// * * -// * This program is free software: you can redistribute it and/or modify * -// * it under the terms of the GNU General Public License as published by * -// * the Free Software Foundation, either version 3 of the License, or * -// * (at your option) any later version. * -// * * -// * This program is distributed in the hope that it will be useful, * -// * but WITHOUT ANY WARRANTY; without even the implied warranty of * -// * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * -// * GNU General Public License for more details. * -// * * -// * You should have received a copy of the GNU General Public License * -// * along with this program. If not, see <http://www.gnu.org/licenses/>. * -// ************************************************************************* - -use std::fmt; -use std::io; -use std::str; -use std::string; - -use structopt::clap; - -/// A trait used to simplify error handling in conjunction with the -/// try_with_* functions we use for repeatedly asking the user for a -/// secret. -pub trait TryInto<T> { - fn try_into(self) -> Result<T, Error>; -} - -impl<T, U> TryInto<U> for T -where - T: Into<U>, -{ - fn try_into(self) -> Result<U, Error> { - Ok(self.into()) - } -} - -#[derive(Debug)] -pub enum Error { - ClapError(clap::Error), - IoError(io::Error), - NitrokeyError(Option<&'static str>, nitrokey::Error), - Utf8Error(str::Utf8Error), - Error(String), -} - -impl TryInto<nitrokey::Error> for Error { - fn try_into(self) -> Result<nitrokey::Error, Error> { - match self { - Error::NitrokeyError(_, err) => Ok(err), - err => Err(err), - } - } -} - -impl From<&str> for Error { - fn from(s: &str) -> Error { - Error::Error(s.to_string()) - } -} - -impl From<String> for Error { - fn from(s: String) -> Error { - Error::Error(s) - } -} - -impl From<clap::Error> for Error { - fn from(e: clap::Error) -> Error { - Error::ClapError(e) - } -} - -impl From<nitrokey::Error> for Error { - fn from(e: nitrokey::Error) -> Error { - Error::NitrokeyError(None, e) - } -} - -impl From<io::Error> for Error { - fn from(e: io::Error) -> Error { - Error::IoError(e) - } -} - -impl From<str::Utf8Error> for Error { - fn from(e: str::Utf8Error) -> Error { - Error::Utf8Error(e) - } -} - -impl From<string::FromUtf8Error> for Error { - fn from(e: string::FromUtf8Error) -> Error { - Error::Utf8Error(e.utf8_error()) - } -} - -impl fmt::Display for Error { - fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { - match *self { - Error::ClapError(ref e) => write!(f, "{}", e), - Error::NitrokeyError(ref ctx, ref e) => { - if let Some(ctx) = ctx { - write!(f, "{}: ", ctx)?; - } - write!(f, "{}", e) - } - Error::Utf8Error(_) => write!(f, "Encountered UTF-8 conversion error"), - Error::IoError(ref e) => write!(f, "IO error: {}", e), - Error::Error(ref e) => write!(f, "{}", e), - } - } -} diff --git a/src/main.rs b/src/main.rs index 4f08d21..4e6b01d 100644 --- a/src/main.rs +++ b/src/main.rs @@ -70,7 +70,6 @@ mod arg_util; mod args; mod commands; -mod error; mod pinentry; #[cfg(test)] mod tests; |