diff options
| author | Dylan DPC <99973273+Dylan-DPC@users.noreply.github.com> | 2023-03-15 17:51:31 +0530 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-03-15 17:51:31 +0530 |
| commit | 2aa3eea5fce4913981e22cdf31ca62823792303d (patch) | |
| tree | 2af8f7be6ce73597da1a30dc739e97639f750561 /compiler/rustc_interface/src/errors.rs | |
| parent | c11399b2e25920473dda49d5e56e1a8b1f42a434 (diff) | |
| parent | ee2d42882f9d76b8fb54d749c35fec265026db47 (diff) | |
| download | rust-2aa3eea5fce4913981e22cdf31ca62823792303d.tar.gz rust-2aa3eea5fce4913981e22cdf31ca62823792303d.zip | |
Rollup merge of #109109 - compiler-errors:polymorphize-foreign, r=Nilstrieb
Use `unused_generic_params` from crate metadata Due to the way that `separate_provide_extern` interacted with the implementation of `<ty::InstanceDef<'tcx> as Key>::query_crate_is_local`, we actually never hit the foreign provider for `unused_generic_params`. Additionally, since the *local* provider of `unused_generic_params` calls `should_polymorphize`, which always returns false if the def-id is foreign, this means that we never actually polymorphize monomorphic instances originating from foreign crates. We don't actually encode `unused_generic_params` for items where all generics are used, so I had to tweak the foreign provider to fall back to `ty::UnusedGenericParams::new_all_used()` to avoid more ICEs when the above bugs were fixed.
Diffstat (limited to 'compiler/rustc_interface/src/errors.rs')
0 files changed, 0 insertions, 0 deletions
