Skip to content

Commit

Permalink
Rollup merge of rust-lang#100705 - compiler-errors:issue-100620, r=ol…
Browse files Browse the repository at this point in the history
…i-obk

Avoid reporting overflow in `is_impossible_method`

Fixes rust-lang#100620

We're evaluating a new predicate in a different param-env than it was checked during typeck, so be more careful about handling overflow errors. Instead of using `FulfillmentCtxt`, using `InferCtxt::evaluate_obligation` by itself will give us back the overflow error, so we can throw it away properly.

This may give us more false-positives, but it doesn't regress the `<HashMap as Iterator>::rev` example that originally motivated adding `is_impossible_method` in the first place.
  • Loading branch information
Dylan-DPC authored Aug 25, 2022
2 parents e1b8ffa + c4a5b14 commit d0bfa26
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 3 deletions.
13 changes: 10 additions & 3 deletions compiler/rustc_trait_selection/src/traits/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -579,9 +579,16 @@ fn is_impossible_method<'tcx>(
});

tcx.infer_ctxt().ignoring_regions().enter(|ref infcx| {
let mut fulfill_ctxt = <dyn TraitEngine<'_>>::new(tcx);
fulfill_ctxt.register_predicate_obligations(infcx, predicates_for_trait);
!fulfill_ctxt.select_all_or_error(infcx).is_empty()
for obligation in predicates_for_trait {
// Ignore overflow error, to be conservative.
if let Ok(result) = infcx.evaluate_obligation(&obligation)
&& !result.may_apply()
{
return true;
}
}

false
})
}

Expand Down
19 changes: 19 additions & 0 deletions src/test/rustdoc/issue-100620.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
pub trait Bar<S> {}

pub trait Qux<T> {}

pub trait Foo<T, S> {
fn bar()
where
T: Bar<S>,
{
}
}

pub struct Concrete;

impl<S> Foo<(), S> for Concrete {}

impl<T, S> Bar<S> for T where S: Qux<T> {}

impl<T, S> Qux<T> for S where T: Bar<S> {}

0 comments on commit d0bfa26

Please sign in to comment.