-// compile-flags:-Zprint-mono-items=eager
+// compile-flags:-Zprint-mono-items=eager -Zpolymorphize=on
#![deny(dead_code)]
#![feature(start)]
// For the non-generic foo(), we should generate a codegen-item even if it
// is not called anywhere
- //~ MONO_ITEM fn trait_method_default_impl::SomeTrait[0]::foo[0]<i8>
+ //~ MONO_ITEM fn <i8 as SomeTrait>::foo
}
trait SomeGenericTrait<T1> {
// For the non-generic foo(), we should generate a codegen-item even if it
// is not called anywhere
- //~ MONO_ITEM fn trait_method_default_impl::SomeGenericTrait[0]::foo[0]<i32, u64>
+ //~ MONO_ITEM fn <i32 as SomeGenericTrait<T1>>::foo
}
// Non-generic impl of generic trait
// since nothing is monomorphic here, nothing should be generated unless used somewhere.
}
-//~ MONO_ITEM fn trait_method_default_impl::start[0]
+//~ MONO_ITEM fn start
#[start]
fn start(_: isize, _: *const *const u8) -> isize {
- //~ MONO_ITEM fn trait_method_default_impl::SomeTrait[0]::bar[0]<i8, char>
+ //~ MONO_ITEM fn <i8 as SomeTrait>::bar::<char>
let _ = 1i8.bar('c');
- //~ MONO_ITEM fn trait_method_default_impl::SomeTrait[0]::bar[0]<i8, &str>
+ //~ MONO_ITEM fn <i8 as SomeTrait>::bar::<&str>
let _ = 2i8.bar("&str");
- //~ MONO_ITEM fn trait_method_default_impl::SomeGenericTrait[0]::bar[0]<i32, u64, char>
+ //~ MONO_ITEM fn <i32 as SomeGenericTrait<u64>>::bar::<char>
0i32.bar(0u64, 'c');
- //~ MONO_ITEM fn trait_method_default_impl::SomeGenericTrait[0]::bar[0]<i32, u64, &str>
+ //~ MONO_ITEM fn <i32 as SomeGenericTrait<u64>>::bar::<&str>
0i32.bar(0u64, "&str");
- //~ MONO_ITEM fn trait_method_default_impl::SomeGenericTrait[0]::bar[0]<u32, i8, &[char; 1]>
+ //~ MONO_ITEM fn <u32 as SomeGenericTrait<i8>>::bar::<&[char; 1]>
0u32.bar(0i8, &['c']);
- //~ MONO_ITEM fn trait_method_default_impl::SomeGenericTrait[0]::bar[0]<u32, i16, ()>
+ //~ MONO_ITEM fn <u32 as SomeGenericTrait<i16>>::bar::<()>
0u32.bar(0i16, ());
0