about summary refs log tree commit diff
path: root/src/libcore
diff options
context:
space:
mode:
authorMazdak Farrokhzad <twingoow@gmail.com>2019-07-30 22:43:37 +0200
committerGitHub <noreply@github.com>2019-07-30 22:43:37 +0200
commitc088890b6e9f813b47bbe41e4eae9cd3545cb1d2 (patch)
treefa25e3f6ebbf2bcc42eb526de59765dc9391e54f /src/libcore
parentcdf97589df2de0d5e877dac43d0ec6089c20fb11 (diff)
parent4a3d41d334860f18a7fc9319167f9e275dd9510b (diff)
downloadrust-c088890b6e9f813b47bbe41e4eae9cd3545cb1d2.tar.gz
rust-c088890b6e9f813b47bbe41e4eae9cd3545cb1d2.zip
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.
Diffstat (limited to 'src/libcore')
-rw-r--r--src/libcore/any.rs3
1 files changed, 2 insertions, 1 deletions
diff --git a/src/libcore/any.rs b/src/libcore/any.rs
index f7aef66942d..078091a9b54 100644
--- a/src/libcore/any.rs
+++ b/src/libcore/any.rs
@@ -468,7 +468,8 @@ impl TypeId {
 /// The current implementation uses the same infrastructure as compiler
 /// diagnostics and debuginfo, but this is not guaranteed.
 #[stable(feature = "type_name", since = "1.38.0")]
-pub fn type_name<T: ?Sized>() -> &'static str {
+#[rustc_const_unstable(feature = "const_type_name")]
+pub const fn type_name<T: ?Sized>() -> &'static str {
     #[cfg(bootstrap)]
     unsafe {
         intrinsics::type_name::<T>()