Error

Trait Error 

1.0.0 · Source
pub trait Error: Debug + Display {
    // Provided methods
    fn source(&self) -> Option<&(dyn Error + 'static)> { ... }
    fn description(&self) -> &str { ... }
    fn cause(&self) -> Option<&dyn Error> { ... }
    fn provide<'a>(&'a self, request: &mut Request<'a>) { ... }
}
Expand description

Error is a trait representing the basic expectations for error values, i.e., values of type E in Result<T, E>.

Errors must describe themselves through the Display and Debug traits. Error messages are typically concise lowercase sentences without trailing punctuation:

let err = "NaN".parse::<u32>().unwrap_err();
assert_eq!(err.to_string(), "invalid digit found in string");

§Error source

Errors may provide cause information. Error::source() is generally used when errors cross “abstraction boundaries”. If one module must report an error that is caused by an error from a lower-level module, it can allow accessing that error via Error::source(). This makes it possible for the high-level module to provide its own errors while also revealing some of the implementation for debugging.

In error types that wrap an underlying error, the underlying error should be either returned by the outer error’s Error::source(), or rendered by the outer error’s Display implementation, but not both.

§Example

Implementing the Error trait only requires that Debug and Display are implemented too.

use std::error::Error;
use std::fmt;
use std::path::PathBuf;

#[derive(Debug)]
struct ReadConfigError {
    path: PathBuf
}

impl fmt::Display for ReadConfigError {
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
        let path = self.path.display();
        write!(f, "unable to read configuration at {path}")
    }
}

impl Error for ReadConfigError {}

Provided Methods§

1.30.0 · Source

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any.

§Examples
use std::error::Error;
use std::fmt;

#[derive(Debug)]
struct SuperError {
    source: SuperErrorSideKick,
}

impl fmt::Display for SuperError {
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
        write!(f, "SuperError is here!")
    }
}

impl Error for SuperError {
    fn source(&self) -> Option<&(dyn Error + 'static)> {
        Some(&self.source)
    }
}

#[derive(Debug)]
struct SuperErrorSideKick;

impl fmt::Display for SuperErrorSideKick {
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
        write!(f, "SuperErrorSideKick is here!")
    }
}

impl Error for SuperErrorSideKick {}

fn get_super_error() -> Result<(), SuperError> {
    Err(SuperError { source: SuperErrorSideKick })
}

fn main() {
    match get_super_error() {
        Err(e) => {
            println!("Error: {e}");
            println!("Caused by: {}", e.source().unwrap());
        }
        _ => println!("No error"),
    }
}
1.0.0 · Source

fn description(&self) -> &str

👎Deprecated since 1.42.0: use the Display impl or to_string()
if let Err(e) = "xc".parse::<u32>() {
    // Print `e` itself, no need for description().
    eprintln!("Error: {e}");
}
1.0.0 · Source

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0: replaced by Error::source, which can support downcasting
Source

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)

Provides type-based access to context intended for error reports.

Used in conjunction with Request::provide_value and Request::provide_ref to extract references to member variables from dyn Error trait objects.

§Example
#![feature(error_generic_member_access)]
use core::fmt;
use core::error::{request_ref, Request};

#[derive(Debug)]
enum MyLittleTeaPot {
    Empty,
}

#[derive(Debug)]
struct MyBacktrace {
    // ...
}

impl MyBacktrace {
    fn new() -> MyBacktrace {
        // ...
    }
}

#[derive(Debug)]
struct Error {
    backtrace: MyBacktrace,
}

impl fmt::Display for Error {
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
        write!(f, "Example Error")
    }
}

impl std::error::Error for Error {
    fn provide<'a>(&'a self, request: &mut Request<'a>) {
        request
            .provide_ref::<MyBacktrace>(&self.backtrace);
    }
}

fn main() {
    let backtrace = MyBacktrace::new();
    let error = Error { backtrace };
    let dyn_error = &error as &dyn std::error::Error;
    let backtrace_ref = request_ref::<MyBacktrace>(dyn_error).unwrap();

    assert!(core::ptr::eq(&error.backtrace, backtrace_ref));
    assert!(request_ref::<MyLittleTeaPot>(dyn_error).is_none());
}

