Enum core::convert::Infallible  
1.34.0 · source · [−]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`
    }
}RunFuture 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:
trait MyTrait {}
impl MyTrait for fn() -> ! {}
impl MyTrait for fn() -> std::convert::Infallible {}RunWith Infallible being an enum, this code is valid.
However when Infallible becomes an alias for the never type,
the two impls will start to overlap
and therefore will be disallowed by the language’s trait coherence rules.
Trait Implementations
const: unstable · sourceimpl Clone for Infallible
 
impl Clone for Infallible
const: unstable · sourcefn clone(&self) -> Infallible
 
fn clone(&self) -> Infallible
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
source. Read moresourceimpl Debug for Infallible
 
impl Debug for Infallible
sourceimpl Display for Infallible
 
impl Display for Infallible
1.8.0 · sourceimpl Error for Infallible
 
impl Error for Infallible
sourcefn description(&self) -> &str
 
fn description(&self) -> &str
1.30.0 · sourcefn source(&self) -> Option<&(dyn Error + 'static)>
 
fn source(&self) -> Option<&(dyn Error + 'static)>
const: unstable · sourceimpl From<!> for Infallible
 
impl From<!> for Infallible
const: unstable · sourceimpl From<Infallible> for TryFromIntError
 
impl From<Infallible> for TryFromIntError
const: unstable · sourcefn from(x: Infallible) -> TryFromIntError
 
fn from(x: Infallible) -> TryFromIntError
1.36.0 (const: unstable) · sourceimpl From<Infallible> for TryFromSliceError
 
impl From<Infallible> for TryFromSliceError
const: unstable · sourcefn from(x: Infallible) -> TryFromSliceError
 
fn from(x: Infallible) -> TryFromSliceError
1.44.0 · sourceimpl Hash for Infallible
 
impl Hash for Infallible
sourceimpl Ord for Infallible
 
impl Ord for Infallible
1.21.0 · sourcefn max(self, other: Self) -> Selfwhere
    Self: Sized,
 
fn max(self, other: Self) -> Selfwhere
    Self: Sized,
1.21.0 · sourcefn min(self, other: Self) -> Selfwhere
    Self: Sized,
 
fn min(self, other: Self) -> Selfwhere
    Self: Sized,
1.50.0 · sourcefn clamp(self, min: Self, max: Self) -> Selfwhere
    Self: Sized,
    Self: PartialOrd,
 
fn clamp(self, min: Self, max: Self) -> Selfwhere
    Self: Sized,
    Self: PartialOrd,
sourceimpl PartialEq<Infallible> for Infallible
 
impl PartialEq<Infallible> for Infallible
sourcefn eq(&self, _: &Infallible) -> bool
 
fn eq(&self, _: &Infallible) -> bool
sourceimpl PartialOrd<Infallible> for Infallible
 
impl PartialOrd<Infallible> for Infallible
sourcefn partial_cmp(&self, _other: &Self) -> Option<Ordering>
 
fn partial_cmp(&self, _other: &Self) -> Option<Ordering>
1.0.0 · sourcefn le(&self, other: &Rhs) -> bool
 
fn le(&self, other: &Rhs) -> bool
self and other) and is used by the <=
operator. Read more