diff options
| author | Michael Goulet <michael@errs.io> | 2025-07-21 16:07:12 +0000 |
|---|---|---|
| committer | Michael Goulet <michael@errs.io> | 2025-07-21 16:07:29 +0000 |
| commit | b5d36e5294d3354ad8feec86b27c698e368c88a6 (patch) | |
| tree | 786113548170ad50aa1c01f4156a767123d6eb37 /compiler/rustc_borrowck | |
| parent | 67819923ac8ea353aaa775303f4c3aacbf41d010 (diff) | |
| download | rust-b5d36e5294d3354ad8feec86b27c698e368c88a6.tar.gz rust-b5d36e5294d3354ad8feec86b27c698e368c88a6.zip | |
Dont ICE on copy error being suppressed due to overflow
Diffstat (limited to 'compiler/rustc_borrowck')
| -rw-r--r-- | compiler/rustc_borrowck/src/diagnostics/move_errors.rs | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/compiler/rustc_borrowck/src/diagnostics/move_errors.rs b/compiler/rustc_borrowck/src/diagnostics/move_errors.rs index 92ca868eb99..447bf7d091a 100644 --- a/compiler/rustc_borrowck/src/diagnostics/move_errors.rs +++ b/compiler/rustc_borrowck/src/diagnostics/move_errors.rs @@ -303,10 +303,11 @@ impl<'infcx, 'tcx> MirBorrowckCtxt<'_, 'infcx, 'tcx> { } fn has_ambiguous_copy(&mut self, ty: Ty<'tcx>) -> bool { - let Some(copy_trait_def) = self.infcx.tcx.lang_items().copy_trait() else { return false }; - // This is only going to be ambiguous if there are incoherent impls, because otherwise - // ambiguity should never happen in MIR. - self.infcx.type_implements_trait(copy_trait_def, [ty], self.infcx.param_env).may_apply() + let Some(copy_def_id) = self.infcx.tcx.lang_items().copy_trait() else { return false }; + + // Avoid bogus move errors because of an incoherent `Copy` impl. + self.infcx.type_implements_trait(copy_def_id, [ty], self.infcx.param_env).may_apply() + && self.infcx.tcx.coherent_trait(copy_def_id).is_err() } fn report_cannot_move_from_static(&mut self, place: Place<'tcx>, span: Span) -> Diag<'infcx> { |
