diff options
author | Aleksey Kladov <[email protected]> | 2019-01-26 08:17:05 +0000 |
---|---|---|
committer | Aleksey Kladov <[email protected]> | 2019-01-26 08:17:05 +0000 |
commit | 3223de59765cae816099e8684a2caf13bc69bb2e (patch) | |
tree | d9164a4180a15be5ae58b779989161c2541ac195 /crates/ra_ide_api/src | |
parent | be1a005ebd02298feb8d272278354411d16acdee (diff) |
move ide queries to ide db
Diffstat (limited to 'crates/ra_ide_api/src')
-rw-r--r-- | crates/ra_ide_api/src/db.rs | 15 | ||||
-rw-r--r-- | crates/ra_ide_api/src/symbol_index.rs | 8 |
2 files changed, 14 insertions, 9 deletions
diff --git a/crates/ra_ide_api/src/db.rs b/crates/ra_ide_api/src/db.rs index 02e12437c..119190e0a 100644 --- a/crates/ra_ide_api/src/db.rs +++ b/crates/ra_ide_api/src/db.rs | |||
@@ -1,11 +1,11 @@ | |||
1 | use std::sync::Arc; | 1 | use std::sync::Arc; |
2 | 2 | ||
3 | use ra_db::{ | 3 | use ra_db::{ |
4 | CheckCanceled, FileId, Canceled, | 4 | CheckCanceled, FileId, Canceled, FilesDatabase, |
5 | salsa::{self, Database}, | 5 | salsa, |
6 | }; | 6 | }; |
7 | 7 | ||
8 | use crate::{symbol_index, LineIndex}; | 8 | use crate::{LineIndex, symbol_index::{self, SymbolsDatabase}}; |
9 | 9 | ||
10 | #[salsa::database( | 10 | #[salsa::database( |
11 | ra_db::FilesDatabaseStorage, | 11 | ra_db::FilesDatabaseStorage, |
@@ -34,12 +34,9 @@ impl Default for RootDatabase { | |||
34 | runtime: salsa::Runtime::default(), | 34 | runtime: salsa::Runtime::default(), |
35 | interner: Default::default(), | 35 | interner: Default::default(), |
36 | }; | 36 | }; |
37 | db.query_mut(ra_db::CrateGraphQuery) | 37 | db.set_crate_graph(Default::default()); |
38 | .set((), Default::default()); | 38 | db.set_local_roots(Default::default()); |
39 | db.query_mut(ra_db::LocalRootsQuery) | 39 | db.set_library_roots(Default::default()); |
40 | .set((), Default::default()); | ||
41 | db.query_mut(ra_db::LibraryRootsQuery) | ||
42 | .set((), Default::default()); | ||
43 | db | 40 | db |
44 | } | 41 | } |
45 | } | 42 | } |
diff --git a/crates/ra_ide_api/src/symbol_index.rs b/crates/ra_ide_api/src/symbol_index.rs index e073a349e..4d81d14b3 100644 --- a/crates/ra_ide_api/src/symbol_index.rs +++ b/crates/ra_ide_api/src/symbol_index.rs | |||
@@ -49,6 +49,14 @@ pub(crate) trait SymbolsDatabase: hir::db::HirDatabase { | |||
49 | fn file_symbols(&self, file_id: FileId) -> Arc<SymbolIndex>; | 49 | fn file_symbols(&self, file_id: FileId) -> Arc<SymbolIndex>; |
50 | #[salsa::input] | 50 | #[salsa::input] |
51 | fn library_symbols(&self, id: SourceRootId) -> Arc<SymbolIndex>; | 51 | fn library_symbols(&self, id: SourceRootId) -> Arc<SymbolIndex>; |
52 | /// The set of "local" (that is, from the current workspace) roots. | ||
53 | /// Files in local roots are assumed to change frequently. | ||
54 | #[salsa::input] | ||
55 | fn local_roots(&self) -> Arc<Vec<SourceRootId>>; | ||
56 | /// The set of roots for crates.io libraries. | ||
57 | /// Files in libraries are assumed to never change. | ||
58 | #[salsa::input] | ||
59 | fn library_roots(&self) -> Arc<Vec<SourceRootId>>; | ||
52 | } | 60 | } |
53 | 61 | ||
54 | fn file_symbols(db: &impl SymbolsDatabase, file_id: FileId) -> Arc<SymbolIndex> { | 62 | fn file_symbols(db: &impl SymbolsDatabase, file_id: FileId) -> Arc<SymbolIndex> { |