rustc_middle::ty

Type Alias TraitRef

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

Aliased Type§

struct TraitRef<'tcx> {
    pub def_id: DefId,
    pub args: &'tcx RawList<(), GenericArg<'tcx>>,
    /* private fields */
}

Fields§

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

Implementations

§

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

pub fn new_from_args( interner: I, trait_def_id: <I as Interner>::DefId, args: <I as Interner>::GenericArgs, ) -> TraitRef<I>

pub fn new( interner: I, trait_def_id: <I as Interner>::DefId, args: impl IntoIterator>, ) -> TraitRef<I>

pub fn from_method( interner: I, trait_id: <I as Interner>::DefId, args: <I as Interner>::GenericArgs, ) -> TraitRef<I>

pub fn identity(interner: I, def_id: <I as Interner>::DefId) -> TraitRef<I>

Returns a TraitRef of the form P0: Foo<P1..Pn> where Pi are the parameters defined on trait.

pub fn with_self_ty( self, interner: I, self_ty: <I as Interner>::Ty, ) -> TraitRef<I>

pub fn self_ty(&self) -> <I as Interner>::Ty

Trait Implementations§

Source§

impl<'tcx> EraseType for TraitRef<'tcx>

Source§

type Result = [u8; 16]

Source§

impl<'tcx> Key for TraitRef<'tcx>

Source§

type Cache<V> = DefaultCache<TraitRef<TyCtxt<'tcx>>, V>

Source§

fn default_span(&self, tcx: TyCtxt<'_>) -> Span

In the event that a cycle occurs, if no explicit span has been given for a query with key self, what span should we use?
Source§

fn key_as_def_id(&self) -> Option<DefId>

If the key is a DefId or DefId–equivalent, return that DefId. Otherwise, return None.
Source§

fn ty_def_id(&self) -> Option<DefId>

Source§

impl ParameterizedOverTcx for TraitRef<'static>

Source§

type Value<'tcx> = TraitRef<TyCtxt<'tcx>>

Source§

impl<'tcx, P: PrettyPrinter<'tcx>> Print<'tcx, P> for TraitRef<'tcx>

Source§

impl<'tcx> PrintTraitRefExt<'tcx> for TraitRef<'tcx>

§

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

§

fn clone(&self) -> TraitRef<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 TraitRef<I>
where I: Interner,

§

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

Formats the value using the given formatter. Read more
§

impl<I, __D> Decodable<__D> for TraitRef<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) -> TraitRef<I>

§

impl<I> Display for TraitRef<I>
where I: Interner,

§

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

Formats the value using the given formatter. Read more
§

impl<I, __E> Encodable<__E> for TraitRef<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 TraitRef<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 TraitRef<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 TraitRef<I>
where I: Interner,

§

impl<I, J> Lift<J> for TraitRef<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>, (): Lift<J, Lifted = ()>,

§

type Lifted = TraitRef<J>

§

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

§

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

§

fn eq(&self, __other: &TraitRef<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> Relate<I> for TraitRef<I>
where I: Interner,

§

fn relate<R>( relation: &mut R, a: TraitRef<I>, b: TraitRef<I>, ) -> Result<TraitRef<I>, TypeError<I>>
where R: TypeRelation<I>,

§

impl<I> TypeFoldable<I> for TraitRef<I>

§

fn try_fold_with<__F>( self, __folder: &mut __F, ) -> Result<TraitRef<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 TraitRef<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 TraitRef<I>
where I: Interner,

§

impl<I> Eq for TraitRef<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