Skip to content

Commit

Permalink
impl Context trait and into_inner
Browse files Browse the repository at this point in the history
Signed-off-by: Bugen Zhao <[email protected]>
  • Loading branch information
BugenZhao committed Feb 13, 2024
1 parent cfcd1b8 commit 6636d8e
Showing 1 changed file with 34 additions and 0 deletions.
34 changes: 34 additions & 0 deletions src/error/src/anyhow.rs
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,13 @@ macro_rules! def_anyhow_newtype {
($(#[$attr:meta])* $vis:vis $name:ident $(;)?) => {
$(#[$attr])* $vis struct $name(::anyhow::Error);

impl $name {
/// Unwrap the newtype to get the inner [`anyhow::Error`].
pub fn into_inner(self) -> ::anyhow::Error {
self.0
}
}

impl std::ops::Deref for $name {
type Target = ::anyhow::Error;

Expand Down Expand Up @@ -85,5 +92,32 @@ macro_rules! def_anyhow_newtype {
value.0.into()
}
}

paste::paste! {
/// Provides the `context` method for `Result` of [`ConnectorError`].
///
/// This trait is the supplement of the [`anyhow::Context`] trait as it cannot be
/// implemented for types outside of the crate.
#[easy_ext::ext([< $name Context >])]
$vis impl<T> Result<T, ConnectorError> {
/// Wrap the error value with additional context.
fn context<C>(self, context: C) -> Result<T, ::anyhow::Error>
where
C: std::fmt::Display + Send + Sync + 'static,
{
::anyhow::Context::context(self.map_err(|error| error.0), context)
}

/// Wrap the error value with additional context that is evaluated lazily
/// only once an error does occur.
fn with_context<C, F>(self, context: F) -> Result<T, ::anyhow::Error>
where
C: std::fmt::Display + Send + Sync + 'static,
F: FnOnce() -> C,
{
::anyhow::Context::with_context(self.map_err(|error| error.0), context)
}
}
}
};
}

0 comments on commit 6636d8e

Please sign in to comment.