pub enum Infallible {}
Expand description
The error type for errors that can never happen.
Since this enum has no variant, a value of this type can never actually exist.
This can be useful for generic APIs that use Result
and parameterize the error type,
to indicate that the result is always Ok
.
For example, the TryFrom
trait (conversion that returns a Result
)
has a blanket implementation for all types where a reverse Into
implementation exists.
impl<T, U> TryFrom<U> for T where U: Into<T> {
type Error = Infallible;
fn try_from(value: U) -> Result<Self, Infallible> {
Ok(U::into(value)) // Never returns `Err`
}
}
§Future compatibility
This enum has the same role as the !
“never” type,
which is unstable in this version of Rust.
When !
is stabilized, we plan to make Infallible
a type alias to it:
… and eventually deprecate Infallible
.
However there is one case where !
syntax can be used
before !
is stabilized as a full-fledged type: in the position of a function’s return type.
Specifically, it is possible to have implementations for two different function pointer types:
With Infallible
being an enum, this code is valid.
However when Infallible
becomes an alias for the never type,
the two impl
s will start to overlap
and therefore will be disallowed by the language’s trait coherence rules.
Trait Implementations§
1.34.0 (const: unstable) · Source§impl Clone for Infallible
impl Clone for Infallible
Source§fn clone(&self) -> Infallible
fn clone(&self) -> Infallible
1.0.0 · Source§fn clone_from(&mut self, source: &Self)where
Self:,
fn clone_from(&mut self, source: &Self)where
Self:,
source
. Read more1.34.0 · Source§impl Debug for Infallible
Available on non-crate feature ferrocene_certified
only.
impl Debug for Infallible
ferrocene_certified
only.1.34.0 · Source§impl Display for Infallible
Available on non-crate feature ferrocene_certified
only.
impl Display for Infallible
ferrocene_certified
only.1.8.0 · Source§impl Error for Infallible
Available on non-crate feature ferrocene_certified
only.
impl Error for Infallible
ferrocene_certified
only.1.30.0 · 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
1.34.0 (const: unstable) · Source§impl From<!> for Infallible
Available on non-crate feature ferrocene_certified
only.
impl From<!> for Infallible
ferrocene_certified
only.1.34.0 (const: unstable) · Source§impl From<Infallible> for TryFromIntError
Available on non-crate feature ferrocene_certified
only.
impl From<Infallible> for TryFromIntError
ferrocene_certified
only.Source§fn from(x: Infallible) -> TryFromIntError
fn from(x: Infallible) -> TryFromIntError
1.36.0 (const: unstable) · Source§impl From<Infallible> for TryFromSliceError
Available on non-crate feature ferrocene_certified
only.
impl From<Infallible> for TryFromSliceError
ferrocene_certified
only.Source§fn from(x: Infallible) -> TryFromSliceError
fn from(x: Infallible) -> TryFromSliceError
1.44.0 · Source§impl Hash for Infallible
Available on non-crate feature ferrocene_certified
only.
impl Hash for Infallible
ferrocene_certified
only.1.34.0 (const: unstable) · Source§impl Ord for Infallible
Available on non-crate feature ferrocene_certified
only.
impl Ord for Infallible
ferrocene_certified
only.1.34.0 (const: unstable) · Source§impl PartialEq for Infallible
Available on non-crate feature ferrocene_certified
only.
impl PartialEq for Infallible
ferrocene_certified
only.1.34.0 (const: unstable) · Source§impl PartialOrd for Infallible
Available on non-crate feature ferrocene_certified
only.
impl PartialOrd for Infallible
ferrocene_certified
only.impl Copy for Infallible
impl Eq for Infallible
ferrocene_certified
only.Auto Trait Implementations§
impl Freeze for Infallible
impl RefUnwindSafe for Infallible
impl Send for Infallible
impl Sync for Infallible
impl Unpin for Infallible
impl UnwindSafe for Infallible
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
ferrocene_certified
only.