mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-12 05:08:52 +00:00
shrink_to_fit TokenMap
's backing storage
This commit is contained in:
parent
9daba961f2
commit
2d799cf5e0
2 changed files with 5 additions and 1 deletions
|
@ -76,6 +76,8 @@ pub struct HygieneFrame {
|
||||||
|
|
||||||
impl HygieneFrames {
|
impl HygieneFrames {
|
||||||
fn new(db: &dyn AstDatabase, file_id: HirFileId) -> Self {
|
fn new(db: &dyn AstDatabase, file_id: HirFileId) -> Self {
|
||||||
|
// Note that this intentionally avoids the `hygiene_frame` query to avoid blowing up memory
|
||||||
|
// usage. The query is only helpful for nested `HygieneFrame`s as it avoids redundant work.
|
||||||
HygieneFrames(Arc::new(HygieneFrame::new(db, file_id)))
|
HygieneFrames(Arc::new(HygieneFrame::new(db, file_id)))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -51,6 +51,7 @@ pub fn syntax_node_to_token_tree(node: &SyntaxNode) -> Option<(tt::Subtree, Toke
|
||||||
let global_offset = node.text_range().start();
|
let global_offset = node.text_range().start();
|
||||||
let mut c = Convertor::new(node, global_offset);
|
let mut c = Convertor::new(node, global_offset);
|
||||||
let subtree = c.go()?;
|
let subtree = c.go()?;
|
||||||
|
c.id_alloc.map.entries.shrink_to_fit();
|
||||||
Some((subtree, c.id_alloc.map))
|
Some((subtree, c.id_alloc.map))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -593,7 +594,8 @@ impl<'a> TtTreeSink<'a> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn finish(self) -> (Parse<SyntaxNode>, TokenMap) {
|
fn finish(mut self) -> (Parse<SyntaxNode>, TokenMap) {
|
||||||
|
self.token_map.entries.shrink_to_fit();
|
||||||
(self.inner.finish(), self.token_map)
|
(self.inner.finish(), self.token_map)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue