diff --git a/crates/cli/src/main.rs b/crates/cli/src/main.rs index 9c6ec08219437ce1da4b1252f7ee75e7d11bd780..459a8266c7fc2412e3210ef4f21ead0883de50e2 100644 --- a/crates/cli/src/main.rs +++ b/crates/cli/src/main.rs @@ -642,14 +642,6 @@ fn main() -> Result<()> { } } - // When only diff paths are provided (no regular paths), add the current - // working directory so the workspace opens with the right context. - if paths.is_empty() && urls.is_empty() && !diff_paths.is_empty() { - if let Ok(cwd) = env::current_dir() { - paths.push(cwd.to_string_lossy().into_owned()); - } - } - anyhow::ensure!( args.dev_server_token.is_none(), "Dev servers were removed in v0.157.x please upgrade to SSH remoting: https://zed.dev/docs/remote-development" diff --git a/crates/zed/src/zed/open_listener.rs b/crates/zed/src/zed/open_listener.rs index e0094cb6556302de17deef1c397de5470128c333..065bb7595d8e67ede90bf12caef5f3a439a4ba5c 100644 --- a/crates/zed/src/zed/open_listener.rs +++ b/crates/zed/src/zed/open_listener.rs @@ -783,7 +783,7 @@ async fn open_workspaces( } async fn open_local_workspace( - workspace_paths: Vec, + mut workspace_paths: Vec, diff_paths: Vec<[String; 2]>, diff_all: bool, open_options: workspace::OpenOptions, @@ -791,6 +791,16 @@ async fn open_local_workspace( app_state: &Arc, cx: &mut AsyncApp, ) -> bool { + let user_provided_paths = !workspace_paths.is_empty(); + + // When only diff paths are provided (no regular paths), add the current + // working directory so the workspace opens with the right context. + if !user_provided_paths && !diff_paths.is_empty() { + if let Ok(cwd) = std::env::current_dir() { + workspace_paths.push(cwd.to_string_lossy().into_owned()); + } + } + let paths_with_position = derive_paths_with_position(app_state.fs.as_ref(), workspace_paths).await; @@ -822,10 +832,12 @@ async fn open_local_workspace( // the entire workspace is closed. if open_options.wait { let mut wait_for_window_close = paths_with_position.is_empty() && diff_paths.is_empty(); - for path_with_position in &paths_with_position { - if app_state.fs.is_dir(&path_with_position.path).await { - wait_for_window_close = true; - break; + if user_provided_paths { + for path_with_position in &paths_with_position { + if app_state.fs.is_dir(&path_with_position.path).await { + wait_for_window_close = true; + break; + } } }