aboutsummaryrefslogtreecommitdiff
path: root/crates/ra_hir_def/src/db.rs
blob: 7133b61dba5de2dfc33857c8b79fa5c8ec907637 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
use std::sync::Arc;

use ra_db::{salsa, SourceDatabase};
use ra_syntax::{Parse, SyntaxNode};

use crate::{
    ast_id_map::{AstIdMap, ErasedFileAstId},
    expand::{HirFileId, MacroCallId, MacroCallLoc, MacroDefId, MacroFile},
};

#[salsa::query_group(AstDatabaseStorage)]
pub trait AstDatabase: SourceDatabase {
    fn ast_id_map(&self, file_id: HirFileId) -> Arc<AstIdMap>;
    #[salsa::transparent]
    fn ast_id_to_node(&self, file_id: HirFileId, ast_id: ErasedFileAstId) -> SyntaxNode;

    #[salsa::transparent]
    #[salsa::invoke(crate::expand::parse_or_expand_query)]
    fn parse_or_expand(&self, file_id: HirFileId) -> Option<SyntaxNode>;

    #[salsa::interned]
    fn intern_macro(&self, macro_call: MacroCallLoc) -> MacroCallId;
    #[salsa::invoke(crate::expand::macro_arg_query)]
    fn macro_arg(&self, id: MacroCallId) -> Option<Arc<tt::Subtree>>;
    #[salsa::invoke(crate::expand::macro_def_query)]
    fn macro_def(&self, id: MacroDefId) -> Option<Arc<mbe::MacroRules>>;
    #[salsa::invoke(crate::expand::parse_macro_query)]
    fn parse_macro(&self, macro_file: MacroFile) -> Option<Parse<SyntaxNode>>;
    #[salsa::invoke(crate::expand::macro_expand_query)]
    fn macro_expand(&self, macro_call: MacroCallId) -> Result<Arc<tt::Subtree>, String>;
}

pub(crate) fn ast_id_map(db: &impl AstDatabase, file_id: HirFileId) -> Arc<AstIdMap> {
    let map =
        db.parse_or_expand(file_id).map_or_else(AstIdMap::default, |it| AstIdMap::from_source(&it));
    Arc::new(map)
}

pub(crate) fn ast_id_to_node(
    db: &impl AstDatabase,
    file_id: HirFileId,
    ast_id: ErasedFileAstId,
) -> SyntaxNode {
    let node = db.parse_or_expand(file_id).unwrap();
    db.ast_id_map(file_id)[ast_id].to_node(&node)
}