From dc074363d180195b6f947eb37d62cf6ae8f98349 Mon Sep 17 00:00:00 2001 From: Essien Ita Essien Date: Mon, 8 Jan 2024 10:41:07 +0000 Subject: [PATCH] no-op: Move external git repo canonicalization into Workspace::init_git_external * Move canonicalization of the external git repo path into the Workspace::init_git_external(). This keeps necessary code together. * Add a new variant of WorkspaceInitError for reporting path not found errors. The user error string is written to pass existing tests. --- cli/src/cli_util.rs | 3 +++ cli/src/commands/init.rs | 12 +----------- lib/src/workspace.rs | 15 ++++++++++++++- 3 files changed, 18 insertions(+), 12 deletions(-) diff --git a/cli/src/cli_util.rs b/cli/src/cli_util.rs index f23e06cec..a652dcb46 100644 --- a/cli/src/cli_util.rs +++ b/cli/src/cli_util.rs @@ -191,6 +191,9 @@ impl From for CommandError { WorkspaceInitError::Path(err) => { CommandError::InternalError(format!("Failed to access the repository: {err}")) } + WorkspaceInitError::PathNotFound(path) => { + user_error(format!("{} doesn't exist", path.display())) + } WorkspaceInitError::Backend(err) => { user_error(format!("Failed to access the repository: {err}")) } diff --git a/cli/src/commands/init.rs b/cli/src/commands/init.rs index b30998003..906ba8531 100644 --- a/cli/src/commands/init.rs +++ b/cli/src/commands/init.rs @@ -66,17 +66,7 @@ pub(crate) fn cmd_init( let relative_wc_path = file_util::relative_path(&cwd, &wc_path); if let Some(git_store_str) = &args.git_repo { - let mut git_store_path = command.cwd().join(git_store_str); - git_store_path = git_store_path - .canonicalize() - .map_err(|_| user_error(format!("{} doesn't exist", git_store_path.display())))?; - if !git_store_path.ends_with(".git") { - git_store_path.push(".git"); - // Undo if .git doesn't exist - likely a bare repo. - if !git_store_path.exists() { - git_store_path.pop(); - } - } + let git_store_path = cwd.join(git_store_str); let (workspace, repo) = Workspace::init_external_git(command.settings(), &wc_path, &git_store_path)?; let mut workspace_command = command.for_loaded_repo(ui, workspace, repo)?; diff --git a/lib/src/workspace.rs b/lib/src/workspace.rs index 4bef895cc..a39fdc9e1 100644 --- a/lib/src/workspace.rs +++ b/lib/src/workspace.rs @@ -48,6 +48,8 @@ pub enum WorkspaceInitError { DestinationExists(PathBuf), #[error("Repo path could not be interpreted as Unicode text")] NonUnicodePath, + #[error("Path {0} does not exist")] + PathNotFound(PathBuf), #[error(transparent)] CheckOutCommit(#[from] CheckOutCommitError), #[error(transparent)] @@ -194,6 +196,17 @@ impl Workspace { workspace_root: &Path, git_repo_path: &Path, ) -> Result<(Self, Arc), WorkspaceInitError> { + let mut git_repo_path = git_repo_path + .canonicalize() + .map_err(|_| WorkspaceInitError::PathNotFound(git_repo_path.to_path_buf()))?; + if !git_repo_path.ends_with(".git") { + git_repo_path.push(".git"); + + if !git_repo_path.exists() { + git_repo_path.pop(); + } + } + let backend_initializer = |settings: &UserSettings, store_path: &Path| -> Result, _> { // If the git repo is inside the workspace, use a relative path to it so the @@ -203,7 +216,7 @@ impl Workspace { // Workspace::new(), but it's not yet here. let store_relative_git_repo_path = match ( workspace_root.canonicalize(), - canonicalize_git_repo_path(git_repo_path), + canonicalize_git_repo_path(&git_repo_path), ) { (Ok(workspace_root), Ok(git_repo_path)) if git_repo_path.starts_with(&workspace_root) =>