pub trait TypePath: 'static {
    // Required methods
    fn type_path() -> &'static str;
    fn short_type_path() -> &'static str;

    // Provided methods
    fn type_ident() -> Option<&'static str> { ... }
    fn crate_name() -> Option<&'static str> { ... }
    fn module_path() -> Option<&'static str> { ... }
}
Expand description

A static accessor to type paths and names.

The engine uses this trait over std::any::type_name for stability and flexibility.

This trait is automatically implemented by the #[derive(Reflect)] macro and allows type path information to be processed without an instance of that type.

Implementors may have difficulty in generating references with static lifetimes. Luckily, this crate comes with some utility structs, to make generating these statics much simpler.

Stability

Certain parts of the engine, e.g. (de)serialization, rely on type paths as identifiers for matching dynamic values to concrete types.

Using std::any::type_name, a scene containing my_crate::foo::MyComponent would break, failing to deserialize if the component was moved from the foo module to the bar module, becoming my_crate::bar::MyComponent. This trait, through attributes when deriving itself or Reflect, can ensure breaking changes are avoidable.

The only external factor we rely on for stability when deriving is the module_path! macro, only if the derive does not provide a #[type_path = "..."] attribute.

Anonymity

Some methods on this trait return Option<&'static str> over &'static str because not all types define all parts of a type path, for example the array type [T; N].

Such types are ‘anonymous’ in that they have only a defined type_path and short_type_path and the methods crate_name, module_path and type_ident all return None.

Primitives are treated like anonymous types, except they also have a defined type_ident.

Example

use bevy_reflect::TypePath;

// This type path will not change with compiler versions or recompiles,
// although it will not be the same if the definition is moved.
#[derive(TypePath)]
struct NonStableTypePath;

// This type path will never change, even if the definition is moved.
#[derive(TypePath)]
#[type_path = "my_crate::foo"]
struct StableTypePath;

// Type paths can have any number of path segments.
#[derive(TypePath)]
#[type_path = "my_crate::foo::bar::baz"]
struct DeeplyNestedStableTypePath;

// Including just a crate name!
#[derive(TypePath)]
#[type_path = "my_crate"]
struct ShallowStableTypePath;

// We can also rename the identifier/name of types.
#[derive(TypePath)]
#[type_path = "my_crate::foo"]
#[type_name = "RenamedStableTypePath"]
struct NamedStableTypePath;

// Generics are also supported.
#[derive(TypePath)]
#[type_path = "my_crate::foo"]
struct StableGenericTypePath<T, const N: usize>([T; N]);

Required Methods§

source

fn type_path() -> &'static str

Returns the fully qualified path of the underlying type.

Generic parameter types are also fully expanded.

For Option<PhantomData>, this is "core::option::Option<core::marker::PhantomData>".

source

fn short_type_path() -> &'static str

Returns a short, pretty-print enabled path to the type.

Generic parameter types are also shortened.

For Option<PhantomData>, this is "Option<PhantomData>".

Provided Methods§

source

fn type_ident() -> Option<&'static str>

Returns the name of the type, or None if it is anonymous.

Primitive types will return Some.

For Option<PhantomData>, this is "Option".

source

fn crate_name() -> Option<&'static str>

Returns the name of the crate the type is in, or None if it is anonymous.

For Option<PhantomData>, this is "core".

source

fn module_path() -> Option<&'static str>

Returns the path to the moudle the type is in, or None if it is anonymous.

For Option<PhantomData>, this is "core::option".

Implementations on Foreign Types§

source§

impl<'a: 'static, T> TypePath for Cow<'a, T>where T: TypePath + PathOnly + ?Sized,

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for i8

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<T> TypePath for VecDeque<T>where T: FromReflect + TypePath,

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for String

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for u64

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for NonZeroIsize

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<T> TypePath for RangeInclusive<T>where T: TypePath + Clone + Send + Sync,

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for Duration

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<A: Reflect + TypePath, B: Reflect + TypePath, C: Reflect + TypePath, D: Reflect + TypePath, E: Reflect + TypePath, F: Reflect + TypePath, G: Reflect + TypePath, H: Reflect + TypePath, I: Reflect + TypePath> TypePath for (A, B, C, D, E, F, G, H, I)

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

impl<A: Reflect + TypePath, B: Reflect + TypePath, C: Reflect + TypePath, D: Reflect + TypePath> TypePath for (A, B, C, D)

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

impl TypePath for u8

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<A: Reflect + TypePath, B: Reflect + TypePath, C: Reflect + TypePath, D: Reflect + TypePath, E: Reflect + TypePath, F: Reflect + TypePath, G: Reflect + TypePath> TypePath for (A, B, C, D, E, F, G)

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

impl TypePath for i64

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<T: TypePath> TypePath for [T]where [T]: ToOwned,

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

