Struct rustc_borrowck::universal_regions::UniversalRegionIndices [−][src]
Fields
indices: FxHashMap<Region<'tcx>, RegionVid>For those regions that may appear in the parameter environment
(’static and early-bound regions), we maintain a map from the
ty::Region to the internal RegionVid we are using. This is
used because trait matching and type-checking will feed us
region constraints that reference those regions and we need to
be able to map them our internal RegionVid. This is
basically equivalent to an InternalSubsts, except that it also
contains an entry for ReStatic – it might be nice to just
use a substs, and then handle ReStatic another way.
Implementations
Initially, the UniversalRegionIndices map contains only the
early-bound regions in scope. Once that is all setup, we come
in later and instantiate the late-bound regions, and then we
insert the ReFree version of those into the map as
well. These are used for error reporting.
Converts r into a local inference variable: r can either
by a ReVar (i.e., already a reference to an inference
variable) or it can be 'static or some early-bound
region. This is useful when taking the results from
type-checking and trait-matching, which may sometimes
reference those regions from the ParamEnv. It is also used
during initialization. Relies on the indices map having been
fully initialized.
pub fn fold_to_region_vids<T>(&self, tcx: TyCtxt<'tcx>, value: T) -> T where
T: TypeFoldable<'tcx>,
pub fn fold_to_region_vids<T>(&self, tcx: TyCtxt<'tcx>, value: T) -> T where
T: TypeFoldable<'tcx>,
Replaces all free regions in value with region vids, as
returned by to_region_vid.
Trait Implementations
Auto Trait Implementations
impl<'tcx> RefUnwindSafe for UniversalRegionIndices<'tcx>
impl<'tcx> Send for UniversalRegionIndices<'tcx>
impl<'tcx> Sync for UniversalRegionIndices<'tcx>
impl<'tcx> Unpin for UniversalRegionIndices<'tcx>
impl<'tcx> UnwindSafe for UniversalRegionIndices<'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: 32 bytes