aboutsummaryrefslogtreecommitdiff
path: root/crates/ra_hir/src/lang_item.rs
diff options
context:
space:
mode:
authorbors[bot] <bors[bot]@users.noreply.github.com>2019-06-02 10:32:26 +0100
committerbors[bot] <bors[bot]@users.noreply.github.com>2019-06-02 10:32:26 +0100
commit82cf27b5fc91a4125315d28b8a3c86e5fa7be26d (patch)
treec6f5e240d385fd33f25a70d20b8244a721202264 /crates/ra_hir/src/lang_item.rs
parent8256dfdd713451cbe54ee61a176b79f1d1bab589 (diff)
parent5af9e475f4acce54f8383ed22febc412cf2541d0 (diff)
Merge #1362
1362: Introduce AST database r=matklad a=matklad The idea here is to separate fragile bits which look into the syntax directly from robust bits which are safe across reparses. This uses the new `salsa::requires` featue Co-authored-by: Aleksey Kladov <[email protected]>
Diffstat (limited to 'crates/ra_hir/src/lang_item.rs')
-rw-r--r--crates/ra_hir/src/lang_item.rs13
1 files changed, 10 insertions, 3 deletions
diff --git a/crates/ra_hir/src/lang_item.rs b/crates/ra_hir/src/lang_item.rs
index 5f3f91cba..4cacaeba4 100644
--- a/crates/ra_hir/src/lang_item.rs
+++ b/crates/ra_hir/src/lang_item.rs
@@ -4,7 +4,7 @@ use rustc_hash::FxHashMap;
4use ra_syntax::{SmolStr, ast::AttrsOwner}; 4use ra_syntax::{SmolStr, ast::AttrsOwner};
5 5
6use crate::{ 6use crate::{
7 Crate, DefDatabase, Enum, Function, HirDatabase, ImplBlock, Module, Static, Struct, Trait 7 Crate, DefDatabase, Enum, Function, HirDatabase, ImplBlock, Module, Static, Struct, Trait, AstDatabase,
8}; 8};
9 9
10#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)] 10#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)]
@@ -41,7 +41,10 @@ impl LangItems {
41 } 41 }
42 42
43 /// Salsa query. This will look for lang items in a specific crate. 43 /// Salsa query. This will look for lang items in a specific crate.
44 pub(crate) fn lang_items_query(db: &impl DefDatabase, krate: Crate) -> Arc<LangItems> { 44 pub(crate) fn lang_items_query(
45 db: &(impl DefDatabase + AstDatabase),
46 krate: Crate,
47 ) -> Arc<LangItems> {
45 let mut lang_items = LangItems { items: FxHashMap::default() }; 48 let mut lang_items = LangItems { items: FxHashMap::default() };
46 49
47 if let Some(module) = krate.root_module(db) { 50 if let Some(module) = krate.root_module(db) {
@@ -74,7 +77,11 @@ impl LangItems {
74 } 77 }
75 } 78 }
76 79
77 fn collect_lang_items_recursive(&mut self, db: &impl DefDatabase, module: &Module) { 80 fn collect_lang_items_recursive(
81 &mut self,
82 db: &(impl DefDatabase + AstDatabase),
83 module: &Module,
84 ) {
78 // Look for impl targets 85 // Look for impl targets
79 let (impl_blocks, source_map) = db.impls_in_module_with_source_map(module.clone()); 86 let (impl_blocks, source_map) = db.impls_in_module_with_source_map(module.clone());
80 let source = module.definition_source(db).1; 87 let source = module.definition_source(db).1;