Enum std::convert::Infallible
pub enum Infallible {}
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:
pub type Infallible = !;
… 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 implementations for two different function pointer types:
trait MyTrait {} impl MyTrait for fn() -> ! {} impl MyTrait for fn() -> std::convert::Infallible {}
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
impl Clone for Infallible
pub fn clone(&self) -> Infallible
Returns a copy of the value. Read more
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
impl Debug for Infallible
pub fn fmt(&self, &mut Formatter<'_>) -> Result<(), Error>
Formats the value using the given formatter. Read more
impl Display for Infallible
pub fn fmt(&self, &mut Formatter<'_>) -> Result<(), Error>
Formats the value using the given formatter. Read more
impl Error for Infallible
fn description(&self) -> &str
use the Display impl or to_string()
fn source(&self) -> Option<&(dyn Error + 'static)>
The lower-level source of this error, if any. Read more
fn backtrace(&self) -> Option<&Backtrace>
Returns a stack backtrace, if available, of where this error occurred. Read more
fn cause(&self) -> Option<&dyn Error>
replaced by Error::source, which can support downcasting
impl From<!> for Infallible
pub fn from(x: !) -> Infallible
Performs the conversion.
impl From<Infallible> for TryFromSliceError
pub fn from(x: Infallible) -> TryFromSliceError
Performs the conversion.
impl From<Infallible> for TryFromIntError
pub fn from(x: Infallible) -> TryFromIntError
Performs the conversion.
impl Hash for Infallible
impl Ord for Infallible
pub fn cmp(&self, _other: &Infallible) -> Ordering
fn max(self, other: Self) -> Self
Compares and returns the maximum of two values. Read more
fn min(self, other: Self) -> Self
Compares and returns the minimum of two values. Read more
fn clamp(self, min: Self, max: Self) -> Self
Restrict a value to a certain interval. Read more
impl PartialEq<Infallible> for Infallible
pub fn eq(&self, &Infallible) -> bool
This method tests for self
and other
values to be equal, and is used by ==
. Read more
fn ne(&self, other: &Rhs) -> bool
This method tests for !=
.
impl PartialOrd<Infallible> for Infallible
pub fn partial_cmp(&self, _other: &Infallible) -> Option<Ordering>
This method returns an ordering between self
and other
values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool
This method tests less than (for self
and other
) and is used by the <
operator. Read more
fn le(&self, other: &Rhs) -> bool
This method tests less than or equal to (for self
and other
) and is used by the <=
operator. Read more
fn gt(&self, other: &Rhs) -> bool
This method tests greater than (for self
and other
) and is used by the >
operator. Read more
fn ge(&self, other: &Rhs) -> bool
This method tests greater than or equal to (for self
and other
) and is used by the >=
operator. Read more
impl Copy for Infallible
impl Eq for Infallible
Auto Trait Implementations
impl RefUnwindSafe for Infallible
impl Send for Infallible
impl Sync for Infallible
impl Unpin for Infallible
impl UnwindSafe for Infallible
Blanket Implementations
impl<T> From<!> for T
pub fn from(t: !) -> T
Performs the conversion.
impl<T> From<T> for T
pub fn from(t: T) -> T
Performs the conversion.
pub fn into(self) -> U
Performs the conversion.
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
Creates owned data from borrowed data, usually by cloning. Read more
pub fn clone_into(&self, target: &mut T)
toowned_clone_into
#41263)recently added
Uses borrowed data to replace owned data, usually by cloning. Read more
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
Performs the conversion.
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
Performs the conversion.
© 2010 The Rust Project Developers
Licensed under the Apache License, Version 2.0 or the MIT license, at your option.
https://doc.rust-lang.org/std/convert/enum.Infallible.html