AsInitialized

Enum AsInitialized 

Source
pub enum AsInitialized {}
Expand description

The byte ranges initialized in T are also initialized in the referent of a Ptr<T>.

Formally: uninitialized bytes may only be present in Ptr<T>’s referent where they are guaranteed to be present in T. This is a dynamic property: if, at a particular byte offset, a valid enum discriminant is set, the subsequent bytes may only have uninitialized bytes as specified by the corresponding enum.

Formally, given len = size_of_val_raw(ptr), at every byte offset, b, in the range [0, len):

  • If, in any instance t: T of length len, the byte at offset b in t is initialized, then the byte at offset b within *ptr must be initialized.

  • Let c be the contents of the byte range [0, b) in *ptr. Let S be the subset of valid instances of T of length len which contain c in the offset range [0, b). If, in any instance of t: T in S, the byte at offset b in t is initialized, then the byte at offset b in *ptr must be initialized.

    Pragmatically, this means that if *ptr is guaranteed to contain an enum type at a particular offset, and the enum discriminant stored in *ptr corresponds to a valid variant of that enum type, then it is guaranteed that the appropriate bytes of *ptr are initialized as defined by that variant’s bit validity (although note that the variant may contain another enum type, in which case the same rules apply depending on the state of its discriminant, and so on recursively).

Trait Implementations§

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> SizedTypeProperties for T

Source§

#[doc(hidden)] const SIZE: usize = _

🔬This is a nightly-only experimental API. (sized_type_properties)
Source§

#[doc(hidden)] const ALIGN: usize = _

🔬This is a nightly-only experimental API. (sized_type_properties)
Source§

#[doc(hidden)] const IS_ZST: bool = _

🔬This is a nightly-only experimental API. (sized_type_properties)
true if this type requires no storage. false if its size is greater than zero. Read more
Source§

#[doc(hidden)] const LAYOUT: Layout = _

🔬This is a nightly-only experimental API. (sized_type_properties)
Source§

#[doc(hidden)] const MAX_SLICE_LEN: usize = _

🔬This is a nightly-only experimental API. (sized_type_properties)
The largest safe length for a [Self]. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<T> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,