Move auxiliary fns out of overlap_with_probe
This commit is contained in:
parent
f518827503
commit
052b31b587
1 changed files with 19 additions and 19 deletions
|
@ -157,25 +157,6 @@ fn overlap_within_probe<'cx, 'tcx>(
|
||||||
impl2_def_id: DefId,
|
impl2_def_id: DefId,
|
||||||
snapshot: &CombinedSnapshot<'_, 'tcx>,
|
snapshot: &CombinedSnapshot<'_, 'tcx>,
|
||||||
) -> Option<OverlapResult<'tcx>> {
|
) -> Option<OverlapResult<'tcx>> {
|
||||||
fn loose_check<'cx, 'tcx>(
|
|
||||||
selcx: &mut SelectionContext<'cx, 'tcx>,
|
|
||||||
o: &PredicateObligation<'tcx>,
|
|
||||||
) -> bool {
|
|
||||||
!selcx.predicate_may_hold_fatal(o)
|
|
||||||
}
|
|
||||||
|
|
||||||
fn strict_check<'cx, 'tcx>(
|
|
||||||
selcx: &SelectionContext<'cx, 'tcx>,
|
|
||||||
o: &PredicateObligation<'tcx>,
|
|
||||||
) -> bool {
|
|
||||||
let infcx = selcx.infcx();
|
|
||||||
let tcx = infcx.tcx;
|
|
||||||
o.flip_polarity(tcx)
|
|
||||||
.as_ref()
|
|
||||||
.map(|o| selcx.infcx().predicate_must_hold_modulo_regions(o))
|
|
||||||
.unwrap_or(false)
|
|
||||||
}
|
|
||||||
|
|
||||||
// For the purposes of this check, we don't bring any placeholder
|
// For the purposes of this check, we don't bring any placeholder
|
||||||
// types into scope; instead, we replace the generic types with
|
// types into scope; instead, we replace the generic types with
|
||||||
// fresh type variables, and hence we do our evaluations in an
|
// fresh type variables, and hence we do our evaluations in an
|
||||||
|
@ -275,6 +256,25 @@ fn overlap_within_probe<'cx, 'tcx>(
|
||||||
Some(OverlapResult { impl_header, intercrate_ambiguity_causes, involves_placeholder })
|
Some(OverlapResult { impl_header, intercrate_ambiguity_causes, involves_placeholder })
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn loose_check<'cx, 'tcx>(
|
||||||
|
selcx: &mut SelectionContext<'cx, 'tcx>,
|
||||||
|
o: &PredicateObligation<'tcx>,
|
||||||
|
) -> bool {
|
||||||
|
!selcx.predicate_may_hold_fatal(o)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn strict_check<'cx, 'tcx>(
|
||||||
|
selcx: &SelectionContext<'cx, 'tcx>,
|
||||||
|
o: &PredicateObligation<'tcx>,
|
||||||
|
) -> bool {
|
||||||
|
let infcx = selcx.infcx();
|
||||||
|
let tcx = infcx.tcx;
|
||||||
|
o.flip_polarity(tcx)
|
||||||
|
.as_ref()
|
||||||
|
.map(|o| selcx.infcx().predicate_must_hold_modulo_regions(o))
|
||||||
|
.unwrap_or(false)
|
||||||
|
}
|
||||||
|
|
||||||
pub fn trait_ref_is_knowable<'tcx>(
|
pub fn trait_ref_is_knowable<'tcx>(
|
||||||
tcx: TyCtxt<'tcx>,
|
tcx: TyCtxt<'tcx>,
|
||||||
trait_ref: ty::TraitRef<'tcx>,
|
trait_ref: ty::TraitRef<'tcx>,
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue