mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-15 22:54:00 +00:00
Cache file_to_def
in SourceToDefCtx
This commit is contained in:
parent
97b58f2846
commit
c12f093716
2 changed files with 40 additions and 28 deletions
|
@ -129,7 +129,7 @@ pub struct Semantics<'db, DB> {
|
||||||
|
|
||||||
pub struct SemanticsImpl<'db> {
|
pub struct SemanticsImpl<'db> {
|
||||||
pub db: &'db dyn HirDatabase,
|
pub db: &'db dyn HirDatabase,
|
||||||
s2d_cache: RefCell<(SourceToDefCache, FxHashMap<MacroFileId, hir_expand::ExpansionInfo>)>,
|
s2d_cache: RefCell<SourceToDefCache>,
|
||||||
/// Rootnode to HirFileId cache
|
/// Rootnode to HirFileId cache
|
||||||
root_to_file_cache: RefCell<FxHashMap<SyntaxNode, HirFileId>>,
|
root_to_file_cache: RefCell<FxHashMap<SyntaxNode, HirFileId>>,
|
||||||
/// MacroCall to its expansion's MacroFileId cache
|
/// MacroCall to its expansion's MacroFileId cache
|
||||||
|
@ -719,7 +719,8 @@ impl<'db> SemanticsImpl<'db> {
|
||||||
let macro_file = invoc.as_macro_file();
|
let macro_file = invoc.as_macro_file();
|
||||||
let expansion_info = {
|
let expansion_info = {
|
||||||
self.with_ctx(|ctx| {
|
self.with_ctx(|ctx| {
|
||||||
ctx.expansion_info_cache
|
ctx.cache
|
||||||
|
.expansion_info_cache
|
||||||
.entry(macro_file)
|
.entry(macro_file)
|
||||||
.or_insert_with(|| {
|
.or_insert_with(|| {
|
||||||
let exp_info = macro_file.expansion_info(self.db.upcast());
|
let exp_info = macro_file.expansion_info(self.db.upcast());
|
||||||
|
@ -806,7 +807,8 @@ impl<'db> SemanticsImpl<'db> {
|
||||||
let process_expansion_for_token = |stack: &mut Vec<_>, macro_file| {
|
let process_expansion_for_token = |stack: &mut Vec<_>, macro_file| {
|
||||||
let InMacroFile { file_id, value: mapped_tokens } = self.with_ctx(|ctx| {
|
let InMacroFile { file_id, value: mapped_tokens } = self.with_ctx(|ctx| {
|
||||||
Some(
|
Some(
|
||||||
ctx.expansion_info_cache
|
ctx.cache
|
||||||
|
.expansion_info_cache
|
||||||
.entry(macro_file)
|
.entry(macro_file)
|
||||||
.or_insert_with(|| {
|
.or_insert_with(|| {
|
||||||
let exp_info = macro_file.expansion_info(self.db.upcast());
|
let exp_info = macro_file.expansion_info(self.db.upcast());
|
||||||
|
@ -1086,6 +1088,7 @@ impl<'db> SemanticsImpl<'db> {
|
||||||
|
|
||||||
self.with_ctx(|ctx| {
|
self.with_ctx(|ctx| {
|
||||||
let expansion_info = ctx
|
let expansion_info = ctx
|
||||||
|
.cache
|
||||||
.expansion_info_cache
|
.expansion_info_cache
|
||||||
.entry(macro_file)
|
.entry(macro_file)
|
||||||
.or_insert_with(|| macro_file.expansion_info(self.db.upcast()));
|
.or_insert_with(|| macro_file.expansion_info(self.db.upcast()));
|
||||||
|
@ -1364,8 +1367,7 @@ impl<'db> SemanticsImpl<'db> {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn with_ctx<F: FnOnce(&mut SourceToDefCtx<'_, '_>) -> T, T>(&self, f: F) -> T {
|
fn with_ctx<F: FnOnce(&mut SourceToDefCtx<'_, '_>) -> T, T>(&self, f: F) -> T {
|
||||||
let (dynmap_cache, expansion_info_cache) = &mut *self.s2d_cache.borrow_mut();
|
let mut ctx = SourceToDefCtx { db: self.db, cache: &mut self.s2d_cache.borrow_mut() };
|
||||||
let mut ctx = SourceToDefCtx { db: self.db, dynmap_cache, expansion_info_cache };
|
|
||||||
f(&mut ctx)
|
f(&mut ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1375,7 +1377,7 @@ impl<'db> SemanticsImpl<'db> {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn file_to_module_defs(&self, file: FileId) -> impl Iterator<Item = Module> {
|
fn file_to_module_defs(&self, file: FileId) -> impl Iterator<Item = Module> {
|
||||||
self.with_ctx(|ctx| ctx.file_to_def(file)).into_iter().map(Module::from)
|
self.with_ctx(|ctx| ctx.file_to_def(file).to_owned()).into_iter().map(Module::from)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn scope(&self, node: &SyntaxNode) -> Option<SemanticsScope<'db>> {
|
pub fn scope(&self, node: &SyntaxNode) -> Option<SemanticsScope<'db>> {
|
||||||
|
@ -1653,6 +1655,7 @@ fn macro_call_to_macro_id(
|
||||||
}
|
}
|
||||||
HirFileIdRepr::MacroFile(macro_file) => {
|
HirFileIdRepr::MacroFile(macro_file) => {
|
||||||
let expansion_info = ctx
|
let expansion_info = ctx
|
||||||
|
.cache
|
||||||
.expansion_info_cache
|
.expansion_info_cache
|
||||||
.entry(macro_file)
|
.entry(macro_file)
|
||||||
.or_insert_with(|| macro_file.expansion_info(ctx.db.upcast()));
|
.or_insert_with(|| macro_file.expansion_info(ctx.db.upcast()));
|
||||||
|
@ -1668,6 +1671,7 @@ fn macro_call_to_macro_id(
|
||||||
}
|
}
|
||||||
HirFileIdRepr::MacroFile(macro_file) => {
|
HirFileIdRepr::MacroFile(macro_file) => {
|
||||||
let expansion_info = ctx
|
let expansion_info = ctx
|
||||||
|
.cache
|
||||||
.expansion_info_cache
|
.expansion_info_cache
|
||||||
.entry(macro_file)
|
.entry(macro_file)
|
||||||
.or_insert_with(|| macro_file.expansion_info(ctx.db.upcast()));
|
.or_insert_with(|| macro_file.expansion_info(ctx.db.upcast()));
|
||||||
|
|
|
@ -112,17 +112,22 @@ use syntax::{
|
||||||
|
|
||||||
use crate::{db::HirDatabase, InFile};
|
use crate::{db::HirDatabase, InFile};
|
||||||
|
|
||||||
pub(super) type SourceToDefCache = FxHashMap<(ChildContainer, HirFileId), DynMap>;
|
#[derive(Default)]
|
||||||
|
pub(super) struct SourceToDefCache {
|
||||||
|
pub(super) dynmap_cache: FxHashMap<(ChildContainer, HirFileId), DynMap>,
|
||||||
|
pub(super) expansion_info_cache: FxHashMap<MacroFileId, ExpansionInfo>,
|
||||||
|
pub(super) file_to_def_cache: FxHashMap<FileId, SmallVec<[ModuleId; 1]>>,
|
||||||
|
}
|
||||||
|
|
||||||
pub(super) struct SourceToDefCtx<'a, 'dyn_cache> {
|
pub(super) struct SourceToDefCtx<'db, 'cache> {
|
||||||
pub(super) db: &'a dyn HirDatabase,
|
pub(super) db: &'db dyn HirDatabase,
|
||||||
pub(super) dynmap_cache: &'dyn_cache mut SourceToDefCache,
|
pub(super) cache: &'cache mut SourceToDefCache,
|
||||||
pub(super) expansion_info_cache: &'a mut FxHashMap<MacroFileId, ExpansionInfo>,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl SourceToDefCtx<'_, '_> {
|
impl SourceToDefCtx<'_, '_> {
|
||||||
pub(super) fn file_to_def(&self, file: FileId) -> SmallVec<[ModuleId; 1]> {
|
pub(super) fn file_to_def(&mut self, file: FileId) -> &SmallVec<[ModuleId; 1]> {
|
||||||
let _p = tracing::span!(tracing::Level::INFO, "SourceToDefCtx::file_to_def").entered();
|
let _p = tracing::span!(tracing::Level::INFO, "SourceToDefCtx::file_to_def").entered();
|
||||||
|
self.cache.file_to_def_cache.entry(file).or_insert_with(|| {
|
||||||
let mut mods = SmallVec::new();
|
let mut mods = SmallVec::new();
|
||||||
for &crate_id in self.db.relevant_crates(file).iter() {
|
for &crate_id in self.db.relevant_crates(file).iter() {
|
||||||
// Note: `mod` declarations in block modules cannot be supported here
|
// Note: `mod` declarations in block modules cannot be supported here
|
||||||
|
@ -137,6 +142,7 @@ impl SourceToDefCtx<'_, '_> {
|
||||||
// FIXME: detached file
|
// FIXME: detached file
|
||||||
}
|
}
|
||||||
mods
|
mods
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(super) fn module_to_def(&mut self, src: InFile<&ast::Module>) -> Option<ModuleId> {
|
pub(super) fn module_to_def(&mut self, src: InFile<&ast::Module>) -> Option<ModuleId> {
|
||||||
|
@ -166,7 +172,7 @@ impl SourceToDefCtx<'_, '_> {
|
||||||
Some(def_map.module_id(child_id))
|
Some(def_map.module_id(child_id))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(super) fn source_file_to_def(&self, src: InFile<&ast::SourceFile>) -> Option<ModuleId> {
|
pub(super) fn source_file_to_def(&mut self, src: InFile<&ast::SourceFile>) -> Option<ModuleId> {
|
||||||
let _p = tracing::span!(tracing::Level::INFO, "source_file_to_def").entered();
|
let _p = tracing::span!(tracing::Level::INFO, "source_file_to_def").entered();
|
||||||
let file_id = src.file_id.original_file(self.db.upcast());
|
let file_id = src.file_id.original_file(self.db.upcast());
|
||||||
self.file_to_def(file_id).first().copied()
|
self.file_to_def(file_id).first().copied()
|
||||||
|
@ -325,7 +331,8 @@ impl SourceToDefCtx<'_, '_> {
|
||||||
|
|
||||||
fn cache_for(&mut self, container: ChildContainer, file_id: HirFileId) -> &DynMap {
|
fn cache_for(&mut self, container: ChildContainer, file_id: HirFileId) -> &DynMap {
|
||||||
let db = self.db;
|
let db = self.db;
|
||||||
self.dynmap_cache
|
self.cache
|
||||||
|
.dynmap_cache
|
||||||
.entry((container, file_id))
|
.entry((container, file_id))
|
||||||
.or_insert_with(|| container.child_by_source(db, file_id))
|
.or_insert_with(|| container.child_by_source(db, file_id))
|
||||||
}
|
}
|
||||||
|
@ -421,6 +428,7 @@ impl SourceToDefCtx<'_, '_> {
|
||||||
let macro_file = node.file_id.macro_file()?;
|
let macro_file = node.file_id.macro_file()?;
|
||||||
|
|
||||||
let expansion_info = this
|
let expansion_info = this
|
||||||
|
.cache
|
||||||
.expansion_info_cache
|
.expansion_info_cache
|
||||||
.entry(macro_file)
|
.entry(macro_file)
|
||||||
.or_insert_with(|| macro_file.expansion_info(this.db.upcast()));
|
.or_insert_with(|| macro_file.expansion_info(this.db.upcast()));
|
||||||
|
|
Loading…
Reference in a new issue