From 6faeef299779aec0f1bb77febad1bbac7eaf2d59 Mon Sep 17 00:00:00 2001 From: Thierry Berger Date: Wed, 7 Jun 2023 13:12:27 +0200 Subject: [PATCH] add TypePath + new test + fix inner representation to SmolStr --- crates/bevy_reflect/src/impls/smol_str.rs | 63 ++++++++++++++++++----- 1 file changed, 51 insertions(+), 12 deletions(-) diff --git a/crates/bevy_reflect/src/impls/smol_str.rs b/crates/bevy_reflect/src/impls/smol_str.rs index 738e64d773698..b5dc9442edc39 100644 --- a/crates/bevy_reflect/src/impls/smol_str.rs +++ b/crates/bevy_reflect/src/impls/smol_str.rs @@ -6,12 +6,13 @@ use std::{ use smol_str::SmolStr; use crate::{ - utility::{reflect_hasher, NonGenericTypeInfoCell}, - FromReflect, FromType, GetTypeRegistration, Reflect, ReflectDeserialize, ReflectFromPtr, - ReflectMut, ReflectOwned, ReflectRef, ReflectSerialize, TypeInfo, TypeRegistration, Typed, - ValueInfo, + utility::{reflect_hasher, GenericTypePathCell, NonGenericTypeInfoCell}, + FromReflect, FromType, GetTypeRegistration, Reflect, ReflectFromPtr, ReflectMut, ReflectOwned, + ReflectRef, TypeInfo, TypePath, TypeRegistration, Typed, ValueInfo, }; +use crate::{ReflectDeserialize, ReflectSerialize}; + impl Reflect for SmolStr { fn type_name(&self) -> &str { std::any::type_name::() @@ -47,10 +48,17 @@ impl Reflect for SmolStr { fn apply(&mut self, value: &dyn Reflect) { let value = value.as_any(); - if let Some(value) = value.downcast_ref::() { + + if let Some(value) = value.downcast_ref::() { + *self = value.clone(); + } else if let Some(value) = value.downcast_ref::() { *self = SmolStr::new(value); } else { - panic!("Value is not a {}.", std::any::type_name::()); + panic!( + "Value is not a {} nor a {}.", + std::any::type_name::(), + std::any::type_name::() + ); } } @@ -99,6 +107,30 @@ impl Typed for SmolStr { } } +impl TypePath for SmolStr { + fn type_path() -> &'static str { + static CELL: GenericTypePathCell = GenericTypePathCell::new(); + CELL.get_or_insert::(|| "smol_str::SmolStr".to_owned()) + } + + fn short_type_path() -> &'static str { + static CELL: GenericTypePathCell = GenericTypePathCell::new(); + CELL.get_or_insert::(|| "SmolStr".to_owned()) + } + + fn type_ident() -> Option<&'static str> { + Some("SmolStr") + } + + fn crate_name() -> Option<&'static str> { + Some("smol_str") + } + + fn module_path() -> Option<&'static str> { + Some("SmolStr") + } +} + impl GetTypeRegistration for SmolStr { fn get_type_registration() -> TypeRegistration { let mut registration = TypeRegistration::of::(); @@ -114,21 +146,28 @@ impl GetTypeRegistration for SmolStr { impl FromReflect for SmolStr { fn from_reflect(reflect: &dyn crate::Reflect) -> Option { - Some(reflect.as_any().downcast_ref::()?.into()) + Some(reflect.as_any().downcast_ref::()?.clone()) } } #[cfg(test)] mod tests { - use crate::Reflect; + use crate::{FromReflect, Reflect}; use smol_str::SmolStr; #[test] fn should_partial_eq_smolstr() { let a: &dyn Reflect = &SmolStr::new("A"); - let b: &dyn Reflect = &SmolStr::new("A"); - let c: &dyn Reflect = &SmolStr::new("B"); - assert_eq!(Some(true), a.reflect_partial_eq(b)); - assert_ne!(Some(false), a.reflect_partial_eq(c)); + let a2: &dyn Reflect = &SmolStr::new("A"); + let b: &dyn Reflect = &SmolStr::new("B"); + assert_eq!(Some(true), a.reflect_partial_eq(a2)); + assert_eq!(Some(false), a.reflect_partial_eq(b)); + } + + #[test] + fn smolstr_should_from_reflect() { + let smolstr = SmolStr::new("hello_world.rs"); + let output = ::from_reflect(&smolstr); + assert_eq!(Some(smolstr), output); } }