rust-analyzer/crates/hir-def/src/lower.rs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

47 lines
1.5 KiB
Rust
Raw Normal View History

//! Context for lowering paths.
2023-09-01 15:30:59 +00:00
use std::cell::OnceCell;
2023-07-04 07:16:15 +00:00
use hir_expand::{
ast_id_map::{AstIdMap, AstIdNode},
2023-11-17 18:07:31 +00:00
AstId, HirFileId, InFile, SpanMap,
2023-07-04 07:16:15 +00:00
};
use syntax::ast;
2023-05-02 14:12:22 +00:00
use triomphe::Arc;
use crate::{db::DefDatabase, path::Path};
pub struct LowerCtx<'a> {
pub db: &'a dyn DefDatabase,
2023-11-17 18:07:31 +00:00
hygiene: Arc<SpanMap>,
// FIXME: This optimization is probably pointless, ast id map should pretty much always exist anyways.
ast_id_map: Option<(HirFileId, OnceCell<Arc<AstIdMap>>)>,
}
impl<'a> LowerCtx<'a> {
2023-11-17 18:07:31 +00:00
pub fn new(db: &'a dyn DefDatabase, hygiene: Arc<SpanMap>, file_id: HirFileId) -> Self {
LowerCtx { db, hygiene, ast_id_map: Some((file_id, OnceCell::new())) }
}
pub fn with_file_id(db: &'a dyn DefDatabase, file_id: HirFileId) -> Self {
2023-11-17 18:07:31 +00:00
LowerCtx { db, hygiene: db.span_map(file_id), ast_id_map: Some((file_id, OnceCell::new())) }
}
2023-11-17 18:07:31 +00:00
pub fn with_hygiene(db: &'a dyn DefDatabase, hygiene: Arc<SpanMap>) -> Self {
LowerCtx { db, hygiene, ast_id_map: None }
}
2023-11-17 18:07:31 +00:00
pub(crate) fn span_map(&self) -> &SpanMap {
&self.hygiene
}
pub(crate) fn lower_path(&self, ast: ast::Path) -> Option<Path> {
Path::from_src(ast, self)
}
2023-07-04 07:16:15 +00:00
pub(crate) fn ast_id<N: AstIdNode>(&self, item: &N) -> Option<AstId<N>> {
let &(file_id, ref ast_id_map) = self.ast_id_map.as_ref()?;
let ast_id_map = ast_id_map.get_or_init(|| self.db.ast_id_map(file_id));
Some(InFile::new(file_id, ast_id_map.ast_id(item)))
}
}