use crate::impls::{impl_type_path, impl_typed}; use crate::utility::WhereClauseOptions; use crate::ReflectMeta; use bevy_macro_utils::fq_std::{FQAny, FQBox, FQClone, FQOption, FQResult}; use quote::quote; /// Implements `GetTypeRegistration` and `Reflect` for the given type data. pub(crate) fn impl_value(meta: &ReflectMeta) -> proc_macro2::TokenStream { let bevy_reflect_path = meta.bevy_reflect_path(); let type_path = meta.type_path(); let hash_fn = meta.attrs().get_hash_impl(bevy_reflect_path); let partial_eq_fn = meta.attrs().get_partial_eq_impl(bevy_reflect_path); let debug_fn = meta.attrs().get_debug_impl(); #[cfg(feature = "documentation")] let with_docs = { let doc = quote::ToTokens::to_token_stream(meta.doc()); Some(quote!(.with_docs(#doc))) }; #[cfg(not(feature = "documentation"))] let with_docs: Option = None; let where_clause_options = WhereClauseOptions::new(meta); let typed_impl = impl_typed( meta, &where_clause_options, quote! { let info = #bevy_reflect_path::ValueInfo::new::() #with_docs; #bevy_reflect_path::TypeInfo::Value(info) }, ); let type_path_impl = impl_type_path(meta); let (impl_generics, ty_generics, where_clause) = type_path.generics().split_for_impl(); let where_reflect_clause = where_clause_options.extend_where_clause(where_clause); let get_type_registration_impl = meta.get_type_registration(&where_clause_options); quote! { #get_type_registration_impl #type_path_impl #typed_impl impl #impl_generics #bevy_reflect_path::Reflect for #type_path #ty_generics #where_reflect_clause { #[inline] fn get_represented_type_info(&self) -> #FQOption<&'static #bevy_reflect_path::TypeInfo> { #FQOption::Some(::type_info()) } #[inline] fn into_any(self: #FQBox) -> #FQBox { self } #[inline] fn as_any(&self) -> &dyn #FQAny { self } #[inline] fn as_any_mut(&mut self) -> &mut dyn #FQAny { self } #[inline] fn into_reflect(self: #FQBox) -> #FQBox { self } #[inline] fn as_reflect(&self) -> &dyn #bevy_reflect_path::Reflect { self } #[inline] fn as_reflect_mut(&mut self) -> &mut dyn #bevy_reflect_path::Reflect { self } #[inline] fn clone_value(&self) -> #FQBox { #FQBox::new(#FQClone::clone(self)) } #[inline] fn try_apply(&mut self, value: &dyn #bevy_reflect_path::Reflect) -> #FQResult<(), #bevy_reflect_path::ApplyError> { let any = #bevy_reflect_path::Reflect::as_any(value); if let #FQOption::Some(value) = ::downcast_ref::(any) { *self = #FQClone::clone(value); } else { return #FQResult::Err( #bevy_reflect_path::ApplyError::MismatchedTypes { from_type: ::core::convert::Into::into(#bevy_reflect_path::DynamicTypePath::reflect_type_path(value)), to_type: ::core::convert::Into::into(::type_path()), } ); } #FQResult::Ok(()) } #[inline] fn set(&mut self, value: #FQBox) -> #FQResult<(), #FQBox> { *self = ::take(value)?; #FQResult::Ok(()) } #[inline] fn reflect_kind(&self) -> #bevy_reflect_path::ReflectKind { #bevy_reflect_path::ReflectKind::Value } #[inline] fn reflect_ref(&self) -> #bevy_reflect_path::ReflectRef { #bevy_reflect_path::ReflectRef::Value(self) } #[inline] fn reflect_mut(&mut self) -> #bevy_reflect_path::ReflectMut { #bevy_reflect_path::ReflectMut::Value(self) } #[inline] fn reflect_owned(self: #FQBox) -> #bevy_reflect_path::ReflectOwned { #bevy_reflect_path::ReflectOwned::Value(self) } #hash_fn #partial_eq_fn #debug_fn } } }