pub trait TryFrom<T>: Sized {
type Error;
// Required method
fn try_from(value: T) -> Result<Self, Self::Error>;
}
Expand description
Simple and safe type conversions that may fail in a controlled
way under some circumstances. It is the reciprocal of TryInto
.
This is useful when you are doing a type conversion that may
trivially succeed but may also need special handling.
For example, there is no way to convert an i64
into an i32
using the From
trait, because an i64
may contain a value
that an i32
cannot represent and so the conversion would lose data.
This might be handled by truncating the i64
to an i32
or by
simply returning i32::MAX
, or by some other method. The From
trait is intended for perfect conversions, so the TryFrom
trait
informs the programmer when a type conversion could go bad and lets
them decide how to handle it.
§Generic Implementations
TryFrom<T> for U
impliesTryInto
<U> for T
try_from
is reflexive, which means thatTryFrom<T> for T
is implemented and cannot fail – the associatedError
type for callingT::try_from()
on a value of typeT
isInfallible
. When the!
type is stabilizedInfallible
and!
will be equivalent.
TryFrom<T>
can be implemented as follows:
struct GreaterThanZero(i32);
impl TryFrom<i32> for GreaterThanZero {
type Error = &'static str;
fn try_from(value: i32) -> Result<Self, Self::Error> {
if value <= 0 {
Err("GreaterThanZero only accepts values greater than zero!")
} else {
Ok(GreaterThanZero(value))
}
}
}
§Examples
As described, i32
implements TryFrom<
i64
>
:
let big_number = 1_000_000_000_000i64;
// Silently truncates `big_number`, requires detecting
// and handling the truncation after the fact.
let smaller_number = big_number as i32;
assert_eq!(smaller_number, -727379968);
// Returns an error because `big_number` is too big to
// fit in an `i32`.
let try_smaller_number = i32::try_from(big_number);
assert!(try_smaller_number.is_err());
// Returns `Ok(3)`.
let try_successful_smaller_number = i32::try_from(3);
assert!(try_successful_smaller_number.is_ok());
Required Associated Types§
Required Methods§
Object Safety§
Implementors§
source§impl TryFrom<&MaybeRelocatable> for Relocatable
impl TryFrom<&MaybeRelocatable> for Relocatable
source§impl TryFrom<&str> for Decimal
impl TryFrom<&str> for Decimal
Try to convert a &str
into a Decimal
.
Can fail if the value is out of range for Decimal
.
source§impl TryFrom<&Felt> for NonZeroFelt
impl TryFrom<&Felt> for NonZeroFelt
type Error = FeltIsZeroError
source§impl TryFrom<Error> for ComponentRange
impl TryFrom<Error> for ComponentRange
type Error = DifferentVariant
source§impl TryFrom<Error> for ConversionRange
impl TryFrom<Error> for ConversionRange
type Error = DifferentVariant
source§impl TryFrom<Error> for DifferentVariant
impl TryFrom<Error> for DifferentVariant
type Error = DifferentVariant
source§impl TryFrom<Error> for InvalidVariant
impl TryFrom<Error> for InvalidVariant
type Error = DifferentVariant
1.59.0 · source§impl TryFrom<char> for u8
impl TryFrom<char> for u8
Maps a char
with code point in U+0000..=U+00FF to a byte in 0x00..=0xFF with same value,
failing if the code point is greater than U+00FF.
See impl From<u8> for char
for details on the encoding.
type Error = TryFromCharError
1.74.0 · source§impl TryFrom<char> for u16
impl TryFrom<char> for u16
Maps a char
with code point in U+0000..=U+FFFF to a u16
in 0x0000..=0xFFFF with same value,
failing if the code point is greater than U+FFFF.
This corresponds to the UCS-2 encoding, as specified in ISO/IEC 10646:2003.
type Error = TryFromCharError
source§impl TryFrom<f32> for Decimal
impl TryFrom<f32> for Decimal
Try to convert a f32
into a Decimal
.
Can fail if the value is out of range for Decimal
.
source§impl TryFrom<f64> for Decimal
impl TryFrom<f64> for Decimal
Try to convert a f64
into a Decimal
.
Can fail if the value is out of range for Decimal
.
source§impl TryFrom<Felt> for NonZeroFelt
impl TryFrom<Felt> for NonZeroFelt
type Error = FeltIsZeroError
source§impl TryFrom<Decimal> for f32
impl TryFrom<Decimal> for f32
Try to convert a Decimal
to f32
.
Can fail if the Decimal
is out of range for f32
.
source§impl TryFrom<Decimal> for f64
impl TryFrom<Decimal> for f64
Try to convert a Decimal
to f64
.
Can fail if the Decimal
is out of range for f64
.
source§impl TryFrom<Decimal> for i8
impl TryFrom<Decimal> for i8
Try to convert a Decimal
to i8
by truncating and returning the integer component.
Can fail if the Decimal
is out of range for i8
.
source§impl TryFrom<Decimal> for i16
impl TryFrom<Decimal> for i16
Try to convert a Decimal
to i16
by truncating and returning the integer component.
Can fail if the Decimal
is out of range for i16
.
source§impl TryFrom<Decimal> for i32
impl TryFrom<Decimal> for i32
Try to convert a Decimal
to i32
by truncating and returning the integer component.
Can fail if the Decimal
is out of range for i32
.
source§impl TryFrom<Decimal> for i64
impl TryFrom<Decimal> for i64
Try to convert a Decimal
to i64
by truncating and returning the integer component.
Can fail if the Decimal
is out of range for i64
.
source§impl TryFrom<Decimal> for i128
impl TryFrom<Decimal> for i128
Try to convert a Decimal
to i128
by truncating and returning the integer component.
Can fail if the Decimal
is out of range for i128
.
source§impl TryFrom<Decimal> for isize
impl TryFrom<Decimal> for isize
Try to convert a Decimal
to isize
by truncating and returning the integer component.
Can fail if the Decimal
is out of range for isize
.
source§impl TryFrom<Decimal> for u8
impl TryFrom<Decimal> for u8
Try to convert a Decimal
to u8
by truncating and returning the integer component.
Can fail if the Decimal
is out of range for u8
.
source§impl TryFrom<Decimal> for u16
impl TryFrom<Decimal> for u16
Try to convert a Decimal
to u16
by truncating and returning the integer component.
Can fail if the Decimal
is out of range for u16
.
source§impl TryFrom<Decimal> for u32
impl TryFrom<Decimal> for u32
Try to convert a Decimal
to u32
by truncating and returning the integer component.
Can fail if the Decimal
is out of range for u32
.
source§impl TryFrom<Decimal> for u64
impl TryFrom<Decimal> for u64
Try to convert a Decimal
to u64
by truncating and returning the integer component.
Can fail if the Decimal
is out of range for u64
.
source§impl TryFrom<Decimal> for u128
impl TryFrom<Decimal> for u128
Try to convert a Decimal
to u128
by truncating and returning the integer component.
Can fail if the Decimal
is out of range for u128
.
source§impl TryFrom<Decimal> for usize
impl TryFrom<Decimal> for usize
Try to convert a Decimal
to usize
by truncating and returning the integer component.
Can fail if the Decimal
is out of range for usize
.
source§impl TryFrom<FieldElement> for u8
impl TryFrom<FieldElement> for u8
type Error = ValueOutOfRangeError
source§impl TryFrom<FieldElement> for u16
impl TryFrom<FieldElement> for u16
type Error = ValueOutOfRangeError
source§impl TryFrom<FieldElement> for u32
impl TryFrom<FieldElement> for u32
type Error = ValueOutOfRangeError
source§impl TryFrom<FieldElement> for u64
impl TryFrom<FieldElement> for u64
type Error = ValueOutOfRangeError
source§impl TryFrom<FieldElement> for u128
impl TryFrom<FieldElement> for u128
type Error = ValueOutOfRangeError
source§impl TryFrom<AffinePoint> for ProjectivePoint
impl TryFrom<AffinePoint> for ProjectivePoint
type Error = CurveError
source§impl TryFrom<OffsetDateTime> for DateTime
impl TryFrom<OffsetDateTime> for DateTime
type Error = DateTimeRangeError
source§impl<'a, T, O> TryFrom<&'a [T]> for &'a BitSlice<T, O>
impl<'a, T, O> TryFrom<&'a [T]> for &'a BitSlice<T, O>
Calls BitSlice::try_from_slice
, but returns the original Rust slice on
error instead of the failure event.
This only fails if slice.len()
exceeds BitSlice::MAX_ELTS
.
source§impl<'a, T, O> TryFrom<&'a mut [T]> for &'a mut BitSlice<T, O>
impl<'a, T, O> TryFrom<&'a mut [T]> for &'a mut BitSlice<T, O>
Calls BitSlice::try_from_slice_mut
, but returns the original Rust slice
on error instead of the failure event.
This only fails if slice.len()
exceeds BitSlice::MAX_ELTS
.
1.34.0 · source§impl<'a, T, const N: usize> TryFrom<&'a [T]> for &'a [T; N]
impl<'a, T, const N: usize> TryFrom<&'a [T]> for &'a [T; N]
Tries to create an array ref &[T; N]
from a slice ref &[T]
. Succeeds if
slice.len() == N
.
let bytes: [u8; 3] = [1, 0, 2];
let bytes_head: &[u8; 2] = <&[u8; 2]>::try_from(&bytes[0..2]).unwrap();
assert_eq!(1, u16::from_le_bytes(*bytes_head));
let bytes_tail: &[u8; 2] = bytes[1..3].try_into().unwrap();
assert_eq!(512, u16::from_le_bytes(*bytes_tail));
type Error = TryFromSliceError
1.34.0 · source§impl<'a, T, const N: usize> TryFrom<&'a mut [T]> for &'a mut [T; N]
impl<'a, T, const N: usize> TryFrom<&'a mut [T]> for &'a mut [T; N]
Tries to create a mutable array ref &mut [T; N]
from a mutable slice ref
&mut [T]
. Succeeds if slice.len() == N
.
let mut bytes: [u8; 3] = [1, 0, 2];
let bytes_head: &mut [u8; 2] = <&mut [u8; 2]>::try_from(&mut bytes[0..2]).unwrap();
assert_eq!(1, u16::from_le_bytes(*bytes_head));
let bytes_tail: &mut [u8; 2] = (&mut bytes[1..3]).try_into().unwrap();
assert_eq!(512, u16::from_le_bytes(*bytes_tail));
type Error = TryFromSliceError
source§impl<'a, const CAP: usize> TryFrom<&'a str> for ArrayString<CAP>
impl<'a, const CAP: usize> TryFrom<&'a str> for ArrayString<CAP>
type Error = CapacityError<&'a str>
source§impl<'a, const CAP: usize> TryFrom<Arguments<'a>> for ArrayString<CAP>
impl<'a, const CAP: usize> TryFrom<Arguments<'a>> for ArrayString<CAP>
type Error = CapacityError<Error>
source§impl<A, O> TryFrom<&BitSlice<<A as BitView>::Store, O>> for &BitArray<A, O>where
A: BitViewSized,
O: BitOrder,
impl<A, O> TryFrom<&BitSlice<<A as BitView>::Store, O>> for &BitArray<A, O>where
A: BitViewSized,
O: BitOrder,
source§impl<A, O> TryFrom<&BitSlice<<A as BitView>::Store, O>> for BitArray<A, O>where
A: BitViewSized,
O: BitOrder,
impl<A, O> TryFrom<&BitSlice<<A as BitView>::Store, O>> for BitArray<A, O>where
A: BitViewSized,
O: BitOrder,
source§impl<A, O> TryFrom<&mut BitSlice<<A as BitView>::Store, O>> for &mut BitArray<A, O>where
A: BitViewSized,
O: BitOrder,
impl<A, O> TryFrom<&mut BitSlice<<A as BitView>::Store, O>> for &mut BitArray<A, O>where
A: BitViewSized,
O: BitOrder,
1.43.0 · source§impl<T, A, const N: usize> TryFrom<Arc<[T], A>> for Arc<[T; N], A>where
A: Allocator,
impl<T, A, const N: usize> TryFrom<Arc<[T], A>> for Arc<[T; N], A>where
A: Allocator,
source§impl<T, A, const N: usize> TryFrom<Box<[T], A>> for allocator_api2::stable::boxed::Box<[T; N], A>where
A: Allocator,
impl<T, A, const N: usize> TryFrom<Box<[T], A>> for allocator_api2::stable::boxed::Box<[T; N], A>where
A: Allocator,
source§impl<T, const CAP: usize> TryFrom<&[T]> for ArrayVec<T, CAP>where
T: Clone,
impl<T, const CAP: usize> TryFrom<&[T]> for ArrayVec<T, CAP>where
T: Clone,
Try to create an ArrayVec
from a slice. This will return an error if the slice was too big to
fit.
use arrayvec::ArrayVec;
use std::convert::TryInto as _;
let array: ArrayVec<_, 4> = (&[1, 2, 3] as &[_]).try_into().unwrap();
assert_eq!(array.len(), 3);
assert_eq!(array.capacity(), 4);
type Error = CapacityError
1.34.0 · source§impl<T, const N: usize> TryFrom<&[T]> for [T; N]where
T: Copy,
impl<T, const N: usize> TryFrom<&[T]> for [T; N]where
T: Copy,
Tries to create an array [T; N]
by copying from a slice &[T]
. Succeeds if
slice.len() == N
.
let bytes: [u8; 3] = [1, 0, 2];
let bytes_head: [u8; 2] = <[u8; 2]>::try_from(&bytes[0..2]).unwrap();
assert_eq!(1, u16::from_le_bytes(bytes_head));
let bytes_tail: [u8; 2] = bytes[1..3].try_into().unwrap();
assert_eq!(512, u16::from_le_bytes(bytes_tail));
type Error = TryFromSliceError
1.59.0 · source§impl<T, const N: usize> TryFrom<&mut [T]> for [T; N]where
T: Copy,
impl<T, const N: usize> TryFrom<&mut [T]> for [T; N]where
T: Copy,
Tries to create an array [T; N]
by copying from a mutable slice &mut [T]
.
Succeeds if slice.len() == N
.
let mut bytes: [u8; 3] = [1, 0, 2];
let bytes_head: [u8; 2] = <[u8; 2]>::try_from(&mut bytes[0..2]).unwrap();
assert_eq!(1, u16::from_le_bytes(bytes_head));
let bytes_tail: [u8; 2] = (&mut bytes[1..3]).try_into().unwrap();
assert_eq!(512, u16::from_le_bytes(bytes_tail));