pub struct SyncFailure<T> { /* fields omitted */ }
Wrapper for std
errors to make them Sync
.
This exists to coerce existing types that are only Error + Send + 'static
into a Fail
-compatible representation, most notably for
types generated by error-chain
.
Unfortunately, this requires wrapping the error in a Mutex
, which must
be locked for every Debug
/Display
. Therefore, this should be
something of a last resort in making the error work with failure
.
[−]
Wraps a non-Sync
Error
in order to make it implement Fail
.
extern crate failure;
use failure::{Error, SyncFailure};
use std::cell::RefCell;
#[derive(Debug)]
struct NonSyncError {
count: RefCell<usize>,
}
fn returns_error() -> Result<(), NonSyncError> {
}
fn my_function() -> Result<(), Error> {
returns_error().map_err(SyncFailure::new)?;
}
Formats the value using the given formatter. Read more
Formats the value using the given formatter. Read more
Returns a reference to the underlying cause of this failure, if it is an error that wraps other errors. Read more
Returns a reference to the Backtrace
carried by this failure, if it carries one. Read more
Wraps this failure in a compatibility wrapper that implements std::error::Error
. Read more
Returns a iterator over the causes of this Fail
with itself as the first item and the root_cause
as the final item. Read more
[−]
Returns the "root cause" of this Fail
- the last value in the cause chain which does not return an underlying cause
. Read more