From c5a65466e264b850607113cbd6621e531cd58329 Mon Sep 17 00:00:00 2001 From: Aleksey Kladov Date: Mon, 18 Feb 2019 14:29:54 +0300 Subject: [PATCH] hide TaskResult from the public API --- crates/ra_vfs/src/io.rs | 19 +++++++++++-------- crates/ra_vfs/src/lib.rs | 24 +++++++++++++++++------- 2 files changed, 28 insertions(+), 15 deletions(-) diff --git a/crates/ra_vfs/src/io.rs b/crates/ra_vfs/src/io.rs index 0cffc03f3e..8eb148a38b 100644 --- a/crates/ra_vfs/src/io.rs +++ b/crates/ra_vfs/src/io.rs @@ -9,7 +9,7 @@ use relative_path::RelativePathBuf; use walkdir::WalkDir; use notify::{DebouncedEvent, RecommendedWatcher, RecursiveMode, Watcher as _Watcher}; -use crate::{Roots, VfsRoot}; +use crate::{Roots, VfsRoot, VfsTask}; pub(crate) enum Task { AddRoot { root: VfsRoot }, @@ -18,7 +18,7 @@ pub(crate) enum Task { /// `TaskResult` transfers files read on the IO thread to the VFS on the main /// thread. #[derive(Debug)] -pub enum TaskResult { +pub(crate) enum TaskResult { /// Emitted when we've recursively scanned a source root during the initial /// load. BulkLoadRoot { root: VfsRoot, files: Vec<(RelativePathBuf, String)> }, @@ -46,7 +46,7 @@ enum ChangeKind { const WATCHER_DELAY: Duration = Duration::from_millis(250); -pub(crate) type Worker = thread_worker::Worker; +pub(crate) type Worker = thread_worker::Worker; pub(crate) fn start(roots: Arc) -> Worker { // This is a pretty elaborate setup of threads & channels! It is // explained by the following concerns: @@ -122,7 +122,7 @@ pub(crate) fn start(roots: Arc) -> Worker { fn watch_root( watcher: Option<&mut RecommendedWatcher>, - sender: &Sender, + sender: &Sender, roots: &Roots, root: VfsRoot, ) { @@ -136,7 +136,8 @@ fn watch_root( Some((path, text)) }) .collect(); - sender.send(TaskResult::BulkLoadRoot { root, files }).unwrap(); + let res = TaskResult::BulkLoadRoot { root, files }; + sender.send(VfsTask(res)).unwrap(); log::debug!("... loaded {}", root_path.display()); } @@ -173,7 +174,7 @@ fn convert_notify_event(event: DebouncedEvent, sender: &Sender<(PathBuf, ChangeK fn handle_change( watcher: Option<&mut RecommendedWatcher>, - sender: &Sender, + sender: &Sender, roots: &Roots, path: PathBuf, kind: ChangeKind, @@ -195,13 +196,15 @@ fn handle_change( .try_for_each(|rel_path| { let abs_path = rel_path.to_path(&roots.path(root)); let text = read_to_string(&abs_path); - sender.send(TaskResult::SingleFile { root, path: rel_path, text }) + let res = TaskResult::SingleFile { root, path: rel_path, text }; + sender.send(VfsTask(res)) }) .unwrap() } ChangeKind::Write | ChangeKind::Remove => { let text = read_to_string(&path); - sender.send(TaskResult::SingleFile { root, path: rel_path, text }).unwrap(); + let res = TaskResult::SingleFile { root, path: rel_path, text }; + sender.send(VfsTask(res)).unwrap(); } } } diff --git a/crates/ra_vfs/src/lib.rs b/crates/ra_vfs/src/lib.rs index 8005c4ff8a..3cd11c9f67 100644 --- a/crates/ra_vfs/src/lib.rs +++ b/crates/ra_vfs/src/lib.rs @@ -33,10 +33,20 @@ use crate::{ roots::Roots, }; -pub use crate::{ - io::TaskResult as VfsTask, - roots::VfsRoot, -}; +pub use crate::roots::VfsRoot; + +/// Opaque wrapper around file-system event. +/// +/// Calling code is expected to just pass `VfsTask` to `handle_task` method. It +/// is exposed as a public API so that the caller can plug vfs events into the +/// main event loop and be notified when changes happen. +pub struct VfsTask(TaskResult); + +impl fmt::Debug for VfsTask { + fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { + f.write_str("VfsTask { ... }") + } +} #[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)] pub struct VfsFile(pub u32); @@ -159,12 +169,12 @@ impl Vfs { mem::replace(&mut self.pending_changes, Vec::new()) } - pub fn task_receiver(&self) -> &Receiver { + pub fn task_receiver(&self) -> &Receiver { self.worker.receiver() } - pub fn handle_task(&mut self, task: io::TaskResult) { - match task { + pub fn handle_task(&mut self, task: VfsTask) { + match task.0 { TaskResult::BulkLoadRoot { root, files } => { let mut cur_files = Vec::new(); // While we were scanning the root in the background, a file might have