diff options
author | bors[bot] <bors[bot]@users.noreply.github.com> | 2019-06-02 10:32:26 +0100 |
---|---|---|
committer | bors[bot] <bors[bot]@users.noreply.github.com> | 2019-06-02 10:32:26 +0100 |
commit | 82cf27b5fc91a4125315d28b8a3c86e5fa7be26d (patch) | |
tree | c6f5e240d385fd33f25a70d20b8244a721202264 /crates/ra_hir/src/lang_item.rs | |
parent | 8256dfdd713451cbe54ee61a176b79f1d1bab589 (diff) | |
parent | 5af9e475f4acce54f8383ed22febc412cf2541d0 (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.rs | 13 |
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; | |||
4 | use ra_syntax::{SmolStr, ast::AttrsOwner}; | 4 | use ra_syntax::{SmolStr, ast::AttrsOwner}; |
5 | 5 | ||
6 | use crate::{ | 6 | use 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; |