Rollup merge of #63123 - TankhouseAle:const-fn-type-name-any, r=oli-obk
`const fn`-ify `std::any::type_name` as laid out in #63084 A test, based on the one I added when I implemented support for the underlying `core::intrinsics::type_name` being allowed in `const fn` contexts, is included.
This commit is contained in:
commit
c088890b6e
2 changed files with 31 additions and 1 deletions
29
src/test/ui/consts/const-fn-type-name-any.rs
Normal file
29
src/test/ui/consts/const-fn-type-name-any.rs
Normal file
|
|
@ -0,0 +1,29 @@
|
|||
// run-pass
|
||||
|
||||
#![feature(const_fn)]
|
||||
#![feature(const_type_name)]
|
||||
#![allow(dead_code)]
|
||||
|
||||
const fn type_name_wrapper<T>(_: &T) -> &'static str {
|
||||
std::any::type_name::<T>()
|
||||
}
|
||||
|
||||
struct Struct<TA, TB, TC> {
|
||||
a: TA,
|
||||
b: TB,
|
||||
c: TC,
|
||||
}
|
||||
|
||||
type StructInstantiation = Struct<i8, f64, bool>;
|
||||
|
||||
const CONST_STRUCT: StructInstantiation = StructInstantiation { a: 12, b: 13.7, c: false };
|
||||
|
||||
const CONST_STRUCT_NAME: &'static str = type_name_wrapper(&CONST_STRUCT);
|
||||
|
||||
fn main() {
|
||||
let non_const_struct = StructInstantiation { a: 87, b: 65.99, c: true };
|
||||
|
||||
let non_const_struct_name = type_name_wrapper(&non_const_struct);
|
||||
|
||||
assert_eq!(CONST_STRUCT_NAME, non_const_struct_name);
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue