diff --git a/compiler/rustc_middle/src/ty/query/plumbing.rs b/compiler/rustc_middle/src/ty/query/plumbing.rs index 91a267e38d5a..b084fd013274 100644 --- a/compiler/rustc_middle/src/ty/query/plumbing.rs +++ b/compiler/rustc_middle/src/ty/query/plumbing.rs @@ -450,8 +450,7 @@ macro_rules! define_queries { Err(lookup) => lookup, }; - let qcx = QueryCtxt(self.tcx); - get_query::, _>(qcx, DUMMY_SP, key, lookup, QueryMode::Ensure); + self.tcx.queries.$name(self.tcx, DUMMY_SP, key, lookup, QueryMode::Ensure); })* } @@ -542,8 +541,7 @@ macro_rules! define_queries { Err(lookup) => lookup, }; - let qcx = QueryCtxt(self.tcx); - get_query::, _>(qcx, self.span, key, lookup, QueryMode::Get).unwrap() + self.tcx.queries.$name(self.tcx, self.span, key, lookup, QueryMode::Get).unwrap() })* } @@ -598,6 +596,20 @@ macro_rules! define_queries_struct { Some(jobs) } + + $($(#[$attr])* + #[inline(always)] + fn $name( + &self, + tcx: TyCtxt<$tcx>, + span: Span, + key: query_keys::$name<$tcx>, + lookup: QueryLookup, + mode: QueryMode, + ) -> Option> { + let qcx = QueryCtxt(tcx); + get_query::, _>(qcx, span, key, lookup, mode) + })* } }; }