From 8b7f58976b32ccc768e35151b77aa9ea004b7495 Mon Sep 17 00:00:00 2001 From: Aleksey Kladov Date: Sun, 2 Jun 2019 20:15:10 +0300 Subject: don't cache parses twice Before this commit, `Parse`s for original file ended up two times in salsa's db: first, when we parse original file, and second, when we parse macro or a file. Given that parse trees are the worst ofenders in terms of memory, it makes sense to make sure we store them only once. --- crates/ra_ide_api/src/change.rs | 2 +- crates/ra_ide_api/src/status.rs | 34 ++++++++++++++++++++++++++++------ 2 files changed, 29 insertions(+), 7 deletions(-) (limited to 'crates/ra_ide_api/src') diff --git a/crates/ra_ide_api/src/change.rs b/crates/ra_ide_api/src/change.rs index 02814ce56..247dc0fee 100644 --- a/crates/ra_ide_api/src/change.rs +++ b/crates/ra_ide_api/src/change.rs @@ -226,7 +226,7 @@ impl RootDatabase { self.query(ra_db::ParseQuery).sweep(sweep); - self.query(hir::db::ParseOrExpandQuery).sweep(sweep); + self.query(hir::db::ParseMacroQuery).sweep(sweep); self.query(hir::db::MacroDefQuery).sweep(sweep); self.query(hir::db::MacroArgQuery).sweep(sweep); self.query(hir::db::MacroExpandQuery).sweep(sweep); diff --git a/crates/ra_ide_api/src/status.rs b/crates/ra_ide_api/src/status.rs index 822279812..0cdeb15eb 100644 --- a/crates/ra_ide_api/src/status.rs +++ b/crates/ra_ide_api/src/status.rs @@ -4,12 +4,12 @@ use std::{ sync::Arc, }; -use ra_syntax::{TreeArc, SyntaxNode}; +use ra_syntax::{TreeArc, SyntaxNode, Parse, AstNode}; use ra_db::{ FileTextQuery, SourceRootId, salsa::{Database, debug::{DebugQueryTable, TableEntry}}, }; -use hir::HirFileId; +use hir::MacroFile; use crate::{ FileId, db::RootDatabase, @@ -17,18 +17,23 @@ use crate::{ }; pub(crate) fn syntax_tree_stats(db: &RootDatabase) -> SyntaxTreeStats { - db.query(hir::db::ParseOrExpandQuery).entries::() + db.query(ra_db::ParseQuery).entries::() +} +pub(crate) fn macro_syntax_tree_stats(db: &RootDatabase) -> SyntaxTreeStats { + db.query(hir::db::ParseMacroQuery).entries::() } pub(crate) fn status(db: &RootDatabase) -> String { let files_stats = db.query(FileTextQuery).entries::(); let syntax_tree_stats = syntax_tree_stats(db); + let macro_syntax_tree_stats = macro_syntax_tree_stats(db); let symbols_stats = db.query(LibrarySymbolsQuery).entries::(); format!( - "{}\n{}\n{}\n\n\nmemory:\n{}\ngc {:?} seconds ago", + "{}\n{}\n{}\n{} (macros)\n\n\nmemory:\n{}\ngc {:?} seconds ago", files_stats, symbols_stats, syntax_tree_stats, + macro_syntax_tree_stats, MemoryStats::current(), db.last_gc.elapsed().as_secs(), ) @@ -73,10 +78,27 @@ impl fmt::Display for SyntaxTreeStats { } } -impl FromIterator>>> for SyntaxTreeStats { +impl FromIterator> for SyntaxTreeStats { + fn from_iter(iter: T) -> SyntaxTreeStats + where + T: IntoIterator>, + { + let mut res = SyntaxTreeStats::default(); + for entry in iter { + res.total += 1; + if let Some(tree) = entry.value.as_ref().map(|it| &it.tree) { + res.retained += 1; + res.retained_size += tree.syntax().memory_size_of_subtree(); + } + } + res + } +} + +impl FromIterator>>> for SyntaxTreeStats { fn from_iter(iter: T) -> SyntaxTreeStats where - T: IntoIterator>>>, + T: IntoIterator>>>, { let mut res = SyntaxTreeStats::default(); for entry in iter { -- cgit v1.2.3