Force codegen in the query-defning crate

This commit is contained in:
Aleksey Kladov 2020-07-06 18:19:02 +02:00 committed by Niko Matsakis
parent b66eb81311
commit a5626cd8a0

View file

@ -180,6 +180,7 @@ pub(crate) fn query_group(args: TokenStream, input: TokenStream) -> TokenStream
let mut query_fn_declarations = proc_macro2::TokenStream::new();
let mut query_fn_definitions = proc_macro2::TokenStream::new();
let mut query_fn_shims = proc_macro2::TokenStream::new();
let mut storage_fields = proc_macro2::TokenStream::new();
let mut queries_with_storage = vec![];
for query in &queries {
@ -211,9 +212,16 @@ pub(crate) fn query_group(args: TokenStream, input: TokenStream) -> TokenStream
queries_with_storage.push(fn_name);
let shim = format_ident!("{}_shim", fn_name);
query_fn_definitions.extend(quote! {
fn #fn_name(&self, #(#key_names: #keys),*) -> #value {
salsa::plumbing::get_query_table::<#qt>(self).get((#(#key_names),*))
#shim(self, #(#key_names),*)
}
});
query_fn_shims.extend(quote! {
fn #shim(db: &dyn #trait_name, #(#key_names: #keys),*) -> #value {
salsa::plumbing::get_query_table::<#qt>(db).get((#(#key_names),*))
}
});
@ -290,6 +298,8 @@ pub(crate) fn query_group(args: TokenStream, input: TokenStream) -> TokenStream
{
#query_fn_declarations
}
#query_fn_shims
}
};