From c79f7883c099f1624f9666fb8691ffc5022c1bf5 Mon Sep 17 00:00:00 2001 From: HampusM Date: Tue, 16 Jun 2026 19:07:36 +0200 Subject: feat(engine): add default value retrieval to type reflection --- engine-macros/src/reflection/enum_impl.rs | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 'engine-macros/src/reflection/enum_impl.rs') diff --git a/engine-macros/src/reflection/enum_impl.rs b/engine-macros/src/reflection/enum_impl.rs index 14142bf..611da6d 100644 --- a/engine-macros/src/reflection/enum_impl.rs +++ b/engine-macros/src/reflection/enum_impl.rs @@ -1,5 +1,6 @@ use quote::{format_ident, quote, ToTokens}; +use crate::reflection::default_value::gen_get_default_value_fn; use crate::reflection::field::{generate as generate_field, ReflectionFieldGenOptions}; use crate::util::{find_engine_crate_path, syn_path, SynPathExt}; @@ -238,6 +239,8 @@ pub fn generate(input: syn::ItemEnum) -> proc_macro2::TokenStream } }; + let get_default_value_fn = gen_get_default_value_fn(&input_ident, &type_generics); + quote! { #[doc(hidden)] mod #mod_name { @@ -254,7 +257,10 @@ pub fn generate(input: syn::ItemEnum) -> proc_macro2::TokenStream variants: &[#(#variants),*], is_unit_only: #is_unit_only, discriminant_layout: #discriminant_layout, - fields_layout: #fields_layout + fields_layout: #fields_layout, + get_default_value: || { + #get_default_value_fn + } } ) }; -- cgit v1.2.3-18-g5258