From db625c0d1ed3c93220902034bd81a478ceded9a1 Mon Sep 17 00:00:00 2001 From: Freja Roberts Date: Fri, 29 Mar 2024 12:55:22 +0100 Subject: [PATCH] fix: don't generate transformed types if there are no transform attrs --- flax-derive/src/lib.rs | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/flax-derive/src/lib.rs b/flax-derive/src/lib.rs index 230d801..6456071 100644 --- a/flax-derive/src/lib.rs +++ b/flax-derive/src/lib.rs @@ -145,7 +145,7 @@ fn derive_fetch_struct(params: &Params) -> TokenStream { // #(#field_names: <<#field_types as #crate_name::fetch::Fetch<'w>::Prepared> as #crate_name::fetch::PreparedFetch<#q_lf>>::Chunk,)* // } - // #[automatically_derived] + #[automatically_derived] impl #item_impl #crate_name::fetch::FetchItem<'q> for #fetch_name #fetch_ty { type Item = #item_name #item_ty; } @@ -239,6 +239,10 @@ fn derive_transform(params: &Params) -> Result { .. } = params; + if attrs.transforms.is_empty() { + return Ok(quote! {}); + } + // Replace all the fields with generics to allow transforming into different types let ty_generics = ('A'..='Z') .zip(fields) @@ -265,8 +269,6 @@ fn derive_transform(params: &Params) -> Result { } }); - // eprintln!("types: {:?}", types); - quote! { #vis struct #transformed_name<#(#ty_generics: for<'x> #crate_name::fetch::Fetch<'x>),*>{ #(#fields)*