diff options
| author | Jacob Pratt <jacob@jhpratt.dev> | 2025-08-21 17:57:56 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-08-21 17:57:56 -0400 | 
| commit | cc98a849c856dddcab0d2aef7b79dcf341d5c66b (patch) | |
| tree | 6d8af858d66a9eac9fd07a41f145e59a14f8ffd3 | |
| parent | e4d71b8089f5d47f59d92f4438439276289347c4 (diff) | |
| parent | 95b3b61b8c2ecf0b5073d5779cea2825c726bf4b (diff) | |
| download | rust-cc98a849c856dddcab0d2aef7b79dcf341d5c66b.tar.gz rust-cc98a849c856dddcab0d2aef7b79dcf341d5c66b.zip  | |
Rollup merge of #145700 - nnethercote:fix-145696, r=lcnr
Handle `ReEarlyParam` in `type_name`. Fixes rust-lang/rust#145696. r? `@lcnr`
| -rw-r--r-- | compiler/rustc_const_eval/src/util/type_name.rs | 6 | ||||
| -rw-r--r-- | tests/ui/type/type-name-basic.rs | 18 | 
2 files changed, 20 insertions, 4 deletions
diff --git a/compiler/rustc_const_eval/src/util/type_name.rs b/compiler/rustc_const_eval/src/util/type_name.rs index 92096958f2b..2ae6655901b 100644 --- a/compiler/rustc_const_eval/src/util/type_name.rs +++ b/compiler/rustc_const_eval/src/util/type_name.rs @@ -164,12 +164,12 @@ impl<'tcx> Printer<'tcx> for TypeNamePrinter<'tcx> { } impl<'tcx> PrettyPrinter<'tcx> for TypeNamePrinter<'tcx> { - fn should_print_optional_region(&self, _region: ty::Region<'_>) -> bool { + fn should_print_optional_region(&self, region: ty::Region<'_>) -> bool { // Bound regions are always printed (as `'_`), which gives some idea that they are special, // even though the `for` is omitted by the pretty printer. // E.g. `for<'a, 'b> fn(&'a u32, &'b u32)` is printed as "fn(&'_ u32, &'_ u32)". - match _region.kind() { - ty::ReErased => false, + match region.kind() { + ty::ReErased | ty::ReEarlyParam(_) => false, ty::ReBound(..) => true, _ => unreachable!(), } diff --git a/tests/ui/type/type-name-basic.rs b/tests/ui/type/type-name-basic.rs index e1310e1f365..343bcae175a 100644 --- a/tests/ui/type/type-name-basic.rs +++ b/tests/ui/type/type-name-basic.rs @@ -5,7 +5,7 @@ #![allow(dead_code)] -use std::any::type_name; +use std::any::{Any, type_name, type_name_of_val}; use std::borrow::Cow; struct Foo<T>(T); @@ -29,6 +29,12 @@ macro_rules! t { } } +macro_rules! v { + ($v:expr, $str:literal) => { + assert_eq!(type_name_of_val(&$v), $str); + } +} + pub fn main() { t!(bool, "bool"); t!(char, "char"); @@ -91,4 +97,14 @@ pub fn main() { } } S::<u32>::test(); + + struct Wrap<T>(T); + impl Wrap<&()> { + fn get(&self) -> impl Any { + struct Info; + Info + } + } + let a = Wrap(&()).get(); + v!(a, "type_name_basic::main::Wrap<&()>::get::Info"); }  | 
