i3-cli-download-dir #12

Merged
kemitix merged 8 commits from i3-cli-download-dir into main 2023-08-06 12:14:03 +01:00
Showing only changes of commit 536534bb04 - Show all commits

View file

@ -3,11 +3,13 @@ use std::{str::Utf8Error, string::FromUtf8Error};
#[derive(Debug)] #[derive(Debug)]
pub struct Error { pub struct Error {
pub details: String, pub details: String,
pub source: String,
} }
impl Error { impl Error {
pub fn message(details: &str) -> Self { pub fn message(details: &str) -> Self {
Self { Self {
details: details.to_string(), details: details.to_string(),
source: "(not provided)".to_string(),
} }
} }
} }
@ -15,6 +17,7 @@ impl From<Utf8Error> for Error {
fn from(value: Utf8Error) -> Self { fn from(value: Utf8Error) -> Self {
Self { Self {
details: value.to_string(), details: value.to_string(),
source: "Utf8Error".to_string(),
} }
} }
} }
@ -22,18 +25,23 @@ impl From<FromUtf8Error> for Error {
fn from(value: FromUtf8Error) -> Self { fn from(value: FromUtf8Error) -> Self {
Self { Self {
details: value.to_string(), details: value.to_string(),
source: "FromUtf8Error".to_string(),
} }
} }
} }
impl From<String> for Error { impl From<String> for Error {
fn from(details: String) -> Self { fn from(details: String) -> Self {
Self { details } Self {
details,
source: "String".to_string(),
}
} }
} }
impl From<std::io::Error> for Error { impl From<std::io::Error> for Error {
fn from(value: std::io::Error) -> Self { fn from(value: std::io::Error) -> Self {
Self { Self {
details: value.to_string(), details: value.to_string(),
source: "std::io::Error".to_string(),
} }
} }
} }
@ -41,6 +49,7 @@ impl From<std::sync::mpsc::SendError<String>> for Error {
fn from(value: std::sync::mpsc::SendError<String>) -> Self { fn from(value: std::sync::mpsc::SendError<String>) -> Self {
Self { Self {
details: value.to_string(), details: value.to_string(),
source: "std::sync::mpsc::SendError".to_string(),
} }
} }
} }
@ -48,6 +57,7 @@ impl From<atom_syndication::Error> for Error {
fn from(value: atom_syndication::Error) -> Self { fn from(value: atom_syndication::Error) -> Self {
Self { Self {
details: value.to_string(), details: value.to_string(),
source: "atom_syndication::Error".to_string(),
} }
} }
} }
@ -55,6 +65,7 @@ impl From<reqwest::Error> for Error {
fn from(value: reqwest::Error) -> Self { fn from(value: reqwest::Error) -> Self {
Self { Self {
details: value.to_string(), details: value.to_string(),
source: "reqwest::Error".to_string(),
} }
} }
} }