Don't Create ParamCandidate
When Obligation Contains Errors
Fixes #121941
This commit is contained in:
parent
4a0cc881dc
commit
96b8225d8d
3 changed files with 21 additions and 0 deletions
|
@ -219,6 +219,13 @@ impl<'cx, 'tcx> SelectionContext<'cx, 'tcx> {
|
|||
) -> Result<(), SelectionError<'tcx>> {
|
||||
debug!(?stack.obligation);
|
||||
|
||||
// An error type will unify with anything. So, avoid
|
||||
// matching an error type with `ParamCandidate`.
|
||||
// This helps us avoid spurious errors like issue #121941.
|
||||
if stack.obligation.predicate.references_error() {
|
||||
return Ok(());
|
||||
}
|
||||
|
||||
let all_bounds = stack
|
||||
.obligation
|
||||
.param_env
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue