pub struct Error { /* private fields */ }Expand description
Error is the error struct returned by all iceberg functions.
§Display
Error can be displayed in two ways:
- Via
Display: likeerr.to_string()orformat!("{err}")
Error will be printed in a single line:
Unexpected, context: { path: /path/to/file, called: send_async } => something wrong happened, source: networking error"- Via
Debug: likeformat!("{err:?}")
Error will be printed in multi lines with more details and backtraces (if captured):
Unexpected => something wrong happened
Context:
path: /path/to/file
called: send_async
Source: networking error
Backtrace:
0: iceberg::error::Error::new
at ./src/error.rs:197:24
1: iceberg::error::tests::generate_error
at ./src/error.rs:241:9
2: iceberg::error::tests::test_error_debug_with_backtrace::{{closure}}
at ./src/error.rs:305:41
...Implementations§
Source§impl Error
impl Error
Sourcepub fn new(kind: ErrorKind, message: impl Into<String>) -> Self
pub fn new(kind: ErrorKind, message: impl Into<String>) -> Self
Create a new Error with error kind and message.
Sourcepub fn with_retryable(self, retryable: bool) -> Self
pub fn with_retryable(self, retryable: bool) -> Self
Set retryable of the error.
Sourcepub fn with_context(self, key: &'static str, value: impl Into<String>) -> Self
pub fn with_context(self, key: &'static str, value: impl Into<String>) -> Self
Add more context in error.
Sourcepub fn with_source(self, src: impl Into<Error>) -> Self
pub fn with_source(self, src: impl Into<Error>) -> Self
Sourcepub fn backtrace(&self) -> &Backtrace
pub fn backtrace(&self) -> &Backtrace
Return error’s backtrace.
Note: the standard way of exposing backtrace is the unstable feature error_generic_member_access.
We don’t provide it as it requires nightly rust.
If you just want to print error with backtrace, use Debug, like format!("{err:?}").
If you use nightly rust, and want to access iceberg::Error’s backtrace in the standard way, you can
implement a new type like this:
// assume you already have `#![feature(error_generic_member_access)]` on the top of your crate
#[derive(::std::fmt::Debug)]
pub struct IcebergError(iceberg::Error);
impl std::fmt::Display for IcebergError {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
self.0.fmt(f)
}
}
impl std::error::Error for IcebergError {
fn provide<'a>(&'a self, request: &mut std::error::Request<'a>) {
request.provide_ref::<std::backtrace::Backtrace>(self.0.backtrace());
}
fn source(&self) -> Option<&(dyn std::error::Error + 'static)> {
self.0.source()
}
}Additionally, you can add a clippy lint to prevent usage of the original iceberg::Error type.
disallowed-types = [
{ path = "iceberg::Error", reason = "Please use `my_crate::IcebergError` instead." },
]Trait Implementations§
Source§impl Error for Error
impl Error for Error
Source§fn source(&self) -> Option<&(dyn Error + 'static)>
fn source(&self) -> Option<&(dyn Error + 'static)>
1.0.0 · Source§fn description(&self) -> &str
fn description(&self) -> &str
Source§impl From<ParseError> for Error
impl From<ParseError> for Error
Source§fn from(v: ParseError) -> Self
fn from(v: ParseError) -> Self
Source§impl From<ParseError> for Error
impl From<ParseError> for Error
Source§fn from(v: ParseError) -> Self
fn from(v: ParseError) -> Self
Source§impl From<ParseIntError> for Error
impl From<ParseIntError> for Error
Source§fn from(v: ParseIntError) -> Self
fn from(v: ParseIntError) -> Self
Source§impl From<TryFromIntError> for Error
impl From<TryFromIntError> for Error
Source§fn from(v: TryFromIntError) -> Self
fn from(v: TryFromIntError) -> Self
Source§impl From<TryFromSliceError> for Error
impl From<TryFromSliceError> for Error
Source§fn from(v: TryFromSliceError) -> Self
fn from(v: TryFromSliceError) -> Self
Auto Trait Implementations§
impl !Freeze for Error
impl RefUnwindSafe for Error
impl Send for Error
impl Sync for Error
impl Unpin for Error
impl UnwindSafe for Error
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> Downcast for Twhere
T: AsAny + ?Sized,
impl<T> Downcast for Twhere
T: AsAny + ?Sized,
§fn downcast_ref<T>(&self) -> Option<&T>where
T: AsAny,
fn downcast_ref<T>(&self) -> Option<&T>where
T: AsAny,
Any.§fn downcast_mut<T>(&mut self) -> Option<&mut T>where
T: AsAny,
fn downcast_mut<T>(&mut self) -> Option<&mut T>where
T: AsAny,
Any.§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
§impl<T> ToStringFallible for Twhere
T: Display,
impl<T> ToStringFallible for Twhere
T: Display,
§fn try_to_string(&self) -> Result<String, TryReserveError>
fn try_to_string(&self) -> Result<String, TryReserveError>
ToString::to_string, but without panic on OOM.