void::coreprovider::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");

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.

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.

Implementors§

1.65.0 · Source§

impl !Error for &str

Source§

impl Error for Void

1.8.0 · Source§

impl Error for Infallible

Source§

impl Error for GetManyMutError

1.0.0 · Source§

impl Error for VarError

1.15.0 · Source§

impl Error for RecvTimeoutError

1.0.0 · Source§

impl Error for TryRecvError

Source§

impl Error for !

1.11.0 · Source§

impl Error for void::coreprovider::fmt::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.17.0 · Source§

impl Error for FromBytesWithNulError

1.4.0 · Source§

impl Error for AddrParseError

1.0.0 · Source§

impl Error for ParseFloatError

1.0.0 · Source§

impl Error for ParseIntError

1.34.0 · Source§

impl Error for 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

1.0.0 · Source§

impl Error for std::io::error::Error

1.7.0 · Source§

impl Error for StripPrefixError

Source§

impl Error for ExitStatusError

1.0.0 · Source§

impl Error for RecvError

1.26.0 · Source§

impl Error for AccessError

1.8.0 · Source§

impl Error for SystemTimeError

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,

1.8.0 · Source§

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

Source§

impl<T> Error for SendTimeoutError<T>

1.0.0 · Source§

impl<T> Error for TrySendError<T>

1.0.0 · Source§

impl<T> Error for TryLockError<T>

Source§

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

1.52.0 · Source§

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

1.0.0 · Source§

impl<T> Error for SendError<T>

1.0.0 · Source§

impl<T> Error for PoisonError<T>

1.0.0 · Source§

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

impl Error for BuildError

impl Error for MatchError

impl Error for AllocError

impl<T: Error> Error for Box<T>

impl Error for Error

impl<T: Any> Error for CapacityError<T>

impl Error for Result

impl Error for ErrorKind

impl Error for ParseError

impl Error for Error

impl Error for Error

impl Error for PingError

impl<T> Error for InsertError<T>
where Self: Debug + Display,

impl Error for Error

impl Error for ParseError

impl Error for OutOfRange

impl Error for Error

impl Error for ParseError

impl Error for RecvError

impl<T: Send> Error for SendTimeoutError<T>

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

impl<T: Send> Error for SendError<T>

impl<'i, E: Display + Debug> Error for ParseError<'i, E>

impl Error for ParseError

impl Error for Error

impl<E: Error> Error for DecodeError<E>

impl Error for DlError

impl Error for LoadError

impl<L, R> Error for Either<L, R>
where L: Error, R: Error,

impl Error for ParseError

impl Error for Error

impl Error for SendError

impl Error for Canceled

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

impl Error for EnterError

impl Error for SpawnError

impl Error for Aborted

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

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

impl<T: Any> Error for ReuniteError<T>

impl<T: Any> Error for ReuniteError<T>

impl<T: Any, Item> Error for ReuniteError<T, Item>

impl Error for Fail

impl Error for Error

impl Error for Error

impl Error for Error

impl Error for Error

impl Error for Error

impl Error for Error

impl Error for CvtError

impl Error for GStrError

impl Error for IConvError

impl Error for BoolError

impl Error for Error

impl Error for JoinError

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

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

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

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

impl Error for MapError

impl Error for ClockError

impl Error for FlowError

impl Error for TagError

impl Error for FlowError

impl<E> Error for GetError<E>
where E: Error + 'static + Error, Self: Debug + Display,

impl Error for SendError

impl Error for UserError

impl Error for Error

impl Error for Error

impl Error for ToStrError

impl Error for Error

impl Error for InvalidUri

impl Error for Error

impl Error for Error

impl Error for TimedOut

impl Error for NotEof

impl Error for Error

impl Error for Error

impl Error for Errors

impl Error for ImageError

impl Error for Error

impl Error for LimitError

impl Error for IpcError

impl Error for UnixError

impl<I> Error for ExactlyOneError<I>
where I: Iterator + Debug, I::Item: Debug,

impl Error for AdhocError

impl Error for IOError

impl Error for RangeError

impl Error for Error

impl Error for Error

impl Error for Error

impl<L: Error + 'static> Error for LoadError<L>

impl Error for Error

impl Error for ParseError

impl Error for ParseError

impl Error for Error

impl Error for Error

impl Error for CallError

impl Error for TypeError

impl Error for WidthError

impl Error for BadHandle

impl Error for ParseError

impl<E> Error for ShaderError<E>
where ShaderError<E>: Display, E: Error + 'static,

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

impl Error for Errno

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

impl<I: Debug + Display> Error for Error<I>

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

impl<E: Error> Error for ParseComplexError<E>

impl Error for Error

impl Error for Error

impl Error for LexError

impl Error for Error

impl Error for Error

impl Error for Error

impl Error for AttrError

impl Error for EmptySlice

impl Error for ReadError

impl Error for ErrorCode

impl Error for Error

impl Error for Error

impl Error for StartError

impl Error for RetryError

impl Error for BuildError

impl Error for BuildError

impl Error for CacheError

impl Error for BuildError

impl Error for BuildError

impl Error for MatchError

impl Error for Error

impl Error for Error

impl Error for Error

impl Error for Error

impl Error for Errno

impl Error for Error

impl Error for OtherError

impl Error for Error

impl Error for Error

impl Error for Error

impl Error for Error

impl Error for Error

impl Error for Error

impl Error for SeatError

impl Error for PoolError

impl<K> Error for BufferSlot<K>
where Self: Debug + Display,

impl Error for Error

impl Error for Error

impl Error for ParseError

impl Error for Error

impl Error for PathError

impl<F> Error for PersistError<F>

impl Error for TiffError

impl Error for Error

impl Error for Format

impl Error for Parse

impl Error for RecvError

impl Error for RecvError

impl Error for RecvError

impl Error for JoinError

impl Error for Elapsed

impl Error for Error

impl<T> Error for SendTimeoutError<T>

impl<T> Error for TrySendError<T>

impl<T> Error for AsyncFdTryNewError<T>

impl<T> Error for SendError<T>

impl<T> Error for SendError<T>

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

impl<T: Debug> Error for SendError<T>

impl Error for Elapsed

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

impl Error for Error

impl Error for Error

impl Error for TomlError

impl Error for Error

impl Error for TlsError

impl Error for UrlError

impl<Role: HandshakeRole> Error for HandshakeError<Role>

impl Error for ParseError

impl<'a> Error for BufReadDecoderError<'a>

impl<'a> Error for DecodeError<'a>

impl Error for Error

impl Error for Error

impl Error for SseError

impl Error for Error

impl Error for WsError

impl Error for InitError

impl Error for WEnumError

impl Error for InvalidId

impl Error for InvalidId

impl Error for BindError

impl Error for Error

impl Error for Error

impl Error for LzwError

impl Error for BindError

impl Error for ClearError

impl Error for CopyError

impl Error for DrawError

impl Error for QueryError

impl Error for InputError

impl Error for StageError

impl Error for MultiError

impl Error for PollError

impl Error for BadImage

impl Error for BadIcon

impl Error for X11Error

impl Error for OsError

impl Error for XError

impl<T: Debug> Error for EventLoopClosed<T>

impl<I: Clone + Debug + Display + Sync + Send + 'static> Error for InputError<I>

impl<I: Debug + Display + Sync + Send + 'static, C: Display + Debug> Error for TreeError<I, C>

impl Error for OpenError

impl Error for ReplyError

impl Error for ParseError