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.rs402
1 files changed, 251 insertions, 151 deletions
diff --git a/crates/hir-def/src/db.rs b/crates/hir-def/src/db.rs
index 598a850898..34cf42d02b 100644
--- a/crates/hir-def/src/db.rs
+++ b/crates/hir-def/src/db.rs
@@ -1,273 +1,373 @@
//! Defines database & queries for name resolution.
-use base_db::{ra_salsa, CrateId, SourceDatabase, Upcast};
+use base_db::{Crate, RootQueryDb, SourceDatabase};
use either::Either;
-use hir_expand::{db::ExpandDatabase, HirFileId, MacroDefId};
+use hir_expand::{EditionedFileId, HirFileId, MacroCallId, MacroDefId, db::ExpandDatabase};
use intern::sym;
use la_arena::ArenaMap;
-use span::{EditionedFileId, MacroCallId};
-use syntax::{ast, AstPtr};
+use syntax::{AstPtr, ast};
+use thin_vec::ThinVec;
use triomphe::Arc;
use crate::{
+ AttrDefId, BlockId, BlockLoc, ConstId, ConstLoc, DefWithBodyId, EnumId, EnumLoc, EnumVariantId,
+ EnumVariantLoc, ExternBlockId, ExternBlockLoc, ExternCrateId, ExternCrateLoc, FunctionId,
+ FunctionLoc, GenericDefId, ImplId, ImplLoc, LocalFieldId, Macro2Id, Macro2Loc, MacroId,
+ MacroRulesId, MacroRulesLoc, MacroRulesLocFlags, ProcMacroId, ProcMacroLoc, StaticId,
+ StaticLoc, StructId, StructLoc, TraitAliasId, TraitAliasLoc, TraitId, TraitLoc, TypeAliasId,
+ TypeAliasLoc, UnionId, UnionLoc, UseId, UseLoc, VariantId,
attr::{Attrs, AttrsWithOwner},
- data::{
- adt::{EnumData, EnumVariantData, StructData, VariantData},
- ConstData, ExternCrateDeclData, FunctionData, ImplData, Macro2Data, MacroRulesData,
- ProcMacroData, StaticData, TraitAliasData, TraitData, TypeAliasData,
+ expr_store::{
+ Body, BodySourceMap, ExpressionStore, ExpressionStoreSourceMap, scope::ExprScopes,
},
- expr_store::{scope::ExprScopes, Body, BodySourceMap},
- generics::GenericParams,
+ hir::generics::GenericParams,
import_map::ImportMap,
- item_tree::{AttrOwner, ItemTree, ItemTreeSourceMaps},
+ item_tree::{AttrOwner, ItemTree},
lang_item::{self, LangItem, LangItemTarget, LangItems},
- nameres::{diagnostics::DefDiagnostics, DefMap},
+ nameres::{
+ DefMap, LocalDefMap,
+ assoc::{ImplItems, TraitItems},
+ diagnostics::DefDiagnostics,
+ },
+ signatures::{
+ ConstSignature, EnumSignature, EnumVariants, FunctionSignature, ImplSignature,
+ InactiveEnumVariantCode, StaticSignature, StructSignature, TraitAliasSignature,
+ TraitSignature, TypeAliasSignature, UnionSignature, VariantFields,
+ },
tt,
- type_ref::TypesSourceMap,
visibility::{self, Visibility},
- AttrDefId, BlockId, BlockLoc, ConstBlockId, ConstBlockLoc, ConstId, ConstLoc, DefWithBodyId,
- EnumId, EnumLoc, EnumVariantId, EnumVariantLoc, ExternBlockId, ExternBlockLoc, ExternCrateId,
- ExternCrateLoc, FunctionId, FunctionLoc, GenericDefId, ImplId, ImplLoc, InTypeConstId,
- InTypeConstLoc, LocalFieldId, Macro2Id, Macro2Loc, MacroId, MacroRulesId, MacroRulesLoc,
- MacroRulesLocFlags, ProcMacroId, ProcMacroLoc, StaticId, StaticLoc, StructId, StructLoc,
- TraitAliasId, TraitAliasLoc, TraitId, TraitLoc, TypeAliasId, TypeAliasLoc, UnionId, UnionLoc,
- 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]
- fn intern_anonymous_const(&self, id: ConstBlockLoc) -> ConstBlockId;
- #[ra_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 {
/// 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(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)]
- 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)]
- fn block_item_tree_with_source_map(
- &self,
- block_id: BlockId,
- ) -> (Arc<ItemTree>, Arc<ItemTreeSourceMaps>);
+ #[salsa::invoke(DefMap::crate_local_def_map_query)]
+ fn crate_local_def_map(&self, krate: Crate) -> (Arc<DefMap>, Arc<LocalDefMap>);
- #[ra_salsa::invoke(DefMap::crate_def_map_query)]
- fn crate_def_map(&self, krate: CrateId) -> Arc<DefMap>;
+ #[salsa::invoke(DefMap::crate_def_map_query)]
+ fn crate_def_map(&self, krate: Crate) -> Arc<DefMap>;
/// Computes the block-level `DefMap`.
- #[ra_salsa::invoke(DefMap::block_def_map_query)]
+ #[salsa::invoke(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(macro_def)]
fn macro_def(&self, m: MacroId) -> MacroDefId;
// region:data
- #[ra_salsa::transparent]
- #[ra_salsa::invoke(StructData::struct_data_query)]
- fn struct_data(&self, id: StructId) -> Arc<StructData>;
+ #[salsa::invoke(VariantFields::query)]
+ fn variant_fields_with_source_map(
+ &self,
+ id: VariantId,
+ ) -> (Arc<VariantFields>, Arc<ExpressionStoreSourceMap>);
- #[ra_salsa::invoke(StructData::struct_data_with_diagnostics_query)]
- fn struct_data_with_diagnostics(&self, id: StructId) -> (Arc<StructData>, DefDiagnostics);
+ #[salsa::tracked]
+ fn enum_variants(&self, id: EnumId) -> Arc<EnumVariants> {
+ self.enum_variants_with_diagnostics(id).0
+ }
+
+ #[salsa::invoke(EnumVariants::enum_variants_query)]
+ fn enum_variants_with_diagnostics(
+ &self,
+ id: EnumId,
+ ) -> (Arc<EnumVariants>, Option<Arc<ThinVec<InactiveEnumVariantCode>>>);
- #[ra_salsa::transparent]
- #[ra_salsa::invoke(StructData::union_data_query)]
- fn union_data(&self, id: UnionId) -> Arc<StructData>;
+ #[salsa::transparent]
+ #[salsa::invoke(ImplItems::impl_items_query)]
+ fn impl_items(&self, e: ImplId) -> Arc<ImplItems>;
- #[ra_salsa::invoke(StructData::union_data_with_diagnostics_query)]
- fn union_data_with_diagnostics(&self, id: UnionId) -> (Arc<StructData>, DefDiagnostics);
+ #[salsa::invoke(ImplItems::impl_items_with_diagnostics_query)]
+ fn impl_items_with_diagnostics(&self, e: ImplId) -> (Arc<ImplItems>, DefDiagnostics);
- #[ra_salsa::invoke(EnumData::enum_data_query)]
- fn enum_data(&self, e: EnumId) -> Arc<EnumData>;
+ #[salsa::transparent]
+ #[salsa::invoke(TraitItems::trait_items_query)]
+ fn trait_items(&self, e: TraitId) -> Arc<TraitItems>;
- #[ra_salsa::transparent]
- #[ra_salsa::invoke(EnumVariantData::enum_variant_data_query)]
- fn enum_variant_data(&self, id: EnumVariantId) -> Arc<EnumVariantData>;
+ #[salsa::invoke(TraitItems::trait_items_with_diagnostics_query)]
+ fn trait_items_with_diagnostics(&self, tr: TraitId) -> (Arc<TraitItems>, DefDiagnostics);
- #[ra_salsa::invoke(EnumVariantData::enum_variant_data_with_diagnostics_query)]
- fn enum_variant_data_with_diagnostics(
- &self,
- id: EnumVariantId,
- ) -> (Arc<EnumVariantData>, DefDiagnostics);
+ #[salsa::tracked]
+ fn variant_fields(&self, id: VariantId) -> Arc<VariantFields> {
+ self.variant_fields_with_source_map(id).0
+ }
+
+ #[salsa::tracked]
+ fn trait_signature(&self, trait_: TraitId) -> Arc<TraitSignature> {
+ self.trait_signature_with_source_map(trait_).0
+ }
- #[ra_salsa::transparent]
- #[ra_salsa::invoke(VariantData::variant_data)]
- fn variant_data(&self, id: VariantId) -> Arc<VariantData>;
- #[ra_salsa::transparent]
- #[ra_salsa::invoke(ImplData::impl_data_query)]
- fn impl_data(&self, e: ImplId) -> Arc<ImplData>;
+ #[salsa::tracked]
+ fn impl_signature(&self, impl_: ImplId) -> Arc<ImplSignature> {
+ self.impl_signature_with_source_map(impl_).0
+ }
+
+ #[salsa::tracked]
+ fn struct_signature(&self, struct_: StructId) -> Arc<StructSignature> {
+ self.struct_signature_with_source_map(struct_).0
+ }
+
+ #[salsa::tracked]
+ fn union_signature(&self, union_: UnionId) -> Arc<UnionSignature> {
+ self.union_signature_with_source_map(union_).0
+ }
+
+ #[salsa::tracked]
+ fn enum_signature(&self, e: EnumId) -> Arc<EnumSignature> {
+ self.enum_signature_with_source_map(e).0
+ }
- #[ra_salsa::invoke(ImplData::impl_data_with_diagnostics_query)]
- fn impl_data_with_diagnostics(&self, e: ImplId) -> (Arc<ImplData>, DefDiagnostics);
+ #[salsa::tracked]
+ fn const_signature(&self, e: ConstId) -> Arc<ConstSignature> {
+ self.const_signature_with_source_map(e).0
+ }
- #[ra_salsa::transparent]
- #[ra_salsa::invoke(TraitData::trait_data_query)]
- fn trait_data(&self, e: TraitId) -> Arc<TraitData>;
+ #[salsa::tracked]
+ fn static_signature(&self, e: StaticId) -> Arc<StaticSignature> {
+ self.static_signature_with_source_map(e).0
+ }
+
+ #[salsa::tracked]
+ fn function_signature(&self, e: FunctionId) -> Arc<FunctionSignature> {
+ self.function_signature_with_source_map(e).0
+ }
+
+ #[salsa::tracked]
+ fn trait_alias_signature(&self, e: TraitAliasId) -> Arc<TraitAliasSignature> {
+ self.trait_alias_signature_with_source_map(e).0
+ }
+
+ #[salsa::tracked]
+ fn type_alias_signature(&self, e: TypeAliasId) -> Arc<TypeAliasSignature> {
+ self.type_alias_signature_with_source_map(e).0
+ }
- #[ra_salsa::invoke(TraitData::trait_data_with_diagnostics_query)]
- fn trait_data_with_diagnostics(&self, tr: TraitId) -> (Arc<TraitData>, DefDiagnostics);
+ #[salsa::invoke(TraitSignature::query)]
+ fn trait_signature_with_source_map(
+ &self,
+ trait_: TraitId,
+ ) -> (Arc<TraitSignature>, Arc<ExpressionStoreSourceMap>);
- #[ra_salsa::invoke(TraitAliasData::trait_alias_query)]
- fn trait_alias_data(&self, e: TraitAliasId) -> Arc<TraitAliasData>;
+ #[salsa::invoke(ImplSignature::query)]
+ fn impl_signature_with_source_map(
+ &self,
+ impl_: ImplId,
+ ) -> (Arc<ImplSignature>, Arc<ExpressionStoreSourceMap>);
- #[ra_salsa::invoke(TypeAliasData::type_alias_data_query)]
- fn type_alias_data(&self, e: TypeAliasId) -> Arc<TypeAliasData>;
+ #[salsa::invoke(StructSignature::query)]
+ fn struct_signature_with_source_map(
+ &self,
+ struct_: StructId,
+ ) -> (Arc<StructSignature>, Arc<ExpressionStoreSourceMap>);
- #[ra_salsa::invoke(FunctionData::fn_data_query)]
- fn function_data(&self, func: FunctionId) -> Arc<FunctionData>;
+ #[salsa::invoke(UnionSignature::query)]
+ fn union_signature_with_source_map(
+ &self,
+ union_: UnionId,
+ ) -> (Arc<UnionSignature>, Arc<ExpressionStoreSourceMap>);
- #[ra_salsa::invoke(ConstData::const_data_query)]
- fn const_data(&self, konst: ConstId) -> Arc<ConstData>;
+ #[salsa::invoke(EnumSignature::query)]
+ fn enum_signature_with_source_map(
+ &self,
+ e: EnumId,
+ ) -> (Arc<EnumSignature>, Arc<ExpressionStoreSourceMap>);
- #[ra_salsa::invoke(StaticData::static_data_query)]
- fn static_data(&self, statik: StaticId) -> Arc<StaticData>;
+ #[salsa::invoke(ConstSignature::query)]
+ fn const_signature_with_source_map(
+ &self,
+ e: ConstId,
+ ) -> (Arc<ConstSignature>, Arc<ExpressionStoreSourceMap>);
- #[ra_salsa::invoke(Macro2Data::macro2_data_query)]
- fn macro2_data(&self, makro: Macro2Id) -> Arc<Macro2Data>;
+ #[salsa::invoke(StaticSignature::query)]
+ fn static_signature_with_source_map(
+ &self,
+ e: StaticId,
+ ) -> (Arc<StaticSignature>, Arc<ExpressionStoreSourceMap>);
- #[ra_salsa::invoke(MacroRulesData::macro_rules_data_query)]
- fn macro_rules_data(&self, makro: MacroRulesId) -> Arc<MacroRulesData>;
+ #[salsa::invoke(FunctionSignature::query)]
+ fn function_signature_with_source_map(
+ &self,
+ e: FunctionId,
+ ) -> (Arc<FunctionSignature>, Arc<ExpressionStoreSourceMap>);
- #[ra_salsa::invoke(ProcMacroData::proc_macro_data_query)]
- fn proc_macro_data(&self, makro: ProcMacroId) -> Arc<ProcMacroData>;
+ #[salsa::invoke(TraitAliasSignature::query)]
+ fn trait_alias_signature_with_source_map(
+ &self,
+ e: TraitAliasId,
+ ) -> (Arc<TraitAliasSignature>, Arc<ExpressionStoreSourceMap>);
- #[ra_salsa::invoke(ExternCrateDeclData::extern_crate_decl_data_query)]
- fn extern_crate_decl_data(&self, extern_crate: ExternCrateId) -> Arc<ExternCrateDeclData>;
+ #[salsa::invoke(TypeAliasSignature::query)]
+ fn type_alias_signature_with_source_map(
+ &self,
+ e: TypeAliasId,
+ ) -> (Arc<TypeAliasSignature>, Arc<ExpressionStoreSourceMap>);
// 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(ExprScopes::expr_scopes_query)]
fn expr_scopes(&self, def: DefWithBodyId) -> Arc<ExprScopes>;
- #[ra_salsa::invoke(GenericParams::generic_params_query)]
+ #[salsa::transparent]
+ #[salsa::invoke(GenericParams::new)]
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)]
- fn generic_params_with_source_map(
+ #[salsa::transparent]
+ #[salsa::invoke(GenericParams::generic_params_and_store)]
+ fn generic_params_and_store(
&self,
def: GenericDefId,
- ) -> (Arc<GenericParams>, Option<Arc<TypesSourceMap>>);
+ ) -> (Arc<GenericParams>, Arc<ExpressionStore>);
+
+ #[salsa::transparent]
+ #[salsa::invoke(GenericParams::generic_params_and_store_and_source_map)]
+ fn generic_params_and_store_and_source_map(
+ &self,
+ def: GenericDefId,
+ ) -> (Arc<GenericParams>, Arc<ExpressionStore>, Arc<ExpressionStoreSourceMap>);
// region:attrs
- #[ra_salsa::invoke(Attrs::fields_attrs_query)]
+ #[salsa::invoke(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(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)]
+ // FIXME: Make this a non-interned query.
+ #[salsa::invoke_interned(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)]
- fn lang_item(&self, start_crate: CrateId, item: LangItem) -> Option<LangItemTarget>;
+ #[salsa::invoke(LangItems::lang_item_query)]
+ fn lang_item(&self, start_crate: Crate, item: LangItem) -> Option<LangItemTarget>;
- #[ra_salsa::invoke(ImportMap::import_map_query)]
- fn import_map(&self, krate: CrateId) -> Arc<ImportMap>;
+ #[salsa::invoke(ImportMap::import_map_query)]
+ fn import_map(&self, krate: Crate) -> 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(visibility::function_visibility_query)]
fn function_visibility(&self, def: FunctionId) -> Visibility;
- #[ra_salsa::invoke(visibility::const_visibility_query)]
+ #[salsa::invoke(visibility::const_visibility_query)]
fn const_visibility(&self, def: ConstId) -> Visibility;
+ #[salsa::invoke(visibility::type_alias_visibility_query)]
+ fn type_alias_visibility(&self, def: TypeAliasId) -> Visibility;
+
// endregion:visibilities
- #[ra_salsa::invoke(LangItems::crate_lang_items_query)]
- fn crate_lang_items(&self, krate: CrateId) -> Option<Arc<LangItems>>;
+ #[salsa::invoke(LangItems::crate_lang_items_query)]
+ fn crate_lang_items(&self, krate: Crate) -> Option<Arc<LangItems>>;
- #[ra_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)]
- fn crate_notable_traits(&self, krate: CrateId) -> Option<Arc<[TraitId]>>;
+ #[salsa::invoke(crate::lang_item::notable_traits_in_deps)]
+ fn notable_traits_in_deps(&self, krate: Crate) -> Arc<[Arc<[TraitId]>]>;
+ #[salsa::invoke(crate::lang_item::crate_notable_traits)]
+ fn crate_notable_traits(&self, krate: Crate) -> Option<Arc<[TraitId]>>;
- fn crate_supports_no_std(&self, crate_id: CrateId) -> bool;
+ #[salsa::invoke(crate_supports_no_std)]
+ fn crate_supports_no_std(&self, crate_id: Crate) -> bool;
- fn include_macro_invoc(&self, crate_id: CrateId) -> Arc<[(MacroCallId, EditionedFileId)]>;
+ #[salsa::invoke(include_macro_invoc)]
+ fn include_macro_invoc(&self, crate_id: Crate) -> Arc<[(MacroCallId, EditionedFileId)]>;
}
// return: macro call id and include file id
fn include_macro_invoc(
db: &dyn DefDatabase,
- krate: CrateId,
+ krate: Crate,
) -> Arc<[(MacroCallId, EditionedFileId)]> {
db.crate_def_map(krate)
.modules
@@ -275,20 +375,20 @@ fn include_macro_invoc(
.flat_map(|m| m.scope.iter_macro_invoc())
.filter_map(|invoc| {
db.lookup_intern_macro_call(*invoc.1)
- .include_file_id(db.upcast(), *invoc.1)
+ .include_file_id(db, *invoc.1)
.map(|x| (*invoc.1, x))
})
.collect()
}
-fn crate_supports_no_std(db: &dyn DefDatabase, crate_id: CrateId) -> bool {
- let file = db.crate_graph()[crate_id].root_file_id();
+fn crate_supports_no_std(db: &dyn DefDatabase, crate_id: Crate) -> bool {
+ let file = crate_id.data(db).root_file_id(db);
let item_tree = db.file_item_tree(file.into());
let attrs = item_tree.raw_attrs(AttrOwner::TopLevel);
for attr in &**attrs {
match attr.path().as_ident() {
- Some(ident) if *ident == sym::no_std.clone() => return true,
- Some(ident) if *ident == sym::cfg_attr.clone() => {}
+ Some(ident) if *ident == sym::no_std => return true,
+ Some(ident) if *ident == sym::cfg_attr => {}
_ => continue,
}
@@ -304,7 +404,7 @@ fn crate_supports_no_std(db: &dyn DefDatabase, crate_id: CrateId) -> bool {
for output in segments.skip(1) {
match output.flat_tokens() {
[tt::TokenTree::Leaf(tt::Leaf::Ident(ident))] if ident.sym == sym::no_std => {
- return true
+ return true;
}
_ => {}
}