internal: Shrink TraitImpls and InherentImpls HashMaps

This commit is contained in:
Lukas Wirth 2021-12-09 18:39:46 +01:00
parent e1a236d65e
commit c469f8abcb

View File

@ -142,6 +142,7 @@ impl TraitImpls {
let crate_def_map = db.crate_def_map(krate); let crate_def_map = db.crate_def_map(krate);
impls.collect_def_map(db, &crate_def_map); impls.collect_def_map(db, &crate_def_map);
impls.shrink_to_fit();
Arc::new(impls) Arc::new(impls)
} }
@ -155,10 +156,32 @@ impl TraitImpls {
let block_def_map = db.block_def_map(block)?; let block_def_map = db.block_def_map(block)?;
impls.collect_def_map(db, &block_def_map); impls.collect_def_map(db, &block_def_map);
impls.shrink_to_fit();
Some(Arc::new(impls)) Some(Arc::new(impls))
} }
pub(crate) fn trait_impls_in_deps_query(db: &dyn HirDatabase, krate: CrateId) -> Arc<Self> {
let _p = profile::span("trait_impls_in_deps_query");
let crate_graph = db.crate_graph();
let mut res = Self { map: FxHashMap::default() };
for krate in crate_graph.transitive_deps(krate) {
res.merge(&db.trait_impls_in_crate(krate));
}
res.shrink_to_fit();
Arc::new(res)
}
fn shrink_to_fit(&mut self) {
self.map.shrink_to_fit();
self.map.values_mut().for_each(|map| {
map.shrink_to_fit();
map.values_mut().for_each(Vec::shrink_to_fit);
});
}
fn collect_def_map(&mut self, db: &dyn HirDatabase, def_map: &DefMap) { fn collect_def_map(&mut self, db: &dyn HirDatabase, def_map: &DefMap) {
for (_module_id, module_data) in def_map.modules() { for (_module_id, module_data) in def_map.modules() {
for impl_id in module_data.scope.impls() { for impl_id in module_data.scope.impls() {
@ -187,18 +210,6 @@ impl TraitImpls {
} }
} }
pub(crate) fn trait_impls_in_deps_query(db: &dyn HirDatabase, krate: CrateId) -> Arc<Self> {
let _p = profile::span("trait_impls_in_deps_query");
let crate_graph = db.crate_graph();
let mut res = Self { map: FxHashMap::default() };
for krate in crate_graph.transitive_deps(krate) {
res.merge(&db.trait_impls_in_crate(krate));
}
Arc::new(res)
}
fn merge(&mut self, other: &Self) { fn merge(&mut self, other: &Self) {
for (trait_, other_map) in &other.map { for (trait_, other_map) in &other.map {
let map = self.map.entry(*trait_).or_default(); let map = self.map.entry(*trait_).or_default();
@ -264,6 +275,7 @@ impl InherentImpls {
let crate_def_map = db.crate_def_map(krate); let crate_def_map = db.crate_def_map(krate);
impls.collect_def_map(db, &crate_def_map); impls.collect_def_map(db, &crate_def_map);
impls.shrink_to_fit();
return Arc::new(impls); return Arc::new(impls);
} }
@ -275,11 +287,17 @@ impl InherentImpls {
let mut impls = Self { map: FxHashMap::default() }; let mut impls = Self { map: FxHashMap::default() };
if let Some(block_def_map) = db.block_def_map(block) { if let Some(block_def_map) = db.block_def_map(block) {
impls.collect_def_map(db, &block_def_map); impls.collect_def_map(db, &block_def_map);
impls.shrink_to_fit();
return Some(Arc::new(impls)); return Some(Arc::new(impls));
} }
return None; return None;
} }
fn shrink_to_fit(&mut self) {
self.map.values_mut().for_each(Vec::shrink_to_fit);
self.map.shrink_to_fit();
}
fn collect_def_map(&mut self, db: &dyn HirDatabase, def_map: &DefMap) { fn collect_def_map(&mut self, db: &dyn HirDatabase, def_map: &DefMap) {
for (_module_id, module_data) in def_map.modules() { for (_module_id, module_data) in def_map.modules() {
for impl_id in module_data.scope.impls() { for impl_id in module_data.scope.impls() {