Enum rustc_infer::infer::lexical_region_resolve::RegionResolutionError [−][src]
pub enum RegionResolutionError<'tcx> {
ConcreteFailure(SubregionOrigin<'tcx>, Region<'tcx>, Region<'tcx>),
GenericBoundFailure(SubregionOrigin<'tcx>, GenericKind<'tcx>, Region<'tcx>),
SubSupConflict(RegionVid, RegionVariableOrigin, SubregionOrigin<'tcx>, Region<'tcx>, SubregionOrigin<'tcx>, Region<'tcx>),
UpperBoundUniverseConflict(RegionVid, RegionVariableOrigin, UniverseIndex, SubregionOrigin<'tcx>, Region<'tcx>),
}
Variants
ConcreteFailure(SubregionOrigin<'tcx>, Region<'tcx>, Region<'tcx>)
ConcreteFailure(o, a, b)
:
o
requires that a <= b
, but this does not hold
Tuple Fields of ConcreteFailure
GenericBoundFailure(SubregionOrigin<'tcx>, GenericKind<'tcx>, Region<'tcx>)
`GenericBoundFailure(p, s, a)
The parameter/associated-type p
must be known to outlive the lifetime
a
(but none of the known bounds are sufficient).
Tuple Fields of GenericBoundFailure
SubSupConflict(RegionVid, RegionVariableOrigin, SubregionOrigin<'tcx>, Region<'tcx>, SubregionOrigin<'tcx>, Region<'tcx>)
SubSupConflict(v, v_origin, sub_origin, sub_r, sup_origin, sup_r)
:
Could not infer a value for v
(which has origin v_origin
)
because sub_r <= v
(due to sub_origin
) but v <= sup_r
(due to sup_origin
) and
sub_r <= sup_r
does not hold.
Tuple Fields of SubSupConflict
0: RegionVid
1: RegionVariableOrigin
2: SubregionOrigin<'tcx>
3: Region<'tcx>
4: SubregionOrigin<'tcx>
5: Region<'tcx>
UpperBoundUniverseConflict(RegionVid, RegionVariableOrigin, UniverseIndex, SubregionOrigin<'tcx>, Region<'tcx>)
Indicates a 'b: 'a
constraint where 'a
is in a universe that
cannot name the placeholder 'b
.
Tuple Fields of UpperBoundUniverseConflict
Trait Implementations
Auto Trait Implementations
impl<'tcx> !RefUnwindSafe for RegionResolutionError<'tcx>
impl<'tcx> !Send for RegionResolutionError<'tcx>
impl<'tcx> !Sync for RegionResolutionError<'tcx>
impl<'tcx> Unpin for RegionResolutionError<'tcx>
impl<'tcx> !UnwindSafe for RegionResolutionError<'tcx>
Blanket Implementations
Mutably borrows from an owned value. Read more
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: 144 bytes
Size for each variant:
ConcreteFailure
: 52 bytesGenericBoundFailure
: 68 bytesSubSupConflict
: 140 bytesUpperBoundUniverseConflict
: 108 bytes