Implementations§

Source§

impl dyn Error

1.3.0 · Source

pub fn is<T>(&self) -> bool
where T: Error + 'static,

Returns true if the inner type is the same as T.

1.3.0 · Source

pub fn downcast_ref<T>(&self) -> Option<&T>
where T: Error + 'static,

Returns some reference to the inner value if it is of type T, or None if it isn’t.

1.3.0 · Source

pub fn downcast_mut<T>(&mut self) -> Option<&mut T>
where T: Error + 'static,

Returns some mutable reference to the inner value if it is of type T, or None if it isn’t.

Source§

impl dyn Error + Send

1.3.0 · Source

pub fn is<T>(&self) -> bool
where T: Error + 'static,

Forwards to the method defined on the type dyn Error.

1.3.0 · Source

pub fn downcast_ref<T>(&self) -> Option<&T>
where T: Error + 'static,

Forwards to the method defined on the type dyn Error.

1.3.0 · Source

pub fn downcast_mut<T>(&mut self) -> Option<&mut T>
where T: Error + 'static,

Forwards to the method defined on the type dyn Error.

Source§

impl dyn Error + Send + Sync

1.3.0 · Source

pub fn is<T>(&self) -> bool
where T: Error + 'static,

Forwards to the method defined on the type dyn Error.

1.3.0 · Source

pub fn downcast_ref<T>(&self) -> Option<&T>
where T: Error + 'static,

Forwards to the method defined on the type dyn Error.

1.3.0 · Source

pub fn downcast_mut<T>(&mut self) -> Option<&mut T>
where T: Error + 'static,

Forwards to the method defined on the type dyn Error.

Source§

impl dyn Error

Source

pub fn sources(&self) -> Source<'_>

🔬This is a nightly-only experimental API. (error_iter)

Returns an iterator starting with the current error and continuing with recursively calling Error::source.

If you want to omit the current error and only use its sources, use skip(1).

§Examples
#![feature(error_iter)]
use std::error::Error;
use std::fmt;

#[derive(Debug)]
struct A;

#[derive(Debug)]
struct B(Option<Box<dyn Error + 'static>>);

impl fmt::Display for A {
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
        write!(f, "A")
    }
}

impl fmt::Display for B {
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
        write!(f, "B")
    }
}

impl Error for A {}

impl Error for B {
    fn source(&self) -> Option<&(dyn Error + 'static)> {
        self.0.as_ref().map(|e| e.as_ref())
    }
}

let b = B(Some(Box::new(A)));

// let err : Box<Error> = b.into(); // or
let err = &b as &dyn Error;

let mut iter = err.sources();

assert_eq!("B".to_string(), iter.next().unwrap().to_string());
assert_eq!("A".to_string(), iter.next().unwrap().to_string());
assert!(iter.next().is_none());
assert!(iter.next().is_none());
Source§

impl dyn Error

1.3.0 · Source

pub fn downcast<T>(self: Box<dyn Error>) -> Result<Box<T>, Box<dyn Error>>
where T: Error + 'static,

Attempts to downcast the box to a concrete type.

Source§

impl dyn Error + Send

1.3.0 · Source

pub fn downcast<T>( self: Box<dyn Error + Send>, ) -> Result<Box<T>, Box<dyn Error + Send>>
where T: Error + 'static,

Attempts to downcast the box to a concrete type.

Source§

impl dyn Error + Send + Sync

1.3.0 · Source

pub fn downcast<T>( self: Box<dyn Error + Send + Sync>, ) -> Result<Box<T>, Box<dyn Error + Send + Sync>>
where T: Error + 'static,

Attempts to downcast the box to a concrete type.

Trait Implementations§

Source§

impl Value for dyn Error

Source§

fn record(&self, key: &Field, visitor: &mut dyn Visit)

Visits this value with the given Visitor.
Source§

impl Value for dyn Error + Send

Source§

