Rephrase the any::type_name docs a bit.

This attempts to be a little clearer (including in terminology) about the lack
of guarantees that any::type_name provides.
This commit is contained in:
Laurence Tratt 2020-05-04 10:17:39 +01:00
parent ff4df04799
commit c9f1162a6f

View File

@ -446,14 +446,14 @@ impl TypeId {
/// # Note /// # Note
/// ///
/// This is intended for diagnostic use. The exact contents and format of the /// This is intended for diagnostic use. The exact contents and format of the
/// string are not specified, other than being a best-effort description of the /// string retrned are not specified, other than being a best-effort description
/// type. For example, `type_name::<Option<String>>()` could return the /// of the type. For example, amongst the strings
/// `"Option<String>"` or `"std::option::Option<std::string::String>"`, but not /// that `type_name::<Option<String>>()` might map to are `"Option<String>"` and
/// `"foobar"`. In addition, the output may change between versions of the /// `"std::option::Option<std::string::String>"`.
/// compiler.
/// ///
/// The type name should not be considered a unique identifier of a type; /// The returned string must not be considered to be a unique identifier of a
/// multiple types may share the same type name. /// type as multiple types may map to the same type name. In addition, the
/// output may change between versions of the compiler.
/// ///
/// The current implementation uses the same infrastructure as compiler /// The current implementation uses the same infrastructure as compiler
/// diagnostics and debuginfo, but this is not guaranteed. /// diagnostics and debuginfo, but this is not guaranteed.