From 1560634f96d637483e7729ddd51787ea69d542bb Mon Sep 17 00:00:00 2001 From: Niko Matsakis Date: Thu, 23 May 2024 20:52:06 -0400 Subject: [PATCH] support methods with 'db lifetimes --- .../salsa-2022-macros/src/tracked_fn.rs | 20 +++++++++++++++---- .../tests/warnings/needless_lifetimes.rs | 10 +++++----- 2 files changed, 21 insertions(+), 9 deletions(-) diff --git a/components/salsa-2022-macros/src/tracked_fn.rs b/components/salsa-2022-macros/src/tracked_fn.rs index 8236cd59..48bc980f 100644 --- a/components/salsa-2022-macros/src/tracked_fn.rs +++ b/components/salsa-2022-macros/src/tracked_fn.rs @@ -142,6 +142,7 @@ pub(crate) fn tracked_impl( }; let name = format!("{}_{}", name_prefix, item_method.sig.ident); Some(tracked_method( + &item_impl.generics, &args, inner_args, item_method, @@ -160,11 +161,14 @@ pub(crate) fn tracked_impl( acc })?; - Ok(quote! { - #item_impl + Ok(crate::debug::dump_tokens( + self_type_name, + quote! { + #item_impl - #(#extra_impls)* - }) + #(#extra_impls)* + }, + )) } struct TrackedImpl; @@ -192,6 +196,7 @@ impl crate::options::AllowedOptions for TrackedImpl { } fn tracked_method( + impl_generics: &syn::Generics, outer_args: &ImplArgs, mut args: FnArgs, item_method: &mut syn::ImplItemFn, @@ -214,6 +219,12 @@ fn tracked_method( block: Box::new(rename_self_in_block(item_method.block.clone())?), }; item_fn.sig.ident = syn::Ident::new(name, item_fn.sig.ident.span()); + + // Insert the generics from impl at the start of the fn generics + for parameter in impl_generics.params.iter().rev() { + item_fn.sig.generics.params.insert(0, parameter.clone()); + } + // Flip the first and second arguments as the rest of the code expects the // database to come first and the struct to come second. We also need to // change the self argument to a normal typed argument called __salsa_self. @@ -222,6 +233,7 @@ fn tracked_method( syn::FnArg::Receiver(r) if r.reference.is_none() => r, arg => return Err(syn::Error::new(arg.span(), "first argument must be self")), }; + let db_param = original_inputs.next().unwrap().into_value(); let mut inputs = syn::punctuated::Punctuated::new(); inputs.push(db_param); diff --git a/salsa-2022-tests/tests/warnings/needless_lifetimes.rs b/salsa-2022-tests/tests/warnings/needless_lifetimes.rs index 19b322cf..3612d39b 100644 --- a/salsa-2022-tests/tests/warnings/needless_lifetimes.rs +++ b/salsa-2022-tests/tests/warnings/needless_lifetimes.rs @@ -1,24 +1,24 @@ pub trait Db: salsa::DbWithJar {} #[salsa::jar(db = Db)] -pub struct Jar(SourceTree, SourceTree_all_items, use_tree); +pub struct Jar(SourceTree<'_>, SourceTree_all_items, use_tree); #[derive(Debug, PartialEq, Eq, Hash)] pub struct Item {} #[salsa::tracked(jar = Jar)] -pub struct SourceTree {} +pub struct SourceTree<'db> {} #[salsa::tracked(jar = Jar)] -impl SourceTree { +impl<'db> SourceTree<'db> { #[salsa::tracked(return_ref)] - pub fn all_items(self, _db: &dyn Db) -> Vec { + pub fn all_items(self, _db: &'db dyn Db) -> Vec { todo!() } } #[salsa::tracked(jar = Jar, return_ref)] -fn use_tree(_db: &dyn Db, _tree: SourceTree) {} +fn use_tree<'db>(_db: &'db dyn Db, _tree: SourceTree<'db>) {} #[allow(unused)] fn use_it(db: &dyn Db, tree: SourceTree) {