From dbb8c87b96dec9942b1bf877b29bafb8246514d4 Mon Sep 17 00:00:00 2001 From: Lucas Fernandes Nogueira Date: Sun, 3 Jul 2022 19:48:05 -0300 Subject: [PATCH] feat(cli): watch Cargo workspaces in the dev command, closes #4222 (#4572) --- .changes/watch-cargo-workspace.md | 6 ++++ tooling/cli/src/interface/rust.rs | 48 +++++++++++++++++++++++-------- 2 files changed, 42 insertions(+), 12 deletions(-) create mode 100644 .changes/watch-cargo-workspace.md diff --git a/.changes/watch-cargo-workspace.md b/.changes/watch-cargo-workspace.md new file mode 100644 index 000000000000..ff54faecee8b --- /dev/null +++ b/.changes/watch-cargo-workspace.md @@ -0,0 +1,6 @@ +--- +"cli.rs": patch +"cli.js": patch +--- + +Watch for Cargo workspace members in the `dev` file watcher. diff --git a/tooling/cli/src/interface/rust.rs b/tooling/cli/src/interface/rust.rs index c98cf191f46e..0326e93d5f88 100644 --- a/tooling/cli/src/interface/rust.rs +++ b/tooling/cli/src/interface/rust.rs @@ -21,6 +21,7 @@ use anyhow::Context; #[cfg(target_os = "linux")] use heck::ToKebabCase; use log::warn; +use log::{debug, info}; use notify::{watcher, DebouncedEvent, RecursiveMode, Watcher}; use serde::Deserialize; use shared_child::SharedChild; @@ -461,20 +462,43 @@ impl Rust { let process = Arc::new(Mutex::new(child)); let (tx, rx) = channel(); let tauri_path = tauri_dir(); + let workspace_path = get_workspace_dir(&tauri_path); + + let watch_folders = if tauri_path == workspace_path { + vec![tauri_path] + } else { + let cargo_settings = CargoSettings::load(&workspace_path)?; + cargo_settings + .workspace + .as_ref() + .map(|w| { + w.members + .clone() + .unwrap_or_default() + .into_iter() + .map(|p| workspace_path.join(p)) + .collect() + }) + .unwrap_or_else(|| vec![tauri_path]) + }; let mut watcher = watcher(tx, Duration::from_secs(1)).unwrap(); - lookup(&tauri_path, |file_type, path| { - if path != tauri_path { - let _ = watcher.watch( - path, - if file_type.is_dir() { - RecursiveMode::Recursive - } else { - RecursiveMode::NonRecursive - }, - ); - } - }); + for path in watch_folders { + info!("Watching {} for changes...", path.display()); + lookup(&path, |file_type, p| { + if p != path { + debug!("Watching {} for changes...", p.display()); + let _ = watcher.watch( + p, + if file_type.is_dir() { + RecursiveMode::Recursive + } else { + RecursiveMode::NonRecursive + }, + ); + } + }); + } loop { let on_exit = on_exit.clone();