fn record(&self, key: &Field, visitor: &mut dyn Visit)

Visits this value with the given Visitor.
Source§

impl Value for dyn Error + Send + Sync

Source§

fn record(&self, key: &Field, visitor: &mut dyn Visit)

Visits this value with the given Visitor.
Source§

impl Value for dyn Error + Sync

Source§

fn record(&self, key: &Field, visitor: &mut dyn Visit)

Visits this value with the given Visitor.

Implementors§

1.65.0 · Source§

impl !Error for &str

Source§

impl Error for OpenAIError

1.8.0 · Source§

impl Error for Infallible

1.17.0 · Source§

impl Error for FromBytesWithNulError

1.86.0 · Source§

impl Error for core::slice::GetDisjointMutError

1.0.0 · Source§

impl Error for VarError

1.89.0 · Source§

impl Error for std::fs::TryLockError

1.15.0 · Source§

impl Error for std::sync::mpsc::RecvTimeoutError

1.0.0 · Source§

impl Error for std::sync::mpsc::TryRecvError

Source§

impl Error for ChatCompletionRequestMessageContentPartRefusalBuilderError

Source§

impl Error for ComputerUsePreviewArgsError

Source§

impl Error for FunctionArgsError

Source§

impl Error for WebSearchPreviewArgsError

Source§

impl Error for ParseAlphabetError

Source§

impl Error for DecodeError

Source§

impl Error for DecodeSliceError

Source§

impl Error for EncodeSliceError

Source§

impl Error for RoundingError

Source§

impl Error for crossbeam_channel::err::RecvTimeoutError

Source§

impl Error for crossbeam_channel::err::TryRecvError

Source§

impl Error for httparse::Error

Source§

impl Error for GetTimezoneError

Source§

impl Error for icu_collections::codepointtrie::error::Error

Source§

impl Error for icu_locale_core::parser::errors::ParseError

Source§

impl Error for PreferencesParseError

Source§

impl Error for json5::error::Error

Source§

impl Error for rand::distr::bernoulli::BernoulliError

Source§

impl Error for rand::distr::uniform::Error

Source§

impl Error for rand::distr::weighted::Error

Source§

impl Error for rand::distributions::bernoulli::BernoulliError

Source§

impl Error for WeightedError

Source§

impl Error for StartError

Source§

impl Error for regex_syntax::error::Error

Source§

impl Error for regex_syntax::error::Error

Source§

impl Error for regex::error::Error

Source§

impl Error for reqwest_eventsource::error::Error

Source§

impl Error for rustls_pki_types::pem::Error

Source§

impl Error for webpki::error::Error

Source§

impl Error for EarlyDataError

Source§

impl Error for EncodeError

Source§

impl Error for EncryptError

Source§

impl Error for rustls::error::Error

Source§

impl Error for VerifierBuilderError

Source§

impl Error for serde_urlencoded::ser::Error

Source§

impl Error for slab::GetDisjointMutError

Source§

impl Error for StrSimError

Source§

impl Error for strum::ParseError

Source§

impl Error for time::error::Error

Source§

impl Error for Format

Source§

impl Error for InvalidFormatDescription

Source§

impl Error for Parse

Source§

impl Error for ParseFromDescription

Source§

impl Error for TryFromParsed

Source§

impl Error for tinystr::error::ParseError

Source§

impl Error for AnyDelimiterCodecError

Source§

impl Error for LinesCodecError

Source§

impl Error for TryAcquireError

Source§

impl Error for tokio::sync::broadcast::error::RecvError

Source§

impl Error for tokio::sync::broadcast::error::TryRecvError

Source§

impl Error for ucd_trie::owned::Error

Source§

impl Error for url::parser::ParseError

Source§

impl Error for ZeroTrieBuildError

Source§

impl Error for UleError

Source§

impl Error for batch_mode_3p::mpsc::error::TryRecvError

Source§

impl Error for batch_mode_3p::oneshot::error::TryRecvError

Source§

impl Error for !

Source§

impl Error for batch_mode_3p::de::value::Error

