diff options
author | 2025-02-25 20:50:23 +0000 | |
---|---|---|
committer | 2025-02-25 20:50:23 +0000 | |
commit | 76b00cd644768d6a1b66b50b802bb72e2be228ce (patch) | |
tree | bd9e5c6a7df6c00fb68692cdb6b39c6912658054 | |
parent | d30131e0fcf7d64a333493bc430baa02fd156f4d (diff) | |
download | luz-76b00cd644768d6a1b66b50b802bb72e2be228ce.tar.gz luz-76b00cd644768d6a1b66b50b802bb72e2be228ce.tar.bz2 luz-76b00cd644768d6a1b66b50b802bb72e2be228ce.zip |
implement Clone for error types
-rw-r--r-- | jabber/src/error.rs | 16 | ||||
-rw-r--r-- | jid/src/lib.rs | 4 | ||||
-rw-r--r-- | stanza/src/stream.rs | 2 |
3 files changed, 13 insertions, 9 deletions
diff --git a/jabber/src/error.rs b/jabber/src/error.rs index 8c27cc9..ec60778 100644 --- a/jabber/src/error.rs +++ b/jabber/src/error.rs @@ -1,4 +1,5 @@ use std::str::Utf8Error; +use std::sync::Arc; use jid::ParseError; use rsasl::mechname::MechanismNameError; @@ -6,9 +7,8 @@ use stanza::client::error::Error as ClientError; use stanza::sasl::Failure; use stanza::stream::Error as StreamError; use thiserror::Error; -use tokio::task::JoinError; -#[derive(Error, Debug)] +#[derive(Error, Debug, Clone)] pub enum Error { #[error("connection")] Connection, @@ -39,16 +39,20 @@ pub enum Error { StreamError(#[from] StreamError), #[error("error missing")] MissingError, - #[error("task join error")] - JoinError(#[from] JoinError), } -#[derive(Error, Debug)] +#[derive(Error, Debug, Clone)] pub enum SASLError { #[error("sasl error: {0}")] - SASL(#[from] rsasl::prelude::SASLError), + SASL(Arc<rsasl::prelude::SASLError>), #[error("mechanism error: {0}")] MechanismName(#[from] MechanismNameError), #[error("authentication failure: {0}")] Authentication(#[from] Failure), } + +impl From<rsasl::prelude::SASLError> for SASLError { + fn from(e: rsasl::prelude::SASLError) -> Self { + Self::SASL(Arc::new(e)) + } +} diff --git a/jid/src/lib.rs b/jid/src/lib.rs index 09b0a7f..8f297c6 100644 --- a/jid/src/lib.rs +++ b/jid/src/lib.rs @@ -62,7 +62,7 @@ impl sqlx::Encode<'_, Sqlite> for JID { } } -#[derive(Debug)] +#[derive(Debug, Clone)] pub enum JIDError { NoResourcePart, ParseError(ParseError), @@ -79,7 +79,7 @@ impl Display for JIDError { impl Error for JIDError {} -#[derive(Debug)] +#[derive(Debug, Clone)] pub enum ParseError { Empty, Malformed(String), diff --git a/stanza/src/stream.rs b/stanza/src/stream.rs index 60b13bc..8e1982f 100644 --- a/stanza/src/stream.rs +++ b/stanza/src/stream.rs @@ -179,7 +179,7 @@ impl FromElement for Feature { } } -#[derive(Error, Debug)] +#[derive(Error, Debug, Clone)] pub struct Error { error: StreamError, text: Option<Text>, |