Unnamed repository; edit this file 'description' to name the repository.
Diffstat (limited to 'crates/hir-def/src/db.rs')
-rw-r--r--crates/hir-def/src/db.rs184
1 files changed, 105 insertions, 79 deletions
diff --git a/crates/hir-def/src/db.rs b/crates/hir-def/src/db.rs
index 598a850898..0772d00f03 100644
--- a/crates/hir-def/src/db.rs
+++ b/crates/hir-def/src/db.rs
@@ -1,5 +1,5 @@
//! Defines database & queries for name resolution.
-use base_db::{ra_salsa, CrateId, SourceDatabase, Upcast};
+use base_db::{CrateId, RootQueryDb, SourceDatabase, Upcast};
use either::Either;
use hir_expand::{db::ExpandDatabase, HirFileId, MacroDefId};
use intern::sym;
@@ -33,178 +33,204 @@ use crate::{
UseId, UseLoc, VariantId,
};
-#[ra_salsa::query_group(InternDatabaseStorage)]
-pub trait InternDatabase: SourceDatabase {
+use salsa::plumbing::AsId;
+
+#[query_group::query_group(InternDatabaseStorage)]
+pub trait InternDatabase: RootQueryDb {
// region: items
- #[ra_salsa::interned]
+ #[salsa::interned]
fn intern_use(&self, loc: UseLoc) -> UseId;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_extern_crate(&self, loc: ExternCrateLoc) -> ExternCrateId;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_function(&self, loc: FunctionLoc) -> FunctionId;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_struct(&self, loc: StructLoc) -> StructId;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_union(&self, loc: UnionLoc) -> UnionId;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_enum(&self, loc: EnumLoc) -> EnumId;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_enum_variant(&self, loc: EnumVariantLoc) -> EnumVariantId;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_const(&self, loc: ConstLoc) -> ConstId;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_static(&self, loc: StaticLoc) -> StaticId;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_trait(&self, loc: TraitLoc) -> TraitId;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_trait_alias(&self, loc: TraitAliasLoc) -> TraitAliasId;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_type_alias(&self, loc: TypeAliasLoc) -> TypeAliasId;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_impl(&self, loc: ImplLoc) -> ImplId;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_extern_block(&self, loc: ExternBlockLoc) -> ExternBlockId;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_macro2(&self, loc: Macro2Loc) -> Macro2Id;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_proc_macro(&self, loc: ProcMacroLoc) -> ProcMacroId;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_macro_rules(&self, loc: MacroRulesLoc) -> MacroRulesId;
- // endregion: items
+ // // endregion: items
- #[ra_salsa::interned]
+ #[salsa::interned]
fn intern_block(&self, loc: BlockLoc) -> BlockId;
- #[ra_salsa::interned]
+ #[salsa::interned]
fn intern_anonymous_const(&self, id: ConstBlockLoc) -> ConstBlockId;
- #[ra_salsa::interned]
+
+ #[salsa::interned]
fn intern_in_type_const(&self, id: InTypeConstLoc) -> InTypeConstId;
}
-#[ra_salsa::query_group(DefDatabaseStorage)]
-pub trait DefDatabase: InternDatabase + ExpandDatabase + Upcast<dyn ExpandDatabase> {
+#[query_group::query_group]
+pub trait DefDatabase:
+ InternDatabase
+ + ExpandDatabase
+ + SourceDatabase
+ + Upcast<dyn ExpandDatabase>
+ + Upcast<dyn RootQueryDb>
+{
/// Whether to expand procedural macros during name resolution.
- #[ra_salsa::input]
+ #[salsa::input]
fn expand_proc_attr_macros(&self) -> bool;
/// Computes an [`ItemTree`] for the given file or macro expansion.
- #[ra_salsa::invoke(ItemTree::file_item_tree_query)]
+ #[salsa::invoke(ItemTree::file_item_tree_query)]
fn file_item_tree(&self, file_id: HirFileId) -> Arc<ItemTree>;
- #[ra_salsa::invoke(ItemTree::block_item_tree_query)]
+ #[salsa::invoke_actual(ItemTree::block_item_tree_query)]
fn block_item_tree(&self, block_id: BlockId) -> Arc<ItemTree>;
- #[ra_salsa::invoke(ItemTree::file_item_tree_with_source_map_query)]
+ #[salsa::invoke(ItemTree::file_item_tree_with_source_map_query)]
fn file_item_tree_with_source_map(
&self,
file_id: HirFileId,
) -> (Arc<ItemTree>, Arc<ItemTreeSourceMaps>);
- #[ra_salsa::invoke(ItemTree::block_item_tree_with_source_map_query)]
+ #[salsa::invoke_actual(ItemTree::block_item_tree_with_source_map_query)]
fn block_item_tree_with_source_map(
&self,
block_id: BlockId,
) -> (Arc<ItemTree>, Arc<ItemTreeSourceMaps>);
- #[ra_salsa::invoke(DefMap::crate_def_map_query)]
+ #[salsa::invoke(DefMap::crate_def_map_query)]
fn crate_def_map(&self, krate: CrateId) -> Arc<DefMap>;
/// Computes the block-level `DefMap`.
- #[ra_salsa::invoke(DefMap::block_def_map_query)]
+ #[salsa::invoke_actual(DefMap::block_def_map_query)]
fn block_def_map(&self, block: BlockId) -> Arc<DefMap>;
/// Turns a MacroId into a MacroDefId, describing the macro's definition post name resolution.
+ #[salsa::invoke_actual(macro_def)]
fn macro_def(&self, m: MacroId) -> MacroDefId;
// region:data
- #[ra_salsa::transparent]
- #[ra_salsa::invoke(StructData::struct_data_query)]
+ #[salsa::transparent]
+ #[salsa::invoke_actual(StructData::struct_data_query)]
fn struct_data(&self, id: StructId) -> Arc<StructData>;
- #[ra_salsa::invoke(StructData::struct_data_with_diagnostics_query)]
+ #[salsa::invoke_actual(StructData::struct_data_with_diagnostics_query)]
fn struct_data_with_diagnostics(&self, id: StructId) -> (Arc<StructData>, DefDiagnostics);
- #[ra_salsa::transparent]
- #[ra_salsa::invoke(StructData::union_data_query)]
+ #[salsa::transparent]
+ #[salsa::invoke_actual(StructData::union_data_query)]
fn union_data(&self, id: UnionId) -> Arc<StructData>;
- #[ra_salsa::invoke(StructData::union_data_with_diagnostics_query)]
+ #[salsa::invoke_actual(StructData::union_data_with_diagnostics_query)]
fn union_data_with_diagnostics(&self, id: UnionId) -> (Arc<StructData>, DefDiagnostics);
- #[ra_salsa::invoke(EnumData::enum_data_query)]
+ #[salsa::invoke_actual(EnumData::enum_data_query)]
fn enum_data(&self, e: EnumId) -> Arc<EnumData>;
- #[ra_salsa::transparent]
- #[ra_salsa::invoke(EnumVariantData::enum_variant_data_query)]
+ #[salsa::transparent]
+ #[salsa::invoke_actual(EnumVariantData::enum_variant_data_query)]
fn enum_variant_data(&self, id: EnumVariantId) -> Arc<EnumVariantData>;
- #[ra_salsa::invoke(EnumVariantData::enum_variant_data_with_diagnostics_query)]
+ #[salsa::invoke_actual(EnumVariantData::enum_variant_data_with_diagnostics_query)]
fn enum_variant_data_with_diagnostics(
&self,
id: EnumVariantId,
) -> (Arc<EnumVariantData>, DefDiagnostics);
- #[ra_salsa::transparent]
- #[ra_salsa::invoke(VariantData::variant_data)]
+ #[salsa::transparent]
+ #[salsa::invoke_actual(VariantData::variant_data)]
fn variant_data(&self, id: VariantId) -> Arc<VariantData>;
- #[ra_salsa::transparent]
- #[ra_salsa::invoke(ImplData::impl_data_query)]
+ #[salsa::transparent]
+ #[salsa::invoke_actual(ImplData::impl_data_query)]
fn impl_data(&self, e: ImplId) -> Arc<ImplData>;
- #[ra_salsa::invoke(ImplData::impl_data_with_diagnostics_query)]
+ #[salsa::invoke_actual(ImplData::impl_data_with_diagnostics_query)]
fn impl_data_with_diagnostics(&self, e: ImplId) -> (Arc<ImplData>, DefDiagnostics);
- #[ra_salsa::transparent]
- #[ra_salsa::invoke(TraitData::trait_data_query)]
+ #[salsa::transparent]
+ #[salsa::invoke_actual(TraitData::trait_data_query)]
fn trait_data(&self, e: TraitId) -> Arc<TraitData>;
- #[ra_salsa::invoke(TraitData::trait_data_with_diagnostics_query)]
+ #[salsa::invoke_actual(TraitData::trait_data_with_diagnostics_query)]
fn trait_data_with_diagnostics(&self, tr: TraitId) -> (Arc<TraitData>, DefDiagnostics);
- #[ra_salsa::invoke(TraitAliasData::trait_alias_query)]
+ #[salsa::invoke_actual(TraitAliasData::trait_alias_query)]
fn trait_alias_data(&self, e: TraitAliasId) -> Arc<TraitAliasData>;
- #[ra_salsa::invoke(TypeAliasData::type_alias_data_query)]
+ #[salsa::invoke_actual(TypeAliasData::type_alias_data_query)]
fn type_alias_data(&self, e: TypeAliasId) -> Arc<TypeAliasData>;
- #[ra_salsa::invoke(FunctionData::fn_data_query)]
+ #[salsa::invoke_actual(FunctionData::fn_data_query)]
fn function_data(&self, func: FunctionId) -> Arc<FunctionData>;
- #[ra_salsa::invoke(ConstData::const_data_query)]
+ #[salsa::invoke_actual(ConstData::const_data_query)]
fn const_data(&self, konst: ConstId) -> Arc<ConstData>;
- #[ra_salsa::invoke(StaticData::static_data_query)]
+ #[salsa::invoke_actual(StaticData::static_data_query)]
fn static_data(&self, statik: StaticId) -> Arc<StaticData>;
- #[ra_salsa::invoke(Macro2Data::macro2_data_query)]
+ #[salsa::invoke_actual(Macro2Data::macro2_data_query)]
fn macro2_data(&self, makro: Macro2Id) -> Arc<Macro2Data>;
- #[ra_salsa::invoke(MacroRulesData::macro_rules_data_query)]
+ #[salsa::invoke_actual(MacroRulesData::macro_rules_data_query)]
fn macro_rules_data(&self, makro: MacroRulesId) -> Arc<MacroRulesData>;
- #[ra_salsa::invoke(ProcMacroData::proc_macro_data_query)]
+ #[salsa::invoke_actual(ProcMacroData::proc_macro_data_query)]
fn proc_macro_data(&self, makro: ProcMacroId) -> Arc<ProcMacroData>;
- #[ra_salsa::invoke(ExternCrateDeclData::extern_crate_decl_data_query)]
+ #[salsa::invoke_actual(ExternCrateDeclData::extern_crate_decl_data_query)]
fn extern_crate_decl_data(&self, extern_crate: ExternCrateId) -> Arc<ExternCrateDeclData>;
// endregion:data
- #[ra_salsa::invoke(Body::body_with_source_map_query)]
- #[ra_salsa::lru]
+ #[salsa::invoke(Body::body_with_source_map_query)]
+ #[salsa::lru(512)]
fn body_with_source_map(&self, def: DefWithBodyId) -> (Arc<Body>, Arc<BodySourceMap>);
- #[ra_salsa::invoke(Body::body_query)]
+ #[salsa::invoke(Body::body_query)]
fn body(&self, def: DefWithBodyId) -> Arc<Body>;
- #[ra_salsa::invoke(ExprScopes::expr_scopes_query)]
+ #[salsa::invoke_actual(ExprScopes::expr_scopes_query)]
fn expr_scopes(&self, def: DefWithBodyId) -> Arc<ExprScopes>;
- #[ra_salsa::invoke(GenericParams::generic_params_query)]
+ #[salsa::invoke_actual(GenericParams::generic_params_query)]
fn generic_params(&self, def: GenericDefId) -> Arc<GenericParams>;
/// If this returns `None` for the source map, that means it is the same as with the item tree.
- #[ra_salsa::invoke(GenericParams::generic_params_with_source_map_query)]
+ #[salsa::invoke_actual(GenericParams::generic_params_with_source_map_query)]
fn generic_params_with_source_map(
&self,
def: GenericDefId,
@@ -212,51 +238,51 @@ pub trait DefDatabase: InternDatabase + ExpandDatabase + Upcast<dyn ExpandDataba
// region:attrs
- #[ra_salsa::invoke(Attrs::fields_attrs_query)]
+ #[salsa::invoke_actual(Attrs::fields_attrs_query)]
fn fields_attrs(&self, def: VariantId) -> Arc<ArenaMap<LocalFieldId, Attrs>>;
// should this really be a query?
- #[ra_salsa::invoke(crate::attr::fields_attrs_source_map)]
+ #[salsa::invoke_actual(crate::attr::fields_attrs_source_map)]
fn fields_attrs_source_map(
&self,
def: VariantId,
) -> Arc<ArenaMap<LocalFieldId, AstPtr<Either<ast::TupleField, ast::RecordField>>>>;
- #[ra_salsa::invoke(AttrsWithOwner::attrs_query)]
+ #[salsa::invoke(AttrsWithOwner::attrs_query)]
fn attrs(&self, def: AttrDefId) -> Attrs;
- #[ra_salsa::transparent]
- #[ra_salsa::invoke(lang_item::lang_attr)]
+ #[salsa::transparent]
+ #[salsa::invoke(lang_item::lang_attr)]
fn lang_attr(&self, def: AttrDefId) -> Option<LangItem>;
// endregion:attrs
- #[ra_salsa::invoke(LangItems::lang_item_query)]
+ #[salsa::invoke(LangItems::lang_item_query)]
fn lang_item(&self, start_crate: CrateId, item: LangItem) -> Option<LangItemTarget>;
- #[ra_salsa::invoke(ImportMap::import_map_query)]
+ #[salsa::invoke(ImportMap::import_map_query)]
fn import_map(&self, krate: CrateId) -> Arc<ImportMap>;
// region:visibilities
- #[ra_salsa::invoke(visibility::field_visibilities_query)]
+ #[salsa::invoke(visibility::field_visibilities_query)]
fn field_visibilities(&self, var: VariantId) -> Arc<ArenaMap<LocalFieldId, Visibility>>;
// FIXME: unify function_visibility and const_visibility?
- #[ra_salsa::invoke(visibility::function_visibility_query)]
+ #[salsa::invoke_actual(visibility::function_visibility_query)]
fn function_visibility(&self, def: FunctionId) -> Visibility;
- #[ra_salsa::invoke(visibility::const_visibility_query)]
+ #[salsa::invoke_actual(visibility::const_visibility_query)]
fn const_visibility(&self, def: ConstId) -> Visibility;
// endregion:visibilities
- #[ra_salsa::invoke(LangItems::crate_lang_items_query)]
+ #[salsa::invoke(LangItems::crate_lang_items_query)]
fn crate_lang_items(&self, krate: CrateId) -> Option<Arc<LangItems>>;
- #[ra_salsa::invoke(crate::lang_item::notable_traits_in_deps)]
+ #[salsa::invoke(crate::lang_item::notable_traits_in_deps)]
fn notable_traits_in_deps(&self, krate: CrateId) -> Arc<[Arc<[TraitId]>]>;
- #[ra_salsa::invoke(crate::lang_item::crate_notable_traits)]
+ #[salsa::invoke(crate::lang_item::crate_notable_traits)]
fn crate_notable_traits(&self, krate: CrateId) -> Option<Arc<[TraitId]>>;
fn crate_supports_no_std(&self, crate_id: CrateId) -> bool;