Enum rustc_infer::traits::SelectionError
source · pub enum SelectionError<'tcx> {
Unimplemented,
OutputTypeParameterMismatch(Binder<'tcx, TraitRef<'tcx>>, Binder<'tcx, TraitRef<'tcx>>, TypeError<'tcx>),
TraitNotObjectSafe(DefId),
NotConstEvaluatable(NotConstEvaluatable),
Overflow(OverflowError),
ErrorReporting,
}
Variants§
Unimplemented
The trait is not implemented.
OutputTypeParameterMismatch(Binder<'tcx, TraitRef<'tcx>>, Binder<'tcx, TraitRef<'tcx>>, TypeError<'tcx>)
After a closure impl has selected, its “outputs” were evaluated
(which for closures includes the “input” type params) and they
didn’t resolve. See confirm_poly_trait_refs
for more.
TraitNotObjectSafe(DefId)
The trait pointed by DefId
is not object safe.
NotConstEvaluatable(NotConstEvaluatable)
A given constant couldn’t be evaluated.
Overflow(OverflowError)
Exceeded the recursion depth during type projection.
ErrorReporting
Signaling that an error has already been emitted, to avoid multiple errors being shown.
Auto Trait Implementations§
impl<'tcx> !RefUnwindSafe for SelectionError<'tcx>
impl<'tcx> !Send for SelectionError<'tcx>
impl<'tcx> !Sync for SelectionError<'tcx>
impl<'tcx> Unpin for SelectionError<'tcx>
impl<'tcx> !UnwindSafe for SelectionError<'tcx>
Blanket Implementations§
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: 80 bytes
Size for each variant:
Unimplemented
: 0 bytesOutputTypeParameterMismatch
: 80 bytesTraitNotObjectSafe
: 8 bytesNotConstEvaluatable
: 1 byteOverflow
: 1 byteErrorReporting
: 0 bytes