aboutsummaryrefslogtreecommitdiff
path: root/crates/vfs/src/file_set.rs
diff options
context:
space:
mode:
Diffstat (limited to 'crates/vfs/src/file_set.rs')
-rw-r--r--crates/vfs/src/file_set.rs46
1 files changed, 25 insertions, 21 deletions
diff --git a/crates/vfs/src/file_set.rs b/crates/vfs/src/file_set.rs
index 0caddc3bc..3f49f31e5 100644
--- a/crates/vfs/src/file_set.rs
+++ b/crates/vfs/src/file_set.rs
@@ -20,34 +20,38 @@ impl FileSet {
20 self.files.len() 20 self.files.len()
21 } 21 }
22 pub fn resolve_path(&self, anchor: FileId, path: &str) -> Option<FileId> { 22 pub fn resolve_path(&self, anchor: FileId, path: &str) -> Option<FileId> {
23 let mut base = dbg!(self.paths[&anchor].clone()); 23 let mut base = self.paths[&anchor].clone();
24 base.pop(); 24 base.pop();
25 let path = dbg!(base).join(dbg!(path))?; 25 let path = base.join(path)?;
26 self.files.get(&path).copied() 26 self.files.get(&path).copied()
27 } 27 }
28 28
29 pub fn file_name_and_extension(&self, file: FileId) -> Option<(&str, &str)> { 29 pub fn file_name_and_extension(&self, file: FileId) -> Option<(&str, Option<&str>)> {
30 self.paths[&file].file_name_and_extension() 30 self.paths[&file].file_name_and_extension()
31 } 31 }
32 32
33 pub fn list_files(&self, directory: FileId) -> Vec<(FileId, String)> { 33 pub fn list_files(
34 // TODO kb determine the ways to list all applicable files 34 &self,
35 // Maybe leave list directory here only and the move the rest of the logic into the database impl? 35 anchor: FileId,
36 // cache results in Salsa? 36 anchor_relative_path: Option<&str>,
37 37 ) -> Option<Vec<(FileId, String)>> {
38 dbg!(directory); 38 let anchor_directory = {
39 /* 39 let path = self.paths[&anchor].clone();
40 [crates/vfs/src/file_set.rs:30] directory = "/Users/someonetoignore/Downloads/tmp_dir/zzzz/src/" 40 match anchor_relative_path {
41 [crates/vfs/src/file_set.rs:31] self.files.keys() = [ 41 Some(anchor_relative_path) => path.join(anchor_relative_path),
42 "/Users/someonetoignore/Downloads/tmp_dir/zzzz/src/test_mod_1/test_mod_2/test_mod_3.rs", 42 None => path.join("../"),
43 "/Users/someonetoignore/Downloads/tmp_dir/zzzz/src/test_mod_1/test_mod_2.rs", 43 }
44 "/Users/someonetoignore/Downloads/tmp_dir/zzzz/src/test_mod_1.rs", 44 }?;
45 "/Users/someonetoignore/Downloads/tmp_dir/zzzz/src/lib.rs", 45
46 "/Users/someonetoignore/Downloads/tmp_dir/zzzz/src/test_mod_3/test_mod_3_1.rs", 46 Some(
47 "/Users/someonetoignore/Downloads/tmp_dir/zzzz/src/test_mod_3.rs", 47 self.paths
48 ] 48 .iter()
49 */ 49 .filter(|(_, path)| path.starts_with(&anchor_directory))
50 Vec::new() 50 // TODO kb need to ensure that no / exists after the anchor_directory
51 .filter(|(_, path)| path.ends_with(".rs"))
52 .map(|(&file_id, path)| (file_id, path.to_string()))
53 .collect(),
54 )
51 } 55 }
52 pub fn insert(&mut self, file_id: FileId, path: VfsPath) { 56 pub fn insert(&mut self, file_id: FileId, path: VfsPath) {
53 self.files.insert(path.clone(), file_id); 57 self.files.insert(path.clone(), file_id);