Skip to content

Commit 4151b09

Browse files
authored
Merge pull request #443 from Veykril/self-span
Preserve span of receiver for query trait functions
2 parents c38077f + 0038ae2 commit 4151b09

File tree

1 file changed

+9
-5
lines changed

1 file changed

+9
-5
lines changed

Diff for: components/salsa-macros/src/query_group.rs

+9-5
Original file line numberDiff line numberDiff line change
@@ -109,8 +109,8 @@ pub(crate) fn query_group(args: TokenStream, input: TokenStream) -> TokenStream
109109

110110
// Extract keys.
111111
let mut iter = method.sig.inputs.iter();
112-
match iter.next() {
113-
Some(FnArg::Receiver(sr)) if sr.mutability.is_none() => (),
112+
let self_receiver = match iter.next() {
113+
Some(FnArg::Receiver(sr)) if sr.mutability.is_none() => sr,
114114
_ => {
115115
return Error::new(
116116
sig_span,
@@ -119,7 +119,7 @@ pub(crate) fn query_group(args: TokenStream, input: TokenStream) -> TokenStream
119119
.to_compile_error()
120120
.into();
121121
}
122-
}
122+
};
123123
let mut keys: Vec<(Ident, Type)> = vec![];
124124
for (idx, arg) in iter.enumerate() {
125125
match arg {
@@ -176,6 +176,7 @@ pub(crate) fn query_group(args: TokenStream, input: TokenStream) -> TokenStream
176176
query_type: lookup_query_type,
177177
query_name: format!("{}", lookup_fn_name),
178178
fn_name: lookup_fn_name,
179+
receiver: self_receiver.clone(),
179180
attrs: vec![], // FIXME -- some automatically generated docs on this method?
180181
storage: QueryStorage::InternedLookup {
181182
intern_query_type: query_type.clone(),
@@ -193,6 +194,7 @@ pub(crate) fn query_group(args: TokenStream, input: TokenStream) -> TokenStream
193194
query_type,
194195
query_name,
195196
fn_name: method.sig.ident,
197+
receiver: self_receiver.clone(),
196198
attrs,
197199
storage,
198200
keys,
@@ -218,10 +220,11 @@ pub(crate) fn query_group(args: TokenStream, input: TokenStream) -> TokenStream
218220
let fn_name = &query.fn_name;
219221
let qt = &query.query_type;
220222
let attrs = &query.attrs;
223+
let self_receiver = &query.receiver;
221224

222225
query_fn_declarations.extend(quote! {
223226
#(#attrs)*
224-
fn #fn_name(&self, #(#key_names: #keys),*) -> #value;
227+
fn #fn_name(#self_receiver, #(#key_names: #keys),*) -> #value;
225228
});
226229

227230
// Special case: transparent queries don't create actual storage,
@@ -277,7 +280,7 @@ pub(crate) fn query_group(args: TokenStream, input: TokenStream) -> TokenStream
277280
specific durability instead of the default of
278281
`Durability::LOW`. You can use `Durability::MAX`
279282
to promise that its value will never change again.
280-
283+
281284
See `{fn_name}` for details.
282285
283286
*Note:* Setting values will trigger cancellation
@@ -720,6 +723,7 @@ fn filter_attrs(attrs: Vec<Attribute>) -> (Vec<Attribute>, Vec<SalsaAttr>) {
720723
#[derive(Debug)]
721724
struct Query {
722725
fn_name: Ident,
726+
receiver: syn::Receiver,
723727
query_name: String,
724728
attrs: Vec<syn::Attribute>,
725729
query_type: Ident,

0 commit comments

Comments
 (0)