aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorLizzy Fleckenstein <eliasfleckenstein@web.de>2023-02-15 12:49:00 +0100
committerLizzy Fleckenstein <eliasfleckenstein@web.de>2023-02-15 12:49:00 +0100
commitea481ae3539e27a98ace48e746fea4a2cbf4d557 (patch)
tree0cbc192d55902c515fe3054c403e411ba944d41a /src
parentdf3188d85034425c8a4d5d7658c84a808e615d19 (diff)
downloadmt_rudp-ea481ae3539e27a98ace48e746fea4a2cbf4d557.tar.xz
Use thiserror
Diffstat (limited to 'src')
-rw-r--r--src/error.rs50
1 files changed, 14 insertions, 36 deletions
diff --git a/src/error.rs b/src/error.rs
index 55566fa..bac843a 100644
--- a/src/error.rs
+++ b/src/error.rs
@@ -1,28 +1,32 @@
use crate::prelude::*;
use num_enum::TryFromPrimitiveError;
-use std::{fmt, io};
+use thiserror::Error;
use tokio::sync::mpsc::error::SendError;
-#[derive(Debug)]
+#[derive(Error, Debug)]
pub enum Error {
- IoError(io::Error),
+ #[error("io error: {0}")]
+ IoError(#[from] std::io::Error),
+ #[error("invalid protocol ID: {0}")]
InvalidProtoId(u32),
+ #[error("invalid channel: {0}")]
InvalidChannel(u8),
+ #[error("invalid type: {0}")]
InvalidType(u8),
+ #[error("invalid control type: {0}")]
InvalidCtlType(u8),
+ #[error("peer ID already set")]
PeerIDAlreadySet,
+ #[error("chunk index {0} bigger than chunk count {1}")]
InvalidChunkIndex(usize, usize),
+ #[error("chunk count changed from {0} to {1}")]
InvalidChunkCount(usize, usize),
+ #[error("remote disconnected (timeout = {0})")]
RemoteDisco(bool),
+ #[error("local disconnected")]
LocalDisco,
}
-impl From<io::Error> for Error {
- fn from(err: io::Error) -> Self {
- Self::IoError(err)
- }
-}
-
impl From<TryFromPrimitiveError<PktType>> for Error {
fn from(err: TryFromPrimitiveError<PktType>) -> Self {
Self::InvalidType(err.number)
@@ -31,7 +35,7 @@ impl From<TryFromPrimitiveError<PktType>> for Error {
impl From<TryFromPrimitiveError<CtlType>> for Error {
fn from(err: TryFromPrimitiveError<CtlType>) -> Self {
- Self::InvalidType(err.number)
+ Self::InvalidCtlType(err.number)
}
}
@@ -40,29 +44,3 @@ impl From<SendError<InPkt>> for Error {
Self::LocalDisco
}
}
-
-impl fmt::Display for Error {
- fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
- use Error::*;
- write!(f, "rudp: ")?;
-
- match self {
- IoError(err) => write!(f, "IO error: {err}"),
- InvalidProtoId(id) => write!(f, "invalid protocol ID: {id}"),
- InvalidChannel(ch) => write!(f, "invalid channel: {ch}"),
- InvalidType(tp) => write!(f, "invalid type: {tp}"),
- InvalidCtlType(tp) => write!(f, "invalid control type: {tp}"),
- PeerIDAlreadySet => write!(f, "peer ID already set"),
- InvalidChunkIndex(i, n) => write!(f, "chunk index {i} bigger than chunk count {n}"),
- InvalidChunkCount(o, n) => write!(f, "chunk count changed from {o} to {n}"),
- RemoteDisco(to) => write!(
- f,
- "remote disconnected{}",
- if *to { " (timeout)" } else { "" }
- ),
- LocalDisco => write!(f, "local disconnected"),
- }
- }
-}
-
-impl std::error::Error for Error {}