about summary refs log tree commit diff
path: root/compiler/rustc_interface/src/errors.rs
diff options
context:
space:
mode:
authorDylan DPC <99973273+Dylan-DPC@users.noreply.github.com>2023-03-15 17:51:31 +0530
committerGitHub <noreply@github.com>2023-03-15 17:51:31 +0530
commit2aa3eea5fce4913981e22cdf31ca62823792303d (patch)
tree2af8f7be6ce73597da1a30dc739e97639f750561 /compiler/rustc_interface/src/errors.rs
parentc11399b2e25920473dda49d5e56e1a8b1f42a434 (diff)
parentee2d42882f9d76b8fb54d749c35fec265026db47 (diff)
downloadrust-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