use parking_lot::Mutex;
use ra_db::{
- mock::FileMap, CheckCanceled, CrateGraph, FileId, FilePosition, SourceDatabase,
- SourceRoot, SourceRootId, salsa
+ CheckCanceled, FilePosition, FileId, CrateGraph, SourceRoot, SourceRootId, SourceDatabase, salsa,
};
use relative_path::RelativePathBuf;
use test_utils::{parse_fixture, CURSOR_MARKER, extract_offset};
events: Mutex<Option<Vec<salsa::Event<MockDatabase>>>>,
runtime: salsa::Runtime<MockDatabase>,
interner: Arc<HirInterner>,
- file_map: Arc<FileMap>,
+ file_counter: u32,
}
impl panic::RefUnwindSafe for MockDatabase {}
(db, position)
}
- pub(crate) fn file_id(&self, file: &str) -> FileId {
- self.file_map.file_id(file)
- }
-
fn from_fixture(fixture: &str) -> (MockDatabase, SourceRoot, Option<FilePosition>) {
let mut db = MockDatabase::default();
let is_crate_root = path == "/lib.rs" || path == "/main.rs";
let path = RelativePathBuf::from_path(&path[1..]).unwrap();
- let file_id = Arc::make_mut(&mut self.file_map).add(path.clone());
+ let file_id = FileId(self.file_counter);
+ self.file_counter += 1;
let text = Arc::new(text.to_string());
self.set_file_text(file_id, text);
self.set_file_relative_path(file_id, path.clone());
events: Default::default(),
runtime: salsa::Runtime::default(),
interner: Default::default(),
- file_map: Default::default(),
+ file_counter: 0,
};
db.set_crate_graph(Default::default());
db
events: Default::default(),
runtime: self.runtime.snapshot(self),
interner: Arc::clone(&self.interner),
- file_map: Arc::clone(&self.file_map),
+ file_counter: self.file_counter,
})
}
}
(db.item_map(krate.crate_id), module_id)
}
-fn item_map_custom_crate_root(fixture: &str, root: &str) -> (Arc<ItemMap>, ModuleId) {
+/// Sets the crate root to the file of the cursor marker
+fn item_map_custom_crate_root(fixture: &str) -> (Arc<ItemMap>, ModuleId) {
let (mut db, pos) = MockDatabase::with_position(fixture);
let mut crate_graph = CrateGraph::default();
- crate_graph.add_crate_root(db.file_id(root));
+ crate_graph.add_crate_root(pos.file_id);
db.set_crate_graph(Arc::new(crate_graph));
let module = crate::source_binder::module_from_position(&db, pos).unwrap();
"
//- /my_library.rs
mod foo;
-
use self::foo::Bar;
<|>
-
//- /foo/mod.rs
pub struct Bar;
",
- "/my_library.rs",
);
check_module_item_map(
&item_map,