Remove Ord
from BoundTy
This commit is contained in:
parent
dd9fe01d06
commit
e87d10846e
2 changed files with 9 additions and 9 deletions
|
@ -868,7 +868,7 @@ impl<'tcx> InlineConstArgs<'tcx> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Copy, Clone, PartialEq, Eq, PartialOrd, Ord, Hash, Debug, TyEncodable, TyDecodable)]
|
#[derive(Copy, Clone, PartialEq, Eq, Hash, Debug, TyEncodable, TyDecodable)]
|
||||||
#[derive(HashStable)]
|
#[derive(HashStable)]
|
||||||
pub enum BoundVariableKind {
|
pub enum BoundVariableKind {
|
||||||
Ty(BoundTyKind),
|
Ty(BoundTyKind),
|
||||||
|
@ -1403,14 +1403,14 @@ impl ParamConst {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash, TyEncodable, TyDecodable)]
|
#[derive(Clone, Copy, PartialEq, Eq, Hash, TyEncodable, TyDecodable)]
|
||||||
#[derive(HashStable)]
|
#[derive(HashStable)]
|
||||||
pub struct BoundTy {
|
pub struct BoundTy {
|
||||||
pub var: BoundVar,
|
pub var: BoundVar,
|
||||||
pub kind: BoundTyKind,
|
pub kind: BoundTyKind,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash, Debug, TyEncodable, TyDecodable)]
|
#[derive(Clone, Copy, PartialEq, Eq, Hash, Debug, TyEncodable, TyDecodable)]
|
||||||
#[derive(HashStable)]
|
#[derive(HashStable)]
|
||||||
pub enum BoundTyKind {
|
pub enum BoundTyKind {
|
||||||
Anon,
|
Anon,
|
||||||
|
|
|
@ -2,7 +2,7 @@ use std::collections::BTreeMap;
|
||||||
|
|
||||||
use super::NormalizeExt;
|
use super::NormalizeExt;
|
||||||
use super::{ObligationCause, PredicateObligation, SelectionContext};
|
use super::{ObligationCause, PredicateObligation, SelectionContext};
|
||||||
use rustc_data_structures::fx::FxHashSet;
|
use rustc_data_structures::fx::{FxHashSet, FxIndexMap};
|
||||||
use rustc_errors::Diag;
|
use rustc_errors::Diag;
|
||||||
use rustc_hir::def_id::DefId;
|
use rustc_hir::def_id::DefId;
|
||||||
use rustc_infer::infer::{InferCtxt, InferOk};
|
use rustc_infer::infer::{InferCtxt, InferOk};
|
||||||
|
@ -432,7 +432,7 @@ pub struct BoundVarReplacer<'me, 'tcx> {
|
||||||
// nice to remove these since we already have the `kind` in the placeholder; we really just need
|
// nice to remove these since we already have the `kind` in the placeholder; we really just need
|
||||||
// the `var` (but we *could* bring that into scope if we were to track them as we pass them).
|
// the `var` (but we *could* bring that into scope if we were to track them as we pass them).
|
||||||
mapped_regions: BTreeMap<ty::PlaceholderRegion, ty::BoundRegion>,
|
mapped_regions: BTreeMap<ty::PlaceholderRegion, ty::BoundRegion>,
|
||||||
mapped_types: BTreeMap<ty::PlaceholderType, ty::BoundTy>,
|
mapped_types: FxIndexMap<ty::PlaceholderType, ty::BoundTy>,
|
||||||
mapped_consts: BTreeMap<ty::PlaceholderConst, ty::BoundVar>,
|
mapped_consts: BTreeMap<ty::PlaceholderConst, ty::BoundVar>,
|
||||||
// The current depth relative to *this* folding, *not* the entire normalization. In other words,
|
// The current depth relative to *this* folding, *not* the entire normalization. In other words,
|
||||||
// the depth of binders we've passed here.
|
// the depth of binders we've passed here.
|
||||||
|
@ -452,11 +452,11 @@ impl<'me, 'tcx> BoundVarReplacer<'me, 'tcx> {
|
||||||
) -> (
|
) -> (
|
||||||
T,
|
T,
|
||||||
BTreeMap<ty::PlaceholderRegion, ty::BoundRegion>,
|
BTreeMap<ty::PlaceholderRegion, ty::BoundRegion>,
|
||||||
BTreeMap<ty::PlaceholderType, ty::BoundTy>,
|
FxIndexMap<ty::PlaceholderType, ty::BoundTy>,
|
||||||
BTreeMap<ty::PlaceholderConst, ty::BoundVar>,
|
BTreeMap<ty::PlaceholderConst, ty::BoundVar>,
|
||||||
) {
|
) {
|
||||||
let mapped_regions: BTreeMap<ty::PlaceholderRegion, ty::BoundRegion> = BTreeMap::new();
|
let mapped_regions: BTreeMap<ty::PlaceholderRegion, ty::BoundRegion> = BTreeMap::new();
|
||||||
let mapped_types: BTreeMap<ty::PlaceholderType, ty::BoundTy> = BTreeMap::new();
|
let mapped_types: FxIndexMap<ty::PlaceholderType, ty::BoundTy> = FxIndexMap::default();
|
||||||
let mapped_consts: BTreeMap<ty::PlaceholderConst, ty::BoundVar> = BTreeMap::new();
|
let mapped_consts: BTreeMap<ty::PlaceholderConst, ty::BoundVar> = BTreeMap::new();
|
||||||
|
|
||||||
let mut replacer = BoundVarReplacer {
|
let mut replacer = BoundVarReplacer {
|
||||||
|
@ -575,7 +575,7 @@ impl<'tcx> TypeFolder<TyCtxt<'tcx>> for BoundVarReplacer<'_, 'tcx> {
|
||||||
pub struct PlaceholderReplacer<'me, 'tcx> {
|
pub struct PlaceholderReplacer<'me, 'tcx> {
|
||||||
infcx: &'me InferCtxt<'tcx>,
|
infcx: &'me InferCtxt<'tcx>,
|
||||||
mapped_regions: BTreeMap<ty::PlaceholderRegion, ty::BoundRegion>,
|
mapped_regions: BTreeMap<ty::PlaceholderRegion, ty::BoundRegion>,
|
||||||
mapped_types: BTreeMap<ty::PlaceholderType, ty::BoundTy>,
|
mapped_types: FxIndexMap<ty::PlaceholderType, ty::BoundTy>,
|
||||||
mapped_consts: BTreeMap<ty::PlaceholderConst, ty::BoundVar>,
|
mapped_consts: BTreeMap<ty::PlaceholderConst, ty::BoundVar>,
|
||||||
universe_indices: &'me [Option<ty::UniverseIndex>],
|
universe_indices: &'me [Option<ty::UniverseIndex>],
|
||||||
current_index: ty::DebruijnIndex,
|
current_index: ty::DebruijnIndex,
|
||||||
|
@ -585,7 +585,7 @@ impl<'me, 'tcx> PlaceholderReplacer<'me, 'tcx> {
|
||||||
pub fn replace_placeholders<T: TypeFoldable<TyCtxt<'tcx>>>(
|
pub fn replace_placeholders<T: TypeFoldable<TyCtxt<'tcx>>>(
|
||||||
infcx: &'me InferCtxt<'tcx>,
|
infcx: &'me InferCtxt<'tcx>,
|
||||||
mapped_regions: BTreeMap<ty::PlaceholderRegion, ty::BoundRegion>,
|
mapped_regions: BTreeMap<ty::PlaceholderRegion, ty::BoundRegion>,
|
||||||
mapped_types: BTreeMap<ty::PlaceholderType, ty::BoundTy>,
|
mapped_types: FxIndexMap<ty::PlaceholderType, ty::BoundTy>,
|
||||||
mapped_consts: BTreeMap<ty::PlaceholderConst, ty::BoundVar>,
|
mapped_consts: BTreeMap<ty::PlaceholderConst, ty::BoundVar>,
|
||||||
universe_indices: &'me [Option<ty::UniverseIndex>],
|
universe_indices: &'me [Option<ty::UniverseIndex>],
|
||||||
value: T,
|
value: T,
|
||||||
|
|
Loading…
Add table
Reference in a new issue