Source§

impl Error for UnorderedKeyError

1.57.0 · Source§

impl Error for TryReserveError

1.58.0 · Source§

impl Error for FromVecWithNulError

1.7.0 · Source§

impl Error for IntoStringError

1.0.0 · Source§

impl Error for NulError

1.0.0 · Source§

impl Error for FromUtf8Error

1.0.0 · Source§

impl Error for FromUtf16Error

1.28.0 · Source§

impl Error for LayoutError

Source§

impl Error for AllocError

1.34.0 · Source§

impl Error for TryFromSliceError

1.13.0 · Source§

impl Error for BorrowError

1.13.0 · Source§

impl Error for BorrowMutError

1.34.0 · Source§

impl Error for CharTryFromError

1.20.0 · Source§

impl Error for ParseCharError

1.9.0 · Source§

impl Error for DecodeUtf16Error

1.59.0 · Source§

impl Error for TryFromCharError

1.69.0 · Source§

impl Error for FromBytesUntilNulError

1.11.0 · Source§

impl Error for core::fmt::Error

1.4.0 · Source§

impl Error for core::net::parser::AddrParseError

1.0.0 · Source§

impl Error for ParseFloatError

1.0.0 · Source§

impl Error for core::num::error::ParseIntError

1.34.0 · Source§

impl Error for core::num::error::TryFromIntError

1.0.0 · Source§

impl Error for ParseBoolError

1.0.0 · Source§

impl Error for Utf8Error

1.66.0 · Source§

impl Error for TryFromFloatSecsError

1.0.0 · Source§

impl Error for JoinPathsError

1.56.0 · Source§

impl Error for WriterPanicked

Source§

impl Error for NormalizeError

1.7.0 · Source§

impl Error for StripPrefixError

Source§

impl Error for ExitStatusError

1.0.0 · Source§

impl Error for std::sync::mpsc::RecvError

1.8.0 · Source§

impl Error for SystemTimeError

Source§

impl Error for aho_corasick::util::error::BuildError

Source§

impl Error for aho_corasick::util::error::MatchError

Source§

impl Error for aho_corasick::util::primitives::PatternIDError

Source§

impl Error for aho_corasick::util::primitives::StateIDError

Source§

impl Error for bitflags::parser::ParseError

Source§

impl Error for TryGetError

Source§

impl Error for chrono::format::ParseError

Source§

impl Error for ParseMonthError

Source§

impl Error for OutOfRange

Source§

impl Error for OutOfRangeError

Source§

impl Error for ParseWeekdayError

Source§

impl Error for clap::errors::Error

Source§

impl Error for crossbeam_channel::err::RecvError

Source§

impl Error for SelectTimeoutError

Source§

impl Error for TrySelectError

Source§

impl Error for deranged::ParseIntError

Source§

impl Error for deranged::TryFromIntError

Source§

impl Error for UninitializedFieldError

Source§

impl Error for env_filter::parser::ParseError

Source§

impl Error for futures_channel::mpsc::SendError

Source§

impl Error for futures_channel::mpsc::TryRecvError

Source§

impl Error for Canceled

Source§

impl Error for EnterError

Source§

impl Error for SpawnError

Source§

impl Error for Aborted

Source§

impl Error for getrandom::error::Error

Source§

impl Error for getrandom::error::Error

Source§

impl Error for LengthLimitError

Source§

impl Error for http::error::Error

Source§

impl Error for MaxSizeReached

Source§

impl Error for InvalidHeaderName

Source§

impl Error for InvalidHeaderValue

Source§

impl Error for ToStrError

Source§

impl Error for InvalidMethod

Source§

impl Error for InvalidStatusCode

Source§

impl Error for InvalidUri

Source§

impl Error for InvalidUriParts

Source§

impl Error for hyper_util::client::legacy::client::Error

Source§

impl Error for InvalidNameError

Source§

impl Error for hyper::error::Error

Source§

impl Error for DataError

Source§

impl Error for Errors

Source§

impl Error for PrefixLenError

Source§

