Struct rustc_trait_selection::traits::project::BoundVarReplacer
source · pub struct BoundVarReplacer<'me, 'tcx> {
infcx: &'me InferCtxt<'tcx>,
mapped_regions: BTreeMap<PlaceholderRegion, BoundRegion>,
mapped_types: BTreeMap<PlaceholderType, BoundTy>,
mapped_consts: BTreeMap<PlaceholderConst<'tcx>, BoundVar>,
current_index: DebruijnIndex,
universe_indices: &'me mut Vec<Option<UniverseIndex>>,
}
Fields§
§infcx: &'me InferCtxt<'tcx>
§mapped_regions: BTreeMap<PlaceholderRegion, BoundRegion>
§mapped_types: BTreeMap<PlaceholderType, BoundTy>
§mapped_consts: BTreeMap<PlaceholderConst<'tcx>, BoundVar>
§current_index: DebruijnIndex
§universe_indices: &'me mut Vec<Option<UniverseIndex>>
Implementations§
source§impl<'me, 'tcx> BoundVarReplacer<'me, 'tcx>
impl<'me, 'tcx> BoundVarReplacer<'me, 'tcx>
sourcepub fn replace_bound_vars<T: TypeFoldable<'tcx>>(
infcx: &'me InferCtxt<'tcx>,
universe_indices: &'me mut Vec<Option<UniverseIndex>>,
value: T
) -> (T, BTreeMap<PlaceholderRegion, BoundRegion>, BTreeMap<PlaceholderType, BoundTy>, BTreeMap<PlaceholderConst<'tcx>, BoundVar>)
pub fn replace_bound_vars<T: TypeFoldable<'tcx>>(
infcx: &'me InferCtxt<'tcx>,
universe_indices: &'me mut Vec<Option<UniverseIndex>>,
value: T
) -> (T, BTreeMap<PlaceholderRegion, BoundRegion>, BTreeMap<PlaceholderType, BoundTy>, BTreeMap<PlaceholderConst<'tcx>, BoundVar>)
Returns Some
if we were able to replace bound vars. If there are any bound vars that
use a binding level above universe_indices.len()
, we fail.
fn universe_for(&mut self, debruijn: DebruijnIndex) -> UniverseIndex
Trait Implementations§
source§impl<'tcx> TypeFolder<'tcx> for BoundVarReplacer<'_, 'tcx>
impl<'tcx> TypeFolder<'tcx> for BoundVarReplacer<'_, 'tcx>
fn tcx<'b>(&'b self) -> TyCtxt<'tcx>
fn fold_binder<T: TypeFoldable<'tcx>>(
&mut self,
t: Binder<'tcx, T>
) -> Binder<'tcx, T>
fn fold_region(&mut self, r: Region<'tcx>) -> Region<'tcx>
fn fold_ty(&mut self, t: Ty<'tcx>) -> Ty<'tcx>
fn fold_const(&mut self, ct: Const<'tcx>) -> Const<'tcx>
fn fold_predicate(&mut self, p: Predicate<'tcx>) -> Predicate<'tcx>
Auto Trait Implementations§
impl<'me, 'tcx> !RefUnwindSafe for BoundVarReplacer<'me, 'tcx>
impl<'me, 'tcx> !Send for BoundVarReplacer<'me, 'tcx>
impl<'me, 'tcx> !Sync for BoundVarReplacer<'me, 'tcx>
impl<'me, 'tcx> Unpin for BoundVarReplacer<'me, 'tcx>where
'tcx: 'me,
impl<'me, 'tcx> !UnwindSafe for BoundVarReplacer<'me, 'tcx>
Blanket Implementations§
source§impl<'tcx, F> FallibleTypeFolder<'tcx> for Fwhere
F: TypeFolder<'tcx>,
impl<'tcx, F> FallibleTypeFolder<'tcx> for Fwhere
F: TypeFolder<'tcx>,
type Error = !
fn tcx<'a>(&'a self) -> TyCtxt<'tcx>
fn try_fold_binder<T>(
&mut self,
t: Binder<'tcx, T>
) -> Result<Binder<'tcx, T>, !>where
T: TypeFoldable<'tcx>,
fn try_fold_ty(&mut self, t: Ty<'tcx>) -> Result<Ty<'tcx>, !>
fn try_fold_region(&mut self, r: Region<'tcx>) -> Result<Region<'tcx>, !>
fn try_fold_const(&mut self, c: Const<'tcx>) -> Result<Const<'tcx>, !>
fn try_fold_predicate(
&mut self,
p: Predicate<'tcx>
) -> Result<Predicate<'tcx>, !>
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: 96 bytes