impl TypePath for usize

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for Instant

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for NonZeroI16

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<A: Reflect + TypePath, B: Reflect + TypePath, C: Reflect + TypePath, D: Reflect + TypePath, E: Reflect + TypePath, F: Reflect + TypePath> TypePath for (A, B, C, D, E, F)

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

impl TypePath for NonZeroU16

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<T> TypePath for RangeTo<T>where T: TypePath + Clone + Send + Sync,

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<A: Reflect + TypePath, B: Reflect + TypePath, C: Reflect + TypePath, D: Reflect + TypePath, E: Reflect + TypePath, F: Reflect + TypePath, G: Reflect + TypePath, H: Reflect + TypePath, I: Reflect + TypePath, J: Reflect + TypePath, K: Reflect + TypePath> TypePath for (A, B, C, D, E, F, G, H, I, J, K)

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

impl TypePath for char

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<A: Reflect + TypePath, B: Reflect + TypePath, C: Reflect + TypePath> TypePath for (A, B, C)

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

impl TypePath for RangeFull

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<T> TypePath for Vec<T>where T: FromReflect + TypePath,

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for NonZeroU32

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for ()

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

impl<A: Reflect + TypePath, B: Reflect + TypePath, C: Reflect + TypePath, D: Reflect + TypePath, E: Reflect + TypePath, F: Reflect + TypePath, G: Reflect + TypePath, H: Reflect + TypePath> TypePath for (A, B, C, D, E, F, G, H)

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

impl TypePath for u128

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<A: Reflect + TypePath, B: Reflect + TypePath, C: Reflect + TypePath, D: Reflect + TypePath, E: Reflect + TypePath> TypePath for (A, B, C, D, E)

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

impl TypePath for NonZeroU64

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for bool

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for OsString

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for NonZeroU8

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for f32

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for i32

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for i128

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for Cow<'static, str>

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<A: Reflect + TypePath, B: Reflect + TypePath> TypePath for (A, B)

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

impl TypePath for RandomState

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for PathBuf

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<T: Reflect + TypePath, const N: usize> TypePath for [T; N]

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

impl TypePath for NonZeroI128

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<A: Reflect + TypePath> TypePath for (A,)

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

impl<A: Reflect + TypePath, B: Reflect + TypePath, C: Reflect + TypePath, D: Reflect + TypePath, E: Reflect + TypePath, F: Reflect + TypePath, G: Reflect + TypePath, H: Reflect + TypePath, I: Reflect + TypePath, J: Reflect + TypePath, K: Reflect + TypePath, L: Reflect + TypePath> TypePath for (A, B, C, D, E, F, G, H, I, J, K, L)

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

impl TypePath for NonZeroI8

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<T, E> TypePath for Result<T, E>where T: TypePath + Clone + Reflect + TypePath, E: TypePath + Clone + Reflect + TypePath,

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<T> TypePath for RangeToInclusive<T>where T: TypePath + Clone + Send + Sync,

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<T> TypePath for Range<T>where T: TypePath + Clone + Send + Sync,

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<T> TypePath for RangeFrom<T>where T: TypePath + Clone + Send + Sync,

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for isize

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for DefaultHashBuilder

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<T> TypePath for Option<T>where T: TypePath + FromReflect + TypePath,

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for NonZeroI64

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for NonZeroUsize

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<A: Reflect + TypePath, B: Reflect + TypePath, C: Reflect + TypePath, D: Reflect + TypePath, E: Reflect + TypePath, F: Reflect + TypePath, G: Reflect + TypePath, H: Reflect + TypePath, I: Reflect + TypePath, J: Reflect + TypePath> TypePath for (A, B, C, D, E, F, G, H, I, J)

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

impl<T> TypePath for HashSet<T>where T: TypePath + Hash + Eq + Clone + Send + Sync,

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for &'static Path

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

impl<K, V, S> TypePath for HashMap<K, V, S>where K: FromReflect + Eq + Hash + ?Sized + TypePath, V: FromReflect + ?Sized + TypePath, S: BuildHasher + Send + Sync + 'static + TypePath,

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for u32

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for u16

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for f64

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl<K, V, S> TypePath for HashMap<K, V, S>where K: FromReflect + Eq + Hash + ?Sized + TypePath, V: FromReflect + ?Sized + TypePath, S: BuildHasher + Send + Sync + 'static + TypePath,

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for Path

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for NonZeroI32

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for i16

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

source§

impl TypePath for NonZeroU128

source§

fn type_path() -> &'static str

source§

fn short_type_path() -> &'static str

source§

fn type_ident() -> Option<&'static str>

source§

fn crate_name() -> Option<&'static str>

source§

fn module_path() -> Option<&'static str>

Implementors§