impl Error for ipnet::parser::AddrParseError

Source§

impl Error for CapacityOverflowError

Source§

impl Error for iri_string::normalize::error::Error

Source§

impl Error for iri_string::template::error::Error

Source§

impl Error for iri_string::validate::Error

Source§

impl Error for jiff::error::Error

Source§

impl Error for log::ParseLevelError

Source§

impl Error for SetLoggerError

Source§

impl Error for FromStrError

Source§

impl Error for Empty

Source§

impl Error for ReadError

Source§

impl Error for rand_core::error::Error

Source§

impl Error for OsError

Source§

impl Error for regex_automata::dfa::onepass::BuildError

Source§

impl Error for regex_automata::error::Error

Source§

impl Error for regex_automata::hybrid::error::BuildError

Source§

impl Error for CacheError

Source§

impl Error for regex_automata::meta::error::BuildError

Source§

impl Error for regex_automata::nfa::thompson::error::BuildError

Source§

impl Error for GroupInfoError

Source§

impl Error for UnicodeWordBoundaryError

Source§

impl Error for regex_automata::util::primitives::PatternIDError

Source§

impl Error for SmallIndexError

Source§

impl Error for regex_automata::util::primitives::StateIDError

Source§

impl Error for regex_automata::util::search::MatchError

Source§

impl Error for PatternSetInsertError

Source§

impl Error for DeserializeError

Source§

impl Error for SerializeError

Source§

impl Error for regex_syntax::ast::Error

Source§

impl Error for regex_syntax::ast::Error

Source§

impl Error for regex_syntax::hir::Error

Source§

impl Error for regex_syntax::hir::Error

Source§

impl Error for regex_syntax::unicode::CaseFoldError

Source§

impl Error for regex_syntax::unicode::CaseFoldError

Source§

impl Error for regex_syntax::unicode::UnicodeWordError

Source§

impl Error for regex_syntax::unicode::UnicodeWordError

Source§

impl Error for CannotCloneRequestError

Source§

impl Error for reqwest::error::Error

Source§

impl Error for Errno

Source§

impl Error for rustls_native_certs::Error

Source§

impl Error for rustls_pki_types::server_name::AddrParseError

Source§

impl Error for InvalidDnsNameError

Source§

impl Error for UnsupportedOperationError

Source§

impl Error for OtherError

Source§

impl Error for serde_json::error::Error

Source§

impl Error for PathPersistError

Source§

impl Error for ComponentRange

Source§

impl Error for ConversionRange

Source§

impl Error for DifferentVariant

Source§

impl Error for InvalidVariant

Source§

impl Error for tokio_stream::stream_ext::timeout::Elapsed

Source§

impl Error for LengthDelimitedCodecError

Source§

impl Error for tokio::net::tcp::split_owned::ReuniteError

Source§

impl Error for tokio::net::unix::split_owned::ReuniteError

Source§

impl Error for TryCurrentError

Source§

impl Error for JoinError

Source§

impl Error for AcquireError

Source§

impl Error for tokio::sync::mutex::TryLockError

Source§

impl Error for tokio::sync::watch::error::RecvError

Source§

impl Error for tokio::time::error::Elapsed

Source§

impl Error for tokio::time::error::Error

Source§

impl Error for tower::timeout::error::Elapsed

Source§

impl Error for None

Source§

impl Error for InitError

Source§

impl Error for SetGlobalDefaultError

Source§

impl Error for tracing_core::metadata::ParseLevelError

Source§

impl Error for ParseLevelFilterError

Source§

impl Error for tracing_subscriber::filter::directive::ParseError

Source§

impl Error for BadName

Source§

impl Error for FromEnvError

Source§

impl Error for tracing_subscriber::reload::Error

Source§

impl Error for TryInitError

Source§

impl Error for uuid::error::Error

1.0.0 · Source§

impl Error for batch_mode_3p::io::Error

Source§

impl Error for batch_mode_3p::oneshot::error::RecvError

1.26.0 · Source§

impl Error for AccessError

Source§

impl<'a, K, V> Error for alloc::collections::btree::map::entry::OccupiedError<'a, K, V>
where K: Debug + Ord, V: Debug,

Source§

impl<'a, K, V> Error for std::collections::hash::map::OccupiedError<'a, K, V>
where K: Debug, V: Debug,

1.51.0 · Source§

impl<'a, T> Error for &'a T
where T: Error + ?Sized,

Source§

impl<A, S, V> Error for ConvertError<A, S, V>
where A: Display + Debug, S: Display + Debug, V: Display + Debug,

Source§

impl<E> Error for backoff::error::Error<E>
where E: Error,

Source§

impl<E> Error for EventStreamError<E>
where E: Display + Debug + Send + Sync,

Source§

impl<E> Error for Err<E>
where E: Debug,

1.8.0 · Source§

impl<E> Error for Box<E>
where E: Error,

Source§

impl<F> Error for PersistError<F>

Source§

impl<I> Error for nom::error::Error<I>
where I: Debug + Display,

Source§

impl<I> Error for VerboseError<I>
where I: Debug + Display,

Source§

impl<R> Error for ErrorVariant<R>

Source§

impl<R> Error for pest::error::Error<R>
where Error<R>: Debug + Display,

Source§

impl<Src, Dst> Error for AlignmentError<Src, Dst>
where Src: Deref, Dst: KnownLayout + ?Sized,

Source§

impl<Src, Dst> Error for SizeError<Src, Dst>
where Src: Deref, Dst: KnownLayout + ?Sized,

Source§

impl<Src, Dst> Error for ValidityError<Src, Dst>
where Src: Deref, Dst: KnownLayout + TryFromBytes + ?Sized,

Source§

impl<T> Error for batch_mode_3p::TrySendError<T>

Source§

impl<T> Error for std::sync::mpmc::error::SendTimeoutError<T>

1.0.0 · Source§

impl<T> Error for std::sync::mpsc::TrySendError<T>

1.0.0 · Source§

impl<T> Error for std::sync::poison::TryLockError<T>

Source§

impl<T> Error for crossbeam_channel::err::SendTimeoutError<T>
where T: Send,

Source§

impl<T> Error for crossbeam_channel::err::TrySendError<T>
where T: Send,

Source§

impl<T> Error for SetError<T>
where T: Debug,

Source§

impl<T> Error for batch_mode_3p::mpsc::error::SendTimeoutError<T>

Source§

impl<T> Error for ThinBox<T>
where T: Error + ?Sized,

1.0.0 · Source§

impl<T> Error for std::sync::mpsc::SendError<T>

1.0.0 · Source§

impl<T> Error for PoisonError<T>

Source§

impl<T> Error for crossbeam_channel::err::SendError<T>
where T: Send,

Source§

impl<T> Error for futures_channel::mpsc::TrySendError<T>
where T: Any,

Source§

impl<T> Error for futures_util::io::split::ReuniteError<T>
where T: Any,

Source§

impl<T> Error for iri_string::template::error::CreationError<T>
where T: Debug,

Source§

impl<T> Error for iri_string::types::generic::error::CreationError<T>
where T: Debug,

Source§

impl<T> Error for PollSendError<T>
where T: Debug,

Source§

impl<T> Error for tokio::sync::broadcast::error::SendError<T>
where T: Debug,

Source§

impl<T> Error for tokio::sync::watch::error::SendError<T>

Source§

impl<T> Error for AsyncFdTryNewError<T>

Source§

impl<T> Error for batch_mode_3p::mpsc::error::SendError<T>

1.52.0 · Source§

impl<T> Error for Arc<T>
where T: Error + ?Sized,

Source§

impl<T, E> Error for TryChunksError<T, E>
where E: Debug + Display,

Source§

impl<T, E> Error for TryReadyChunksError<T, E>
where E: Debug + Display,

Source§

impl<T, Item> Error for futures_util::stream::stream::split::ReuniteError<T, Item>
where T: Any,

1.0.0 · Source§

impl<W> Error for IntoInnerError<W>
where W: Send + Debug,