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/struct_impl.rs | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 'engine-macros/src/reflection/struct_impl.rs') diff --git a/engine-macros/src/reflection/struct_impl.rs b/engine-macros/src/reflection/struct_impl.rs index b1adea5..ce1086b 100644 --- a/engine-macros/src/reflection/struct_impl.rs +++ b/engine-macros/src/reflection/struct_impl.rs @@ -1,5 +1,6 @@ use quote::quote; +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}; @@ -49,6 +50,8 @@ pub fn generate(input: syn::ItemStruct) -> proc_macro2::TokenStream ) }); + let get_default_value_fn = gen_get_default_value_fn(&input_ident, &type_generics); + quote! { unsafe impl #impl_generics #engine_crate_path::reflection::Reflection for #input_ident #type_generics #where_clause @@ -59,7 +62,10 @@ pub fn generate(input: syn::ItemStruct) -> proc_macro2::TokenStream #engine_crate_path::reflection::Struct { fields: &[ #(#fields),* - ] + ], + get_default_value: || { + #get_default_value_fn + } } ) }; -- cgit v1.2.3-18-g5258