rustc_middle::ty

Type Alias UnevaluatedConst

Source
pub type UnevaluatedConst<'tcx> = UnevaluatedConst<TyCtxt<'tcx>>;

Aliased Type§

struct UnevaluatedConst<'tcx> {
    pub def: DefId,
    pub args: &'tcx RawList<(), GenericArg<'tcx>>,
}

Fields§

§def: DefId§args: &'tcx RawList<(), GenericArg<'tcx>>

Implementations

§

impl<I> UnevaluatedConst<I>
where I: Interner,

pub fn new( def: <I as Interner>::DefId, args: <I as Interner>::GenericArgs, ) -> UnevaluatedConst<I>

Trait Implementations§

Source§

impl<'tcx> EraseType for UnevaluatedConst<'tcx>

Source§

type Result = [u8; 16]

Source§

impl<'tcx> UnevaluatedConstEvalExt<'tcx> for UnevaluatedConst<'tcx>

Source§

fn prepare_for_eval( self, tcx: TyCtxt<'tcx>, param_env: ParamEnv<'tcx>, ) -> (ParamEnv<'tcx>, Self)

FIXME(RalfJung): I cannot explain what this does or why it makes sense, but not doing this hurts performance.

§

impl<I> Clone for UnevaluatedConst<I>
where I: Interner,

§

fn clone(&self) -> UnevaluatedConst<I>

Returns a copy of the value. Read more
Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
§

impl<I> Debug for UnevaluatedConst<I>
where I: Interner,

§

fn fmt(&self, __f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
§

impl<I, __D> Decodable<__D> for UnevaluatedConst<I>
where I: Interner, __D: TyDecoder<I = I>, <I as Interner>::DefId: Decodable<__D>, <I as Interner>::GenericArgs: Decodable<__D>,

§

fn decode(__decoder: &mut __D) -> UnevaluatedConst<I>

§

impl<I, __E> Encodable<__E> for UnevaluatedConst<I>
where I: Interner, __E: TyEncoder<I = I>, <I as Interner>::DefId: Encodable<__E>, <I as Interner>::GenericArgs: Encodable<__E>,

§

fn encode(&self, __encoder: &mut __E)

§

impl<I> Hash for UnevaluatedConst<I>
where I: Interner,

§

fn hash<__H>(&self, __state: &mut __H)
where __H: Hasher,

Feeds this value into the given Hasher. Read more
Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
§

impl<I, __CTX> HashStable<__CTX> for UnevaluatedConst<I>
where I: Interner, <I as Interner>::DefId: HashStable<__CTX>, <I as Interner>::GenericArgs: HashStable<__CTX>,

§

fn hash_stable( &self, __hcx: &mut __CTX, __hasher: &mut StableHasher<SipHasher128>, )

Source§

impl<I> IntoDiagArg for UnevaluatedConst<I>
where I: Interner,

§

impl<I, J> Lift<J> for UnevaluatedConst<I>
where I: Interner, J: Interner, <I as Interner>::DefId: Lift<J, Lifted = <J as Interner>::DefId>, <I as Interner>::GenericArgs: Lift<J, Lifted = <J as Interner>::GenericArgs>,

§

type Lifted = UnevaluatedConst<J>

§

fn lift_to_interner(self, interner: J) -> Option<UnevaluatedConst<J>>

§

impl<I> PartialEq for UnevaluatedConst<I>
where I: Interner,

§

fn eq(&self, __other: &UnevaluatedConst<I>) -> bool

Tests for self and other values to be equal, and is used by ==.
Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl<I> TypeFoldable<I> for UnevaluatedConst<I>

§

fn try_fold_with<__F>( self, __folder: &mut __F, ) -> Result<UnevaluatedConst<I>, <__F as FallibleTypeFolder<I>>::Error>
where __F: FallibleTypeFolder<I>,

The entry point for folding. To fold a value t with a folder f call: t.try_fold_with(f). Read more
§

fn fold_with<F>(self, folder: &mut F) -> Self
where F: TypeFolder<I>,

A convenient alternative to try_fold_with for use with infallible folders. Do not override this method, to ensure coherence with try_fold_with.
§

impl<I> TypeVisitable<I> for UnevaluatedConst<I>

§

fn visit_with<__V>( &self, __visitor: &mut __V, ) -> <__V as TypeVisitor<I>>::Result
where __V: TypeVisitor<I>,

The entry point for visiting. To visit a value t with a visitor v call: t.visit_with(v). Read more
§

impl<I> Copy for UnevaluatedConst<I>
where I: Interner,

§

impl<I> Eq for UnevaluatedConst<I>
where I: Interner,

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 16 bytes