Enum rustc::traits::Vtable
[−]
[src]
pub enum Vtable<'tcx, N> { VtableImpl(VtableImplData<'tcx, N>), VtableDefaultImpl(VtableDefaultImplData<N>), VtableParam(Vec<N>), VtableObject(VtableObjectData<'tcx, N>), VtableBuiltin(VtableBuiltinData<N>), VtableClosure(VtableClosureData<'tcx, N>), VtableFnPointer(VtableFnPointerData<'tcx, N>), }
rustc_private
)Given the successful resolution of an obligation, the Vtable
indicates where the vtable comes from. Note that while we call this
a "vtable", it does not necessarily indicate dynamic dispatch at
runtime. Vtable
instances just tell the compiler where to find
methods, but in generic code those methods are typically statically
dispatched -- only when an object is constructed is a Vtable
instance reified into an actual vtable.
For example, the vtable may be tied to a specific impl (case A), or it may be relative to some bound that is in scope (case B).
impl<T:Clone> Clone<T> for Option<T> { ... } // Impl_1 impl<T:Clone> Clone<T> for Box<T> { ... } // Impl_2 impl Clone for int { ... } // Impl_3 fn foo<T:Clone>(concrete: Option<Box<int>>, param: T, mixed: Option<T>) { // Case A: Vtable points at a specific impl. Only possible when // type is concretely known. If the impl itself has bounded // type parameters, Vtable will carry resolutions for those as well: concrete.clone(); // Vtable(Impl_1, [Vtable(Impl_2, [Vtable(Impl_3)])]) // Case B: Vtable must be provided by caller. This applies when // type is a type parameter. param.clone(); // VtableParam // Case C: A mix of cases A and B. mixed.clone(); // Vtable(Impl_1, [VtableParam]) }
The type parameter N
See explanation on VtableImplData
.
Variants
VtableImpl(VtableImplData<'tcx, N>)
rustc_private
)Vtable identifying a particular impl.
VtableDefaultImpl(VtableDefaultImplData<N>)
rustc_private
)Vtable for default trait implementations
This carries the information and nested obligations with regards
to a default implementation for a trait Trait
. The nested obligations
ensure the trait implementation holds for all the constituent types.
VtableParam(Vec<N>)
rustc_private
)Successful resolution to an obligation provided by the caller
for some type parameter. The Vec<N>
represents the
obligations incurred from normalizing the where-clause (if
any).
VtableObject(VtableObjectData<'tcx, N>)
rustc_private
)Virtual calls through an object
VtableBuiltin(VtableBuiltinData<N>)
rustc_private
)Successful resolution for a builtin trait.
VtableClosure(VtableClosureData<'tcx, N>)
rustc_private
)Vtable automatically generated for a closure. The def ID is the ID
of the closure expression. This is a VtableImpl
in spirit, but the
impl is generated by the compiler and does not appear in the source.
VtableFnPointer(VtableFnPointerData<'tcx, N>)
rustc_private
)Same as above, but for a fn pointer type with the given signature.
Methods
impl<'tcx, N> Vtable<'tcx, N>
[src]
fn nested_obligations(self) -> Vec<N>
fn map<M, F>(self, f: F) -> Vtable<'tcx, M> where F: FnMut(N) -> M
Trait Implementations
impl<'tcx, N: Debug> Debug for Vtable<'tcx, N>
[src]
impl<'a, 'tcx> Lift<'tcx> for Vtable<'a, ()>
[src]
type Lifted = Vtable<'tcx, ()>
fn lift_to_tcx<'b, 'gcx>(&self, tcx: TyCtxt<'b, 'gcx, 'tcx>) -> Option<Self::Lifted>
impl<'tcx, N: TypeFoldable<'tcx>> TypeFoldable<'tcx> for Vtable<'tcx, N>
[src]
fn super_fold_with<'gcx: 'tcx, F: TypeFolder<'gcx, 'tcx>>(&self, folder: &mut F) -> Self
fn super_visit_with<V: TypeVisitor<'tcx>>(&self, visitor: &mut V) -> bool
fn fold_with<'gcx: 'tcx, F: TypeFolder<'gcx, 'tcx>>(&self, folder: &mut F) -> Self
fn visit_with<V: TypeVisitor<'tcx>>(&self, visitor: &mut V) -> bool
fn has_regions_escaping_depth(&self, depth: u32) -> bool
fn has_escaping_regions(&self) -> bool
fn has_type_flags(&self, flags: TypeFlags) -> bool
fn has_projection_types(&self) -> bool
fn references_error(&self) -> bool
fn has_param_types(&self) -> bool
fn has_self_ty(&self) -> bool
fn has_infer_types(&self) -> bool
fn needs_infer(&self) -> bool
fn needs_subst(&self) -> bool
fn has_closure_types(&self) -> bool
fn has_erasable_regions(&self) -> bool
fn is_global(&self) -> bool
Indicates whether this value references only 'global' types/lifetimes that are the same regardless of what fn we are in. This is used for caching. Errs on the side of returning false. Read more
Derived Implementations
impl<'tcx, N: Clone> Clone for Vtable<'tcx, N>
[src]
fn clone(&self) -> Vtable<'tcx, N>
Returns a copy of the value. Read more
fn clone_from(&mut self, source: &Self)
1.0.0
Performs copy-assignment from source